1
0
mirror of https://github.com/Llewellynvdm/conky.git synced 2025-01-13 19:22:58 +00:00

update machinery: complete transition

* Drop all need_mask alterations (no idea why there were here at all,
  but surely not sane since they are missing in the non-linux
  functions).
* Drop the update delay for update_meminfo(), as parsing /proc should
  not lead to abnormal overhead.
* Check for x_initialised from inside update_x11info(), so we can call
  it unconditionally.
This commit is contained in:
Phil Sutter 2009-09-07 01:05:33 +02:00
parent d7c7f06aca
commit e044093735
6 changed files with 28 additions and 95 deletions

View File

@ -423,15 +423,10 @@ int no_buffers;
void update_stuff(void)
{
int i;
static double last_meminfo_update;
struct update_cb *uc;
info.mask = 0;
if (no_buffers) {
need_mask |= 1 << INFO_BUFFERS;
}
/* clear speeds and up status in case device was removed and doesn't get
* updated */
@ -451,21 +446,11 @@ void update_stuff(void)
for (uc = update_cb_head.next; uc; uc = uc->next)
(*uc->func)();
if ((NEED(INFO_MEM) || NEED(INFO_BUFFERS) || NEED(INFO_TOP))
&& current_update_time - last_meminfo_update > 6.9) {
update_meminfo();
if (no_buffers) {
info.mem -= info.bufmem;
info.memeasyfree += info.bufmem;
}
last_meminfo_update = current_update_time;
/* XXX: move the following into the update_meminfo() functions? */
if (no_buffers) {
info.mem -= info.bufmem;
info.memeasyfree += info.bufmem;
}
#ifdef X11
if (NEED(INFO_X11) && x_initialised == YES) {
update_x11info();
}
#endif
}
/* Ohkie to return negative values for temperatures */

View File

@ -207,64 +207,22 @@ extern struct conftree *currentconffile;
char **get_templates(void);
enum {
INFO_CPU = 0,
INFO_MAIL = 1,
INFO_MEM = 2,
INFO_NET = 3,
INFO_PROCS = 4,
INFO_RUN_PROCS = 5,
INFO_UPTIME = 6,
INFO_BUFFERS = 7,
INFO_FS = 8,
INFO_SYSFS = 9,
INFO_MIXER = 10,
INFO_LOADAVG = 11,
INFO_UNAME = 12,
INFO_FREQ = 13,
#ifdef MPD
INFO_MPD = 14,
#endif
INFO_TOP = 15,
INFO_WIFI = 16,
INFO_DISKIO = 17,
INFO_I8K = 18,
#ifdef TCP_PORT_MONITOR
INFO_TCP_PORT_MONITOR = 19,
#endif
#ifdef AUDACIOUS
INFO_AUDACIOUS = 20,
#endif
#ifdef BMPX
INFO_BMPX = 21,
#endif
#ifdef XMMS2
INFO_XMMS2 = 22,
#endif
INFO_ENTROPY = 23,
#ifdef IBM
INFO_SMAPI = 25,
#endif
INFO_USERS = 26,
INFO_GW = 27,
#ifdef NVIDIA
INFO_NVIDIA = 28,
#endif
#ifdef X11
INFO_X11 = 29,
#endif
INFO_DNS = 30,
#ifdef MOC
INFO_MOC = 31,
#endif
#ifdef APCUPSD
INFO_APCUPSD = 32,
#endif
#ifdef WEATHER
INFO_WEATHER = 33,
#endif
#ifdef HDDTEMP
INFO_HDDTEMP = 34,
#endif
};
/* get_battery_stuff() item selector

View File

@ -543,8 +543,8 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
END OBJ(obsd_vendor, 0)
END OBJ(obsd_product, 0)
#endif /* __OpenBSD__ */
END OBJ(buffers, INFO_BUFFERS)
END OBJ(cached, INFO_BUFFERS)
END OBJ(buffers, CALLBACK(&update_meminfo))
END OBJ(cached, CALLBACK(&update_meminfo))
#define SCAN_CPU(__arg, __var) { \
int __offset = 0; \
if (__arg && sscanf(__arg, " cpu%u %n", &__var, &__offset) > 0) \
@ -1032,6 +1032,7 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
* avoid having almost-same code four times, we have this special
* handler. */
if (strncmp(s, "top", 3) == EQUAL) {
add_update_callback(&update_meminfo);
if (!parse_top_args(s, arg, obj)) {
return NULL;
}
@ -1368,21 +1369,21 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
/* if '1' (in mboxscan.c) then there was SIGUSR1, hmm */
obj->data.mboxscan.output[0] = 1;
strncpy(obj->data.mboxscan.args, arg, text_buffer_size);
END OBJ(mem, INFO_MEM)
END OBJ(memeasyfree, INFO_MEM)
END OBJ(memfree, INFO_MEM)
END OBJ(memmax, INFO_MEM)
END OBJ(memperc, INFO_MEM)
END OBJ(mem, CALLBACK(&update_meminfo))
END OBJ(memeasyfree, CALLBACK(&update_meminfo))
END OBJ(memfree, CALLBACK(&update_meminfo))
END OBJ(memmax, CALLBACK(&update_meminfo))
END OBJ(memperc, CALLBACK(&update_meminfo))
#ifdef X11
END OBJ(memgauge, INFO_MEM)
END OBJ(memgauge, CALLBACK(&update_meminfo))
SIZE_DEFAULTS(gauge);
scan_gauge(arg, &obj->data.pair.a, &obj->data.pair.b);
#endif /* X11*/
END OBJ(membar, INFO_MEM)
END OBJ(membar, CALLBACK(&update_meminfo))
SIZE_DEFAULTS(bar);
scan_bar(arg, &obj->data.pair.a, &obj->data.pair.b);
#ifdef X11
END OBJ(memgraph, INFO_MEM)
END OBJ(memgraph, CALLBACK(&update_meminfo))
char *buf = 0;
SIZE_DEFAULTS(graph);
buf = scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d,
@ -1413,11 +1414,11 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
END OBJ_IF(if_mixer_mute, INFO_MIXER)
obj->data.ifblock.i = mixer_init(arg);
#ifdef X11
END OBJ(monitor, INFO_X11)
END OBJ(monitor_number, INFO_X11)
END OBJ(desktop, INFO_X11)
END OBJ(desktop_number, INFO_X11)
END OBJ(desktop_name, INFO_X11)
END OBJ(monitor, CALLBACK(&update_x11info))
END OBJ(monitor_number, CALLBACK(&update_x11info))
END OBJ(desktop, CALLBACK(&update_x11info))
END OBJ(desktop_number, CALLBACK(&update_x11info))
END OBJ(desktop_name, CALLBACK(&update_x11info))
#endif
END OBJ(nodename, 0)
END OBJ(processes, CALLBACK(&update_total_processes))
@ -1445,11 +1446,11 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
obj->data.pair.a = a;
obj->data.pair.b = b;
#endif /* X11 */
END OBJ(swap, INFO_MEM)
END OBJ(swapfree, INFO_MEM)
END OBJ(swapmax, INFO_MEM)
END OBJ(swapperc, INFO_MEM)
END OBJ(swapbar, INFO_MEM)
END OBJ(swap, CALLBACK(&update_meminfo))
END OBJ(swapfree, CALLBACK(&update_meminfo))
END OBJ(swapmax, CALLBACK(&update_meminfo))
END OBJ(swapperc, CALLBACK(&update_meminfo))
END OBJ(swapbar, CALLBACK(&update_meminfo))
SIZE_DEFAULTS(bar);
scan_bar(arg, &obj->data.pair.a, &obj->data.pair.b);
END OBJ(sysname, 0)
@ -1564,7 +1565,7 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
free(buf);
#endif
END OBJ(uptime_short, CALLBACK(&update_uptime))
END OBJ(uptime, INFO_UPTIME)
END OBJ(uptime, CALLBACK(&update_uptime))
END OBJ(user_names, CALLBACK(&update_users))
END OBJ(user_times, CALLBACK(&update_users))
END OBJ(user_terms, CALLBACK(&update_users))

View File

@ -116,7 +116,6 @@ void update_uptime(void)
fscanf(fp, "%lf", &info.uptime);
fclose(fp);
}
info.mask |= (1 << INFO_UPTIME);
}
int check_mount(char *s)
@ -185,8 +184,6 @@ void update_meminfo(void)
info.bufmem = info.cached + info.buffers;
info.mask |= (1 << INFO_MEM) | (1 << INFO_BUFFERS);
fclose(meminfo_fp);
}
@ -509,8 +506,6 @@ void update_net_stats(void)
first = 0;
fclose(net_dev_fp);
info.mask |= (1 << INFO_NET);
}
int result;
@ -536,7 +531,6 @@ void update_total_processes(void)
fscanf(fp, "%*f %*f %*f %*d/%hu", &info.procs);
fclose(fp);
}
info.mask |= (1 << INFO_PROCS);
}
#define CPU_SAMPLE_COUNT 15
@ -657,7 +651,6 @@ inline static void update_stat(void)
if (strncmp(buf, "procs_running ", 14) == 0) {
sscanf(buf, "%*s %hu", &info.run_procs);
info.mask |= (1 << INFO_RUN_PROCS);
} else if (strncmp(buf, "cpu", 3) == 0) {
double delta;
if (isdigit(buf[3])) {
@ -678,7 +671,6 @@ inline static void update_stat(void)
cpu[idx].cpu_active_total = cpu[idx].cpu_total -
(cpu[idx].cpu_idle + cpu[idx].cpu_iowait);
info.mask |= (1 << INFO_CPU);
delta = current_update_time - last_update_time;
@ -755,7 +747,6 @@ void update_load_average(void)
&info.loadavg[2]);
fclose(fp);
}
info.mask |= (1 << INFO_LOADAVG);
}
#define PROC_I8K "/proc/i8k"
@ -2146,8 +2137,6 @@ void update_entropy(void)
fclose(fp1);
fclose(fp2);
info.mask |= (1 << INFO_ENTROPY);
}
const char *get_disk_protect_queue(const char *disk)

View File

@ -733,8 +733,6 @@ int parse_top_args(const char *s, const char *arg, struct text_object *obj)
obj->data.top.s = strndup(arg, text_buffer_size);
}
need_mask |= (1 << INFO_TOP);
if (s[3] == 0) {
obj->type = OBJ_top;
top_cpu = 1;

View File

@ -705,6 +705,8 @@ void get_x11_desktop_info(Display *current_display, Atom atom)
void update_x11info(void)
{
struct information *current_info = &info;
if (!x_initialised == YES)
return;
current_info->x11.monitor.number = XScreenCount(display);
current_info->x11.monitor.current = XDefaultScreen(display);
}