#include <unistd.h>
#include <X11/Xlib.h>
-/* global variables */
-static Display *dpy;
-
-/* statusbar configuration type and struct */
-typedef char *(*op_fun) (const char *);
-struct arg {
- op_fun func;
- const char *format;
- const char *args;
-};
-
-/* functions */
-void setstatus(const char *);
-char *smprintf(const char *, ...);
-char *get_battery(const char *);
-char *get_cpu_temperature(const char *);
-char *get_cpu_usage(const char *);
-char *get_datetime(const char *);
-char *get_diskusage(const char *);
-char *get_ram_usage(const char *);
-char *get_volume(const char *);
-char *get_wifi_signal(const char *);
-
-/* include config header */
+/* local headers */
+#include "slstatus.h"
#include "config.h"
/* set statusbar */
/* battery percentage */
char *
-get_battery(const char *battery)
+battery_perc(const char *battery)
{
int now, full, perc;
char batterynowfile[64] = "";
return smprintf("%d%%", perc);
}
-/* cpu temperature */
-char *
-get_cpu_temperature(const char *file)
-{
- int temperature;
- FILE *fp;
-
- /* open temperature file */
- if (!(fp = fopen(file, "r"))) {
- fprintf(stderr, "Could not open temperature file.\n");
- return smprintf("n/a");
- }
-
- /* extract temperature */
- fscanf(fp, "%d", &temperature);
-
- /* close temperature file */
- fclose(fp);
-
- /* return temperature in degrees */
- return smprintf("%d°C", temperature / 1000);
-}
-
/* cpu percentage */
char *
-get_cpu_usage(const char *null)
+cpu_perc(const char *null)
{
int perc;
long double a[4], b[4];
/* date and time */
char *
-get_datetime(const char *timeformat)
+datetime(const char *timeformat)
{
time_t tm;
size_t bufsize = 64;
setlocale(LC_TIME, "C");
/* return time */
- return smprintf("%s", buf);
+ char *ret = smprintf("%s", buf);
+ free(buf);
+ return ret;
}
/* disk usage percentage */
char *
-get_diskusage(const char *mountpoint)
+disk_perc(const char *mountpoint)
{
int perc = 0;
struct statvfs fs;
/* ram percentage */
char *
-get_ram_usage(const char *null)
+ram_perc(const char *null)
{
int perc;
long total, free, buffers, cached;
return smprintf("%d%%", perc);
}
+/* temperature */
+char *
+temp(const char *file)
+{
+ int temperature;
+ FILE *fp;
+
+ /* open temperature file */
+ if (!(fp = fopen(file, "r"))) {
+ fprintf(stderr, "Could not open temperature file.\n");
+ return smprintf("n/a");
+ }
+
+ /* extract temperature */
+ fscanf(fp, "%d", &temperature);
+
+ /* close temperature file */
+ fclose(fp);
+
+ /* return temperature in degrees */
+ return smprintf("%d°C", temperature / 1000);
+}
+
+
/* alsa volume percentage */
char *
-get_volume(const char *soundcard)
+vol_perc(const char *soundcard)
{
int mute = 0;
long vol = 0, max = 0, min = 0;
/* wifi percentage */
char *
-get_wifi_signal(const char *wificard)
+wifi_perc(const char *wificard)
{
int bufsize = 255;
int strength;
/* return status every interval */
for (;;) {
/* clear the string */
- strcpy(status_string, "");
+ memset(status_string, 0, sizeof(status_string));
/* generate status_string */
for (size_t i = 0; i < sizeof(args) / sizeof(args[0]); ++i) {
char *res = argument.func(argument.args);
char *element = smprintf(argument.format, res);
strcat(status_string, element);
+ free(res);
+ free(element);
}
/* return the statusbar */