X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=i3status.h;h=aa7f20e39a1953da7ba8ba2544584c436ea36591;hb=112512c546c8d9a46b503b5e4b9cc10afb1a248e;hp=da8714130fce7003bcc582cdf216ac34a3174933;hpb=6fda988f360b3145d5772b6964f336dd652357ea;p=i3%2Fi3status diff --git a/i3status.h b/i3status.h index da87141..aa7f20e 100644 --- a/i3status.h +++ b/i3status.h @@ -5,12 +5,47 @@ #include "queue.h" -#define BAR "^fg(#333333)^p(5;-2)^ro(2)^p()^fg()^p(5)" +#ifdef DZEN + #define BAR "^fg(#333333)^p(5;-2)^ro(2)^p()^fg()^p(5)" +#elif XMOBAR + #define BAR " | " +#endif #define BEGINS_WITH(haystack, needle) (strncmp(haystack, needle, strlen(needle)) == 0) #define max(a, b) (a > b ? a : b) +#define generate(orderidx, name, function) \ + do { \ + write_to_statusbar(order_to_str(order[orderidx], name), function, (j == (highest_order-1))); \ + } while (0) + +#define generate_order(condition, orderidx, name, function) \ + do { \ + if (j == order[orderidx] && condition) \ + generate(orderidx, name, function); \ + } while (0) + +#if defined(LINUX) + +#define THERMAL_ZONE "/sys/class/thermal/thermal_zone%d/temp" + +#elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__) + +#define THERMAL_ZONE "hw.acpi.thermal.tz%d.temperature" +#define BATT_LIFE "hw.acpi.battery.life" +#define BATT_TIME "hw.acpi.battery.time" +#define BATT_STATE "hw.acpi.battery.state" + +#endif + +#if defined(__FreeBSD_kernel__) && defined(__GLIBC__) + +#include +#include + +#endif + typedef enum { CS_DISCHARGING, CS_CHARGING, CS_FULL } charging_status_t; -enum { ORDER_RUN, ORDER_WLAN, ORDER_ETH, ORDER_BATTERY, ORDER_CPU_TEMPERATURE, ORDER_LOAD, ORDER_TIME, MAX_ORDER }; +enum { ORDER_RUN, ORDER_WLAN, ORDER_ETH, ORDER_BATTERY, ORDER_CPU_TEMPERATURE, ORDER_LOAD, ORDER_TIME, ORDER_IPV6, MAX_ORDER }; struct battery { char *path; @@ -22,15 +57,16 @@ struct battery { /* src/general.c */ char *skip_character(char *input, char character, int amount); void die(const char *fmt, ...); -char *concat(const char *str1, const char *str2); void create_file(const char *name); +char *order_to_str(int number, char *name); void setup(void); void write_to_statusbar(const char *name, const char *message, bool final_entry); -void slurp(char *filename, char *destination, int size); +bool slurp(char *filename, char *destination, int size); /* src/output.c */ void write_error_to_statusbar(const char *message); char *color(const char *colorstr); +char *endcolor() __attribute__ ((pure)); void cleanup_rbar_dir(); /* src/config.c */ @@ -51,16 +87,19 @@ extern struct battery_head batteries; /* socket file descriptor for general purposes */ extern int general_socket; +extern int highest_order; + extern const char *wlan_interface; extern const char *eth_interface; -extern const char *wmii_path; +extern char *wmii_path; extern const char *time_format; extern bool use_colors; extern bool get_ethspeed; +extern bool get_ipv6; extern bool get_cpu_temperature; extern char *thermal_zone; extern const char *wmii_normcolors; -extern char order[MAX_ORDER][2]; +extern int order[MAX_ORDER]; extern const char **run_watches; extern unsigned int num_run_watches; extern unsigned int interval;