/* local libraries */
#include "config.h"
+/* check file macro */
+#define CHECK_FILE(X,Y) do { \
+ if (stat(X,&Y) < 0) return -1; \
+ if (!S_ISREG(Y.st_mode)) return -1; \
+} while (0);
+
/* functions */
-void setstatus(char *str);
int config_check();
+void setstatus(char *str);
char *smprintf(char *fmt, ...);
char *get_battery();
char *get_cpu_temperature();
/* global variables */
static Display *dpy;
+/* check configured paths */
+int
+config_check()
+{
+ struct stat fs;
+
+ /* check all files in the config.h file */
+ CHECK_FILE(batterynowfile, fs);
+ CHECK_FILE(batteryfullfile, fs);
+ CHECK_FILE(tempfile, fs);
+
+ /* check update interval */
+ if (update_interval < 1)
+ return -1;
+
+ /* exit successfully */
+ return 0;
+}
+
/* set statusbar (WM_NAME) */
void
setstatus(char *str)
return ret;
}
-#define CHECK_FILE(X,Y) do { \
- if (stat(X,&Y) < 0) return -1; \
- if (!S_ISREG(Y.st_mode)) return -1; \
-} while (0);
-
-/* check configured paths */
-int
-config_check()
-{
- struct stat fs;
- CHECK_FILE(batterynowfile, fs);
- CHECK_FILE(batteryfullfile, fs);
- CHECK_FILE(tempfile, fs);
- return 0;
-}
-
/* battery percentage */
char *
get_battery()
/* open battery now file */
if (!(fp = fopen(batterynowfile, "r"))) {
fprintf(stderr, "Error opening battery file.");
- exit(1);
+ return smprintf("n/a");
}
/* read value */
/* open battery full file */
if (!(fp = fopen(batteryfullfile, "r"))) {
fprintf(stderr, "Error opening battery file.");
- exit(1);
+ return smprintf("n/a");
}
/* read value */
/* open temperature file */
if (!(fp = fopen(tempfile, "r"))) {
fprintf(stderr, "Could not open temperature file.\n");
- exit(1);
+ return smprintf("n/a");
}
/* extract temperature */
/* open stat file */
if (!(fp = fopen("/proc/stat","r"))) {
fprintf(stderr, "Error opening stat file.");
- exit(1);
+ return smprintf("n/a");
}
/* read values */
/* open stat file */
if (!(fp = fopen("/proc/stat","r"))) {
fprintf(stderr, "Error opening stat file.");
- exit(1);
+ return smprintf("n/a");
}
/* read values */
/* get time in format */
time(&tm);
if(!strftime(buf, bufsize, timeformat, localtime(&tm))) {
- fprintf(stderr, "Strftime failed.\n");
- exit(1);
+ fprintf(stderr, "Strftime failed.\n");
+ return smprintf("n/a");
}
/* return time */
/* open meminfo file */
if (!(fp = fopen("/proc/meminfo", "r"))) {
fprintf(stderr, "Error opening meminfo file.");
- exit(1);
+ return smprintf("n/a");
}
/* read the values */
/* open wifi file */
if(!(fp = fopen(path, "r"))) {
fprintf(stderr, "Error opening wifi operstate file.");
- exit(1);
+ return smprintf("n/a");
}
/* read the status */
/* check if interface down */
if(strcmp(status, "up\n") != 0){
- return "n/a";
+ return smprintf("n/a");
}
/* open wifi file */
if (!(fp = fopen("/proc/net/wireless", "r"))) {
fprintf(stderr, "Error opening wireless file.");
- exit(1);
+ return smprintf("n/a");
}
/* extract the signal strength */
/* check config for sanity */
if (config_check() < 0) {
- fprintf(stderr, "Config error, please check paths and recompile\n");
+ fprintf(stderr, "Config error, please check paths and interval and recompile!\n");
exit(1);
}
+
/* open display */
if (!(dpy = XOpenDisplay(0x0))) {
fprintf(stderr, "Cannot open display!\n");
free(ram_usage);
free(volume);
free(wifi_signal);
- sleep(update_interval);
+
+ /* wait, "update_interval - 1" because of get_cpu_usage() which uses 1 second */
+ sleep(update_interval -1);
}
/* close display */