diff --git a/src/common.c b/src/common.c index 7d664a1c..d648c781 100644 --- a/src/common.c +++ b/src/common.c @@ -179,7 +179,7 @@ void variable_substitute(const char *s, char *dest, unsigned int n) static struct net_stat netstats[16]; -struct net_stat *get_net_stat(const char *dev) +struct net_stat *get_net_stat(const char *dev, void *free_at_crash1, void *free_at_crash2) { unsigned int i; @@ -202,7 +202,7 @@ struct net_stat *get_net_stat(const char *dev) } } - CRIT_ERR("too many interfaces used (limit is 16)"); + CRIT_ERR(free_at_crash1, free_at_crash2, "too many interfaces used (limit is 16)"); return 0; } @@ -224,7 +224,7 @@ int interface_up(const char *dev) struct ifreq ifr; if ((fd = socket(PF_INET, SOCK_DGRAM, 0)) < 0) { - CRIT_ERR("could not create sockfd"); + CRIT_ERR(NULL, NULL, "could not create sockfd"); return 0; } strncpy(ifr.ifr_name, dev, IFNAMSIZ); diff --git a/src/common.h b/src/common.h index 32241dda..ba2bb179 100644 --- a/src/common.h +++ b/src/common.h @@ -74,7 +74,7 @@ struct net_stat { char ap[18]; }; void clear_net_stats(void); -struct net_stat *get_net_stat(const char *); +struct net_stat *get_net_stat(const char *dev, void *free_at_crash1, void *free_at_crash2); int interface_up(const char *dev); void get_adt746x_cpu(char *, size_t); diff --git a/src/conky.c b/src/conky.c index 687018d3..d3a0c93e 100644 --- a/src/conky.c +++ b/src/conky.c @@ -378,11 +378,11 @@ int register_iconv(iconv_t *new_iconv) { iconv_cd = realloc(iconv_cd, sizeof(iconv_t *) * (iconv_count + 1)); if (!iconv_cd) { - CRIT_ERR("Out of memory"); + CRIT_ERR(NULL, NULL, "Out of memory"); } iconv_cd[iconv_count] = malloc(sizeof(iconv_t)); if (!iconv_cd[iconv_count]) { - CRIT_ERR("Out of memory"); + CRIT_ERR(NULL, NULL, "Out of memory"); } memcpy(iconv_cd[iconv_count], new_iconv, sizeof(iconv_t)); iconv_count++; @@ -1233,7 +1233,7 @@ static int parse_top_args(const char *s, const char *arg, struct text_object *ob /* construct_text_object() creates a new text_object */ static struct text_object *construct_text_object(const char *s, - const char *arg, long line, char allow_threaded, void **ifblock_opaque) + const char *arg, long line, char allow_threaded, void **ifblock_opaque, void *free_at_crash) { // struct text_object *obj = new_text_object(); struct text_object *obj = new_text_object_internal(); @@ -1300,10 +1300,10 @@ static struct text_object *construct_text_object(const char *s, } obj->data.read_tcp.port = htons(obj->data.read_tcp.port); if(obj->data.read_tcp.port < 1 || obj->data.read_tcp.port > 65535) { - CRIT_ERR("read_tcp: Needs \"(host) port\" as argument(s)"); + CRIT_ERR(obj, free_at_crash, "read_tcp: Needs \"(host) port\" as argument(s)"); } }else{ - CRIT_ERR("read_tcp: Needs \"(host) port\" as argument(s)"); + CRIT_ERR(obj, free_at_crash, "read_tcp: Needs \"(host) port\" as argument(s)"); } #if defined(__linux__) END OBJ(voltage_mv, 0) @@ -1332,76 +1332,76 @@ static struct text_object *construct_text_object(const char *s, #ifdef HAVE_IWLIB END OBJ(wireless_essid, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_mode, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_bitrate, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_ap, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_link_qual, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_link_qual_max, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_link_qual_perc, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(wireless_link_bar, INFO_NET) SIZE_DEFAULTS(bar); if (arg) { arg = scan_bar(arg, &obj->a, &obj->b); - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } #endif /* HAVE_IWLIB */ @@ -1464,7 +1464,7 @@ static struct text_object *construct_text_object(const char *s, if (arg) obj->data.s = strndup(dev_name(arg), text_buffer_size); else - CRIT_ERR("disk_protect needs an argument"); + CRIT_ERR(obj, free_at_crash, "disk_protect needs an argument"); END OBJ(i8k_version, INFO_I8K) END OBJ(i8k_bios, INFO_I8K) END OBJ(i8k_serial, INFO_I8K) @@ -1479,7 +1479,7 @@ static struct text_object *construct_text_object(const char *s, END OBJ(ibm_fan, 0) END OBJ(ibm_temps, 0) if (!arg) { - CRIT_ERR("ibm_temps: needs an argument"); + CRIT_ERR(obj, free_at_crash, "ibm_temps: needs an argument"); } if (!isdigit(arg[0]) || strlen(arg) >= 2 || atoi(&arg[0]) >= 8) { obj->data.sensor = 0; @@ -1496,7 +1496,7 @@ static struct text_object *construct_text_object(const char *s, END OBJ_IF(if_gw, INFO_GW) END OBJ(ioscheduler, 0) if (!arg) { - CRIT_ERR("get_ioscheduler needs an argument (e.g. hda)"); + CRIT_ERR(obj, free_at_crash, "get_ioscheduler needs an argument (e.g. hda)"); obj->data.s = 0; } else obj->data.s = strndup(dev_name(arg), text_buffer_size); @@ -1527,7 +1527,7 @@ static struct text_object *construct_text_object(const char *s, #if defined(__OpenBSD__) END OBJ(obsd_sensors_temp, 0) if (!arg) { - CRIT_ERR("obsd_sensors_temp: needs an argument"); + CRIT_ERR(obj, free_at_crash, "obsd_sensors_temp: needs an argument"); } if (!isdigit(arg[0]) || atoi(&arg[0]) < 0 || atoi(&arg[0]) > OBSD_MAX_SENSORS - 1) { @@ -1537,7 +1537,7 @@ static struct text_object *construct_text_object(const char *s, obj->data.sensor = atoi(&arg[0]); END OBJ(obsd_sensors_fan, 0) if (!arg) { - CRIT_ERR("obsd_sensors_fan: needs 2 arguments (device and sensor " + CRIT_ERR(obj, free_at_crash, "obsd_sensors_fan: needs 2 arguments (device and sensor " "number)"); } if (!isdigit(arg[0]) || atoi(&arg[0]) < 0 @@ -1548,7 +1548,7 @@ static struct text_object *construct_text_object(const char *s, obj->data.sensor = atoi(&arg[0]); END OBJ(obsd_sensors_volt, 0) if (!arg) { - CRIT_ERR("obsd_sensors_volt: needs 2 arguments (device and sensor " + CRIT_ERR(obj, free_at_crash, "obsd_sensors_volt: needs 2 arguments (device and sensor " "number)"); } if (!isdigit(arg[0]) || atoi(&arg[0]) < 0 @@ -1674,20 +1674,20 @@ static struct text_object *construct_text_object(const char *s, END OBJ(conky_build_arch, 0) END OBJ(downspeed, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(downspeedf, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } #ifdef X11 @@ -1699,7 +1699,7 @@ static struct text_object *construct_text_object(const char *s, // default to DEFAULTNETDEV buf = strndup(buf ? buf : DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); #endif /* X11 */ END OBJ(else, 0) @@ -2021,21 +2021,21 @@ static struct text_object *construct_text_object(const char *s, } } else OBJ(addr, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } #if defined(__linux__) END OBJ(addrs, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } #endif /* __linux__ */ @@ -2053,13 +2053,13 @@ static struct text_object *construct_text_object(const char *s, if (arg) { obj->data.s = strndup(arg, text_buffer_size); }else{ - CRIT_ERR("lines needs a argument"); + CRIT_ERR(obj, free_at_crash, "lines needs a argument"); } END OBJ(words, 0) if (arg) { obj->data.s = strndup(arg, text_buffer_size); }else{ - CRIT_ERR("words needs a argument"); + CRIT_ERR(obj, free_at_crash, "words needs a argument"); } END OBJ(loadavg, INFO_LOADAVG) int a = 1, b = 2, c = 3, r = 3; @@ -2466,7 +2466,7 @@ static struct text_object *construct_text_object(const char *s, #ifdef HAVE_ICONV END OBJ(iconv_start, 0) if (iconv_converting) { - CRIT_ERR("You must stop your last iconv conversion before " + CRIT_ERR(obj, free_at_crash, "You must stop your last iconv conversion before " "starting another"); } if (arg) { @@ -2474,7 +2474,7 @@ static struct text_object *construct_text_object(const char *s, char iconv_to[CODEPAGE_LENGTH]; if (sscanf(arg, "%s %s", iconv_from, iconv_to) != 2) { - CRIT_ERR("Invalid arguments for iconv_start"); + CRIT_ERR(obj, free_at_crash, "Invalid arguments for iconv_start"); } else { iconv_t new_iconv; @@ -2487,7 +2487,7 @@ static struct text_object *construct_text_object(const char *s, } } } else { - CRIT_ERR("Iconv requires arguments"); + CRIT_ERR(obj, free_at_crash, "Iconv requires arguments"); } END OBJ(iconv_stop, 0) iconv_converting = 0; @@ -2495,27 +2495,27 @@ static struct text_object *construct_text_object(const char *s, #endif END OBJ(totaldown, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(totalup, INFO_NET) - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(updates, 0) END OBJ_IF(if_updatenr, 0) obj->data.ifblock.i = arg ? atoi(arg) : 0; - if(obj->data.ifblock.i == 0) CRIT_ERR("if_updatenr needs a number above 0 as argument"); + if(obj->data.ifblock.i == 0) CRIT_ERR(obj, free_at_crash, "if_updatenr needs a number above 0 as argument"); updatereset = obj->data.ifblock.i > updatereset ? obj->data.ifblock.i : updatereset; END OBJ(alignr, 0) obj->data.i = arg ? atoi(arg) : 0; @@ -2523,20 +2523,20 @@ static struct text_object *construct_text_object(const char *s, obj->data.i = arg ? atoi(arg) : 0; END OBJ(upspeed, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } END OBJ(upspeedf, INFO_NET) if (arg) { - obj->data.net = get_net_stat(arg); + obj->data.net = get_net_stat(arg, obj, free_at_crash); } else { // default to DEFAULTNETDEV char *buf = strndup(DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); } @@ -2549,7 +2549,7 @@ static struct text_object *construct_text_object(const char *s, // default to DEFAULTNETDEV buf = strndup(buf ? buf : DEFAULTNETDEV, text_buffer_size); - obj->data.net = get_net_stat(buf); + obj->data.net = get_net_stat(buf, obj, free_at_crash); free(buf); #endif END OBJ(uptime_short, INFO_UPTIME) @@ -2741,7 +2741,7 @@ static struct text_object *construct_text_object(const char *s, if (info.audacious.max_title_len > 0) { info.audacious.max_title_len++; } else { - CRIT_ERR("audacious_title: invalid length argument"); + CRIT_ERR(obj, free_at_crash, "audacious_title: invalid length argument"); } } END OBJ(audacious_length, INFO_AUDACIOUS) @@ -2790,7 +2790,7 @@ static struct text_object *construct_text_object(const char *s, init_eve(); } else { - CRIT_ERR("eve needs arguments: "); + CRIT_ERR(obj, free_at_crash, "eve needs arguments: "); } #endif #ifdef RSS @@ -2811,7 +2811,7 @@ static struct text_object *construct_text_object(const char *s, init_rss_info(); } else { - CRIT_ERR("rss needs arguments: " + CRIT_ERR(obj, free_at_crash, "rss needs arguments: " "[act_par] [spaces in front]"); } #endif @@ -2847,7 +2847,7 @@ static struct text_object *construct_text_object(const char *s, obj->data.weather.interval = interval * 60; // convert to seconds free(icao); } else { - CRIT_ERR("weather needs arguments: [interval in minutes]"); + CRIT_ERR(obj, free_at_crash, "weather needs arguments: [interval in minutes]"); } #endif #ifdef HAVE_LUA @@ -2855,13 +2855,13 @@ static struct text_object *construct_text_object(const char *s, if (arg) { obj->data.s = strndup(arg, text_buffer_size); } else { - CRIT_ERR("lua needs arguments: [function parameters]"); + CRIT_ERR(obj, free_at_crash, "lua needs arguments: [function parameters]"); } END OBJ(lua_parse, 0) if (arg) { obj->data.s = strndup(arg, text_buffer_size); } else { - CRIT_ERR("lua_parse needs arguments: [function parameters]"); + CRIT_ERR(obj, free_at_crash, "lua_parse needs arguments: [function parameters]"); } END OBJ(lua_bar, 0) SIZE_DEFAULTS(bar); @@ -2870,10 +2870,10 @@ static struct text_object *construct_text_object(const char *s, if(arg) { obj->data.s = strndup(arg, text_buffer_size); } else { - CRIT_ERR("lua_bar needs arguments: , [function parameters]"); + CRIT_ERR(obj, free_at_crash, "lua_bar needs arguments: , [function parameters]"); } } else { - CRIT_ERR("lua_bar needs arguments: , [function parameters]"); + CRIT_ERR(obj, free_at_crash, "lua_bar needs arguments: , [function parameters]"); } #ifdef X11 END OBJ(lua_graph, 0) @@ -2885,10 +2885,10 @@ static struct text_object *construct_text_object(const char *s, if (buf) { obj->data.s = buf; } else { - CRIT_ERR("lua_graph needs arguments: [height],[width] [gradient colour 1] [gradient colour 2] [scale] [-t] [-l]"); + CRIT_ERR(obj, free_at_crash, "lua_graph needs arguments: [height],[width] [gradient colour 1] [gradient colour 2] [scale] [-t] [-l]"); } } else { - CRIT_ERR("lua_graph needs arguments: [height],[width] [gradient colour 1] [gradient colour 2] [scale] [-t] [-l]"); + CRIT_ERR(obj, free_at_crash, "lua_graph needs arguments: [height],[width] [gradient colour 1] [gradient colour 2] [scale] [-t] [-l]"); } END OBJ(lua_gauge, 0) SIZE_DEFAULTS(gauge); @@ -2897,10 +2897,10 @@ static struct text_object *construct_text_object(const char *s, if (arg) { obj->data.s = strndup(arg, text_buffer_size); } else { - CRIT_ERR("lua_gauge needs arguments: , [function parameters]"); + CRIT_ERR(obj, free_at_crash, "lua_gauge needs arguments: , [function parameters]"); } } else { - CRIT_ERR("lua_gauge needs arguments: , [function parameters]"); + CRIT_ERR(obj, free_at_crash, "lua_gauge needs arguments: , [function parameters]"); } #endif /* X11 */ #endif /* HAVE_LUA */ @@ -2930,14 +2930,14 @@ static struct text_object *construct_text_object(const char *s, obj->sub = malloc(sizeof(struct text_object)); extract_variable_text_internal(obj->sub, arg, 0); }else{ - CRIT_ERR("blink needs a argument"); + CRIT_ERR(obj, free_at_crash, "blink needs a argument"); } END OBJ(to_bytes, 0) if(arg) { obj->sub = malloc(sizeof(struct text_object)); extract_variable_text_internal(obj->sub, arg, 0); }else{ - CRIT_ERR("to_bytes needs a argument"); + CRIT_ERR(obj, free_at_crash, "to_bytes needs a argument"); } END OBJ(scroll, 0) int n1, n2; @@ -2952,7 +2952,7 @@ static struct text_object *construct_text_object(const char *s, extract_variable_text_internal(obj->sub, obj->data.scroll.text, 0); } else { - CRIT_ERR("scroll needs arguments: [] "); + CRIT_ERR(obj, free_at_crash, "scroll needs arguments: [] "); } END OBJ(combine, 0) if(arg) { @@ -2998,17 +2998,17 @@ static struct text_object *construct_text_object(const char *s, obj->sub->sub = malloc(sizeof(struct text_object)); extract_variable_text_internal(obj->sub->sub, obj->data.combine.right, 0); } else { - CRIT_ERR("combine needs arguments: "); + CRIT_ERR(obj, free_at_crash, "combine needs arguments: "); } } else { - CRIT_ERR("combine needs arguments: "); + CRIT_ERR(obj, free_at_crash, "combine needs arguments: "); } #ifdef NVIDIA END OBJ(nvidia, 0) if (!arg) { - CRIT_ERR("nvidia needs an argument\n"); + CRIT_ERR(obj, free_at_crash, "nvidia needs an argument\n"); } else if (set_nvidia_type(&obj->data.nvidia, arg)) { - CRIT_ERR("nvidia: invalid argument" + CRIT_ERR(obj, free_at_crash, "nvidia: invalid argument" " specified: '%s'\n", arg); } #endif /* NVIDIA */ @@ -3019,13 +3019,13 @@ static struct text_object *construct_text_object(const char *s, char host[64]; int port; if (sscanf(arg, "%63s %d", host, &port) != 2) { - CRIT_ERR("apcupsd needs arguments: "); + CRIT_ERR(obj, free_at_crash, "apcupsd needs arguments: "); } else { info.apcupsd.port = htons(port); strncpy(info.apcupsd.host, host, sizeof(info.apcupsd.host)); } } else { - CRIT_ERR("apcupsd needs arguments: "); + CRIT_ERR(obj, free_at_crash, "apcupsd needs arguments: "); } END OBJ(apcupsd_name, INFO_APCUPSD) END OBJ(apcupsd_model, INFO_APCUPSD) @@ -3237,7 +3237,7 @@ static char *find_and_replace_templates(const char *inbuf) *(p - 1) = '\0'; } else { // we ran into the end of string without finding a closing }, bark - CRIT_ERR("cannot find a closing '}' in template expansion"); + CRIT_ERR(NULL, NULL, "cannot find a closing '}' in template expansion"); } } else { templ = p + 1; @@ -3440,7 +3440,7 @@ static int extract_variable_text_internal(struct text_object *retval, const char obj = construct_text_object(buf, arg, line, allow_threaded, - &ifblock_opaque); + &ifblock_opaque, orig_p); if (obj != NULL) { append_object(retval, obj); } @@ -3869,7 +3869,7 @@ static void generate_text_internal(char *p, int p_max_size, if (obj->data.cpu_index > info.cpu_count) { ERR("obj->data.cpu_index %i info.cpu_count %i", obj->data.cpu_index, info.cpu_count); - CRIT_ERR("attempting to use more CPUs than you have!"); + CRIT_ERR(NULL, NULL, "attempting to use more CPUs than you have!"); } percent_print(p, p_max_size, round_to_int(cur->cpu_usage[obj->data.cpu_index] * 100.0)); @@ -6992,7 +6992,7 @@ static void main_loop(void) #ifdef SIGNAL_BLOCKING /* block signals. we will inspect for pending signals later */ if (sigprocmask(SIG_BLOCK, &newmask, &oldmask) < 0) { - CRIT_ERR("unable to sigprocmask()"); + CRIT_ERR(NULL, NULL, "unable to sigprocmask()"); } #endif @@ -7300,7 +7300,7 @@ static void main_loop(void) #ifdef SIGNAL_BLOCKING /* unblock signals of interest and let handler fly */ if (sigprocmask(SIG_SETMASK, &oldmask, NULL) < 0) { - CRIT_ERR("unable to sigprocmask()"); + CRIT_ERR(NULL, NULL, "unable to sigprocmask()"); } #endif @@ -7395,7 +7395,7 @@ static void main_loop(void) g_signal_pending = 0; } - clean_up(); + clean_up(NULL, NULL); #ifdef HAVE_SYS_INOTIFY_H if (inotify_fd != -1) { @@ -7486,9 +7486,15 @@ static void reload_config(void) } } -void clean_up(void) +void clean_up(void *memtofree1, void* memtofree2) { int i; + if(memtofree1) { + free(memtofree1); + } + if(memtofree2) { + free(memtofree2); + } timed_thread_destroy_registered_threads(); if (info.cpu_usage) { @@ -8642,7 +8648,7 @@ static void load_config_file(const char *f) } fclose(fp); if (strlen(global_text) < 1) { - CRIT_ERR("no text supplied in configuration; exiting"); + CRIT_ERR(NULL, NULL, "no text supplied in configuration; exiting"); } global_text_lines = line + 1; return; @@ -8762,7 +8768,7 @@ static void load_config_file(const char *f) info.music_player_interval = update_interval; } if (!global_text) { // didn't supply any text - CRIT_ERR("missing text block in configuration; exiting"); + CRIT_ERR(NULL, NULL, "missing text block in configuration; exiting"); } } @@ -9148,7 +9154,7 @@ int main(int argc, char **argv) ERR("no readable personal or system-wide config file found," " using builtin default"); #else - CRIT_ERR("no readable personal or system-wide config file found"); + CRIT_ERR(NULL, NULL, "no readable personal or system-wide config file found"); #endif /* ! CONF_OUTPUT */ } } @@ -9187,7 +9193,7 @@ int main(int argc, char **argv) #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) if ((kd = kvm_open("/dev/null", "/dev/null", "/dev/null", O_RDONLY, "kvm_open")) == NULL) { - CRIT_ERR("cannot read kvm"); + CRIT_ERR(NULL, NULL, "cannot read kvm"); } #endif diff --git a/src/fonts.c b/src/fonts.c index bb5f47ff..1db76239 100644 --- a/src/fonts.c +++ b/src/fonts.c @@ -67,7 +67,7 @@ int add_font(const char *data_in) return 0; } if (font_count > MAX_FONTS) { - CRIT_ERR("you don't need that many fonts, sorry."); + CRIT_ERR(NULL, NULL, "you don't need that many fonts, sorry."); } font_count++; if (font_count == 0) { @@ -76,14 +76,14 @@ int add_font(const char *data_in) } if ((fonts = (struct font_list *) malloc(sizeof(struct font_list))) == NULL) { - CRIT_ERR("malloc"); + CRIT_ERR(NULL, NULL, "malloc"); } memset(fonts, 0, sizeof(struct font_list)); } fonts = realloc(fonts, (sizeof(struct font_list) * (font_count + 1))); memset(&fonts[font_count], 0, sizeof(struct font_list)); if (fonts == NULL) { - CRIT_ERR("realloc in add_font"); + CRIT_ERR(NULL, NULL, "realloc in add_font"); } // must account for null terminator if (strlen(data_in) < DEFAULT_TEXT_BUFFER_SIZE) { @@ -92,7 +92,7 @@ int add_font(const char *data_in) fonts[font_count].font_alpha = 0xffff; #endif } else { - CRIT_ERR("Oops...looks like something overflowed in add_font()."); + CRIT_ERR(NULL, NULL, "Oops...looks like something overflowed in add_font()."); } return font_count; } @@ -105,7 +105,7 @@ void set_first_font(const char *data_in) if (font_count < 0) { if ((fonts = (struct font_list *) malloc(sizeof(struct font_list))) == NULL) { - CRIT_ERR("malloc"); + CRIT_ERR(NULL, NULL, "malloc"); } memset(fonts, 0, sizeof(struct font_list)); font_count++; @@ -180,7 +180,7 @@ void load_fonts(void) ERR("can't load Xft font '%s'", "courier-12"); if ((fonts[i].font = XLoadQueryFont(display, "fixed")) == NULL) { - CRIT_ERR("can't load font '%s'", "fixed"); + CRIT_ERR(NULL, NULL, "can't load font '%s'", "fixed"); } use_xft = 0; @@ -191,7 +191,7 @@ void load_fonts(void) if (!fonts[i].font && (fonts[i].font = XLoadQueryFont(display, fonts[i].name)) == NULL) { ERR("can't load font '%s'", fonts[i].name); if ((fonts[i].font = XLoadQueryFont(display, "fixed")) == NULL) { - CRIT_ERR("can't load font '%s'", "fixed"); + CRIT_ERR(NULL, NULL, "can't load font '%s'", "fixed"); } } } diff --git a/src/freebsd.c b/src/freebsd.c index 92ebc9f0..e1c77017 100644 --- a/src/freebsd.c +++ b/src/freebsd.c @@ -199,7 +199,7 @@ void update_net_stats(void) } for (ifa = ifap; ifa; ifa = ifa->ifa_next) { - ns = get_net_stat((const char *) ifa->ifa_name); + ns = get_net_stat((const char *) ifa->ifa_name, NULL, NULL); if (ifa->ifa_flags & IFF_UP) { struct ifaddrs *iftmp; @@ -614,7 +614,7 @@ void update_wifi_stats(void) } for (ifa = ifap; ifa; ifa = ifa->ifa_next) { - ns = get_net_stat((const char *) ifa->ifa_name); + ns = get_net_stat((const char *) ifa->ifa_name, NULL, NULL); s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP); diff --git a/src/fs.c b/src/fs.c index c2a0a3db..50c6ff9a 100644 --- a/src/fs.c +++ b/src/fs.c @@ -162,13 +162,13 @@ void get_fs_type(const char *path, char *result) fseek(mtab, 0, SEEK_SET); slash = strrchr(search_path, '/'); if (slash == NULL) - CRIT_ERR("invalid path '%s'", path); + CRIT_ERR(NULL, NULL, "invalid path '%s'", path); if (strlen(slash) == 1) /* trailing slash */ *(slash) = '\0'; else if (strlen(slash) > 1) *(slash + 1) = '\0'; else - CRIT_ERR("found a crack in the matrix!"); + CRIT_ERR(NULL, NULL, "found a crack in the matrix!"); } while (strlen(search_path) > 0); free(search_path); diff --git a/src/linux.c b/src/linux.c index e4727ab6..78121bd8 100644 --- a/src/linux.c +++ b/src/linux.c @@ -349,7 +349,7 @@ void update_net_stats(void) *p = '\0'; p++; - ns = get_net_stat(s); + ns = get_net_stat(s, NULL, NULL); ns->up = 1; memset(&(ns->addr.sa_data), 0, 14); @@ -393,7 +393,7 @@ void update_net_stats(void) break; ns2 = get_net_stat( - ((struct ifreq *) conf.ifc_buf)[k].ifr_ifrn.ifrn_name); + ((struct ifreq *) conf.ifc_buf)[k].ifr_ifrn.ifrn_name, NULL, NULL); ns2->addr = ((struct ifreq *) conf.ifc_buf)[k].ifr_ifru.ifru_addr; sprintf(temp_addr, "%u.%u.%u.%u, ", ns2->addr.sa_data[2] & 255, @@ -765,7 +765,7 @@ void update_i8k(void) i8k_procbuf = (char *) malloc(128 * sizeof(char)); } if ((fp = fopen(PROC_I8K, "r")) == NULL) { - CRIT_ERR("/proc/i8k doesn't exist! use insmod to make sure the kernel " + CRIT_ERR(NULL, NULL, "/proc/i8k doesn't exist! use insmod to make sure the kernel " "driver is loaded..."); } @@ -888,7 +888,7 @@ int open_sysfs_sensor(const char *dir, const char *dev, const char *type, int n, /* open file */ fd = open(path, O_RDONLY); if (fd < 0) { - CRIT_ERR("can't open '%s': %s\nplease check your device or remove this " + CRIT_ERR(NULL, NULL, "can't open '%s': %s\nplease check your device or remove this " "var from "PACKAGE_NAME, path, strerror(errno)); } diff --git a/src/logging.h b/src/logging.h index 0f5bb42a..ba70f233 100644 --- a/src/logging.h +++ b/src/logging.h @@ -25,7 +25,7 @@ * */ -void clean_up(void); +void clean_up(void *memtofree1, void* memtofree2); #ifndef _LOGGING_H #define _LOGGING_H @@ -37,8 +37,8 @@ void clean_up(void); } /* critical error */ -#define CRIT_ERR(...) \ - { ERR(__VA_ARGS__); clean_up(); exit(EXIT_FAILURE); } +#define CRIT_ERR(memtofree1, memtofree2, ...) \ + { ERR(__VA_ARGS__); clean_up(memtofree1, memtofree2); exit(EXIT_FAILURE); } /* debugging output */ extern int global_debug_level; diff --git a/src/mboxscan.c b/src/mboxscan.c index 5b3550dd..e2e3cfab 100644 --- a/src/mboxscan.c +++ b/src/mboxscan.c @@ -137,7 +137,7 @@ void mbox_scan(char *args, char *output, size_t max_len) free(copy_args); } if (strlen(mbox_mail_spool) < 1) { - CRIT_ERR("Usage: ${mboxscan [-n ] " + CRIT_ERR(NULL, NULL, "Usage: ${mboxscan [-n ] " "[-fw ] [-sw ] " "[-t mbox]}"); } @@ -148,7 +148,7 @@ void mbox_scan(char *args, char *output, size_t max_len) } if (stat(mbox_mail_spool, &statbuf)) { - CRIT_ERR("can't stat %s: %s", mbox_mail_spool, strerror(errno)); + CRIT_ERR(NULL, NULL, "can't stat %s: %s", mbox_mail_spool, strerror(errno)); } args_ok = 1; /* args-computing necessary only once */ } diff --git a/src/netbsd.c b/src/netbsd.c index d104c1b4..9ac3413d 100644 --- a/src/netbsd.c +++ b/src/netbsd.c @@ -186,7 +186,7 @@ void update_net_stats() long long last_recv, last_trans; kvm_read(nkd, (u_long) ifnetaddr, (void *) &ifnet, sizeof(ifnet)); - ns = get_net_stat(ifnet.if_xname); + ns = get_net_stat(ifnet.if_xname, NULL, NULL); ns->up = 1; last_recv = ns->recv; last_trans = ns->trans; diff --git a/src/openbsd.c b/src/openbsd.c index 88f8f7fc..db83ef78 100644 --- a/src/openbsd.c +++ b/src/openbsd.c @@ -211,7 +211,7 @@ void update_net_stats() } for (ifa = ifap; ifa; ifa = ifa->ifa_next) { - ns = get_net_stat((const char *) ifa->ifa_name); + ns = get_net_stat((const char *) ifa->ifa_name, NULL, NULL); if (ifa->ifa_flags & IFF_UP) { struct ifaddrs *iftmp; diff --git a/src/sony.c b/src/sony.c index 5227f564..7a25788d 100644 --- a/src/sony.c +++ b/src/sony.c @@ -65,7 +65,7 @@ void get_sony_fanspeed(char *p_client_buffer, size_t client_buffer_size) } } } else { - CRIT_ERR("can't open '%s': %s\nEnable sony support or remove " + CRIT_ERR(NULL, NULL, "can't open '%s': %s\nEnable sony support or remove " "sony* from your "PACKAGE_NAME" config file.", fan, strerror(errno)); } diff --git a/src/specials.c b/src/specials.c index 1a624483..f12c1e6c 100644 --- a/src/specials.c +++ b/src/specials.c @@ -190,7 +190,7 @@ char *scan_graph(const char *args, int *w, int *h, static struct special_t *new_special(char *buf, enum special_types t) { if (special_count >= max_specials) { - CRIT_ERR("too many special things in text"); + CRIT_ERR(NULL, NULL, "too many special things in text"); } buf[0] = SPECIAL_CHAR; diff --git a/src/tcp-portmon.c b/src/tcp-portmon.c index 987f1abf..b969b59b 100644 --- a/src/tcp-portmon.c +++ b/src/tcp-portmon.c @@ -34,19 +34,19 @@ int tcp_portmon_init(const char *arg, struct tcp_port_monitor_data *pmd) connection_index = 0; /* massive argument checking */ if (!arg) { - CRIT_ERR("tcp_portmon: needs arguments"); + CRIT_ERR(NULL, NULL, "tcp_portmon: needs arguments"); } argc = sscanf(arg, "%d %d %31s %d", &port_begin, &port_end, itembuf, &connection_index); if ((argc != 3) && (argc != 4)) { - CRIT_ERR("tcp_portmon: requires 3 or 4 arguments"); + CRIT_ERR(NULL, NULL, "tcp_portmon: requires 3 or 4 arguments"); } if ((port_begin < 1) || (port_begin > 65535) || (port_end < 1) || (port_end > 65535)) { - CRIT_ERR("tcp_portmon: port values must be from 1 to 65535"); + CRIT_ERR(NULL, NULL, "tcp_portmon: port values must be from 1 to 65535"); } if (port_begin > port_end) { - CRIT_ERR("tcp_portmon: starting port must be <= ending port"); + CRIT_ERR(NULL, NULL, "tcp_portmon: starting port must be <= ending port"); } if (strncmp(itembuf, "count", 31) == EQUAL) { item = COUNT; @@ -67,14 +67,14 @@ int tcp_portmon_init(const char *arg, struct tcp_port_monitor_data *pmd) } else if (strncmp(itembuf, "lservice", 31) == EQUAL) { item = LOCALSERVICE; } else { - CRIT_ERR("tcp_portmon: invalid item specified"); + CRIT_ERR(NULL, NULL, "tcp_portmon: invalid item specified"); } if ((argc == 3) && (item != COUNT)) { - CRIT_ERR("tcp_portmon: 3 argument form valid only for \"count\" " + CRIT_ERR(NULL, NULL, "tcp_portmon: 3 argument form valid only for \"count\" " "item"); } if ((argc == 4) && (connection_index < 0)) { - CRIT_ERR("tcp_portmon: connection index must be non-negative"); + CRIT_ERR(NULL, NULL, "tcp_portmon: connection index must be non-negative"); } /* ok, args looks good. save the text object data */ pmd->port_range_begin = (in_port_t) port_begin; @@ -87,7 +87,7 @@ int tcp_portmon_init(const char *arg, struct tcp_port_monitor_data *pmd) if (!pmc) { pmc = create_tcp_port_monitor_collection(); if (!pmc) { - CRIT_ERR("tcp_portmon: unable to create port monitor " + CRIT_ERR(NULL, NULL, "tcp_portmon: unable to create port monitor " "collection"); } } @@ -99,11 +99,11 @@ int tcp_portmon_init(const char *arg, struct tcp_port_monitor_data *pmd) port_end, &pma); if (!p_monitor) { - CRIT_ERR("tcp_portmon: unable to create port monitor"); + CRIT_ERR(NULL, NULL, "tcp_portmon: unable to create port monitor"); } /* add the newly created monitor to the collection */ if (insert_tcp_port_monitor_into_collection(pmc, p_monitor) != 0) { - CRIT_ERR("tcp_portmon: unable to add port monitor to " + CRIT_ERR(NULL, NULL, "tcp_portmon: unable to add port monitor to " "collection"); } } diff --git a/src/text_object.c b/src/text_object.c index 78a8a867..cf89c9bc 100644 --- a/src/text_object.c +++ b/src/text_object.c @@ -50,7 +50,7 @@ int append_object(struct text_object *root, struct text_object *obj) if (end) { if (end->next) - CRIT_ERR("huston, we have a lift-off"); + CRIT_ERR(NULL, NULL, "huston, we have a lift-off"); end->next = obj; } else { root->next = obj; @@ -101,7 +101,7 @@ static int push_ifblock(struct ifblock_stack_obj **ifblock_stack_top, switch (type) { case IFBLOCK_ENDIF: if (!(*ifblock_stack_top)) - CRIT_ERR("got an endif without matching if"); + CRIT_ERR(NULL, NULL, "got an endif without matching if"); (*ifblock_stack_top)->obj->data.ifblock.next = obj; /* if there's some else in between, remove and free it */ if ((*ifblock_stack_top)->type == IFBLOCK_ELSE) { @@ -116,7 +116,7 @@ static int push_ifblock(struct ifblock_stack_obj **ifblock_stack_top, break; case IFBLOCK_ELSE: if (!(*ifblock_stack_top)) - CRIT_ERR("got an else without matching if"); + CRIT_ERR(NULL, NULL, "got an else without matching if"); (*ifblock_stack_top)->obj->data.ifblock.next = obj; /* fall through */ case IFBLOCK_IF: @@ -127,7 +127,7 @@ static int push_ifblock(struct ifblock_stack_obj **ifblock_stack_top, *ifblock_stack_top = stackobj; break; default: - CRIT_ERR("push_ifblock() missuse detected!"); + CRIT_ERR(NULL, NULL, "push_ifblock() missuse detected!"); } return 0; } diff --git a/src/x11.c b/src/x11.c index 68e21a09..6f0c35f1 100644 --- a/src/x11.c +++ b/src/x11.c @@ -72,7 +72,7 @@ void init_X11(const char *disp) { if (!display) { if ((display = XOpenDisplay(disp)) == NULL) { - CRIT_ERR("can't open display: %s", XDisplayName(0)); + CRIT_ERR(NULL, NULL, "can't open display: %s", XDisplayName(0)); } }