Tue Mar 16 11:47:24 2004 Michael Jennings (mej)
Cleaned up patch to remove suckage. SVN revision: 9368
This commit is contained in:
parent
8741181adf
commit
ede817222e
|
@ -56,241 +56,246 @@ static void in_cb(void *data, Window w);
|
|||
static void out_cb(void *data, Window w);
|
||||
|
||||
static void
|
||||
timer_cb(void *data) {
|
||||
timer_cb(void *data)
|
||||
{
|
||||
|
||||
char buff[1024];
|
||||
unsigned long total, used, buffers, cached, free;
|
||||
char buff[1024];
|
||||
unsigned long total, used, buffers, cached, free;
|
||||
|
||||
#ifdef HAVE_LIBGTOP
|
||||
int check=0;
|
||||
glibtop_mem mem;
|
||||
glibtop_swap swap;
|
||||
glibtop_get_mem (&mem);
|
||||
|
||||
total=(unsigned long)mem.total;
|
||||
used=(unsigned long)mem.used;
|
||||
buffers=(unsigned long)mem.buffer;
|
||||
cached=(unsigned long)mem.cached;
|
||||
#else
|
||||
FILE *fp;
|
||||
int check = 0;
|
||||
glibtop_mem mem;
|
||||
glibtop_swap swap;
|
||||
|
||||
if ((fp = fopen("/proc/meminfo", "r")) == NULL) {
|
||||
D(("Failed to open /proc/meminfo -- %s\n", strerror(errno)));
|
||||
glibtop_get_mem(&mem);
|
||||
|
||||
total = (unsigned long) mem.total;
|
||||
used = (unsigned long) mem.used;
|
||||
buffers = (unsigned long) mem.buffer;
|
||||
cached = (unsigned long) mem.cached;
|
||||
#else
|
||||
FILE *fp;
|
||||
|
||||
if ((fp = fopen("/proc/meminfo", "r")) == NULL) {
|
||||
D(("Failed to open /proc/meminfo -- %s\n", strerror(errno)));
|
||||
return;
|
||||
}
|
||||
|
||||
if (kernel_2_6) {
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &total);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &free);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &buffers);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &cached);
|
||||
|
||||
total *= 1024;
|
||||
free *= 1024;
|
||||
buffers *= 1024;
|
||||
cached *= 1024;
|
||||
used = total - free;
|
||||
|
||||
} else {
|
||||
|
||||
fgets(buff, sizeof(buff), fp); /* Ignore the first line */
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu %lu %*u %*u %lu %lu", &total, &used, &buffers, &cached);
|
||||
}
|
||||
|
||||
#endif /* HAVE_LIBGTOP */
|
||||
|
||||
used -= (buffers + cached);
|
||||
mem_val = (int) ((((float) used) / total) * 100.0);
|
||||
D(("%d = 100 * %lu / %lu\n", (100 * used) / total, used, total));
|
||||
D(("Memory: %d%% (%lu/%lu)\n", mem_val, used, total));
|
||||
Epplet_gadget_data_changed(mem_bar);
|
||||
if (used < 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "M: %lub", used);
|
||||
} else if (used < 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "M: %luK", used / 1024);
|
||||
} else if (used < 1024 * 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "M: %luM", used / (1024 * 1024));
|
||||
} else {
|
||||
Esnprintf(buff, sizeof(buff), "M: %luG", used / (1024 * 1024 * 1024));
|
||||
}
|
||||
Epplet_change_label(mem_label, buff);
|
||||
|
||||
#ifdef HAVE_LIBGTOP
|
||||
glibtop_get_swap(&swap);
|
||||
check = 0;
|
||||
|
||||
do {
|
||||
total = (unsigned long) swap.total;
|
||||
used = (unsigned long) swap.used;
|
||||
} while (swap.total == 0 && swap.used == 0 && check++ < 15);
|
||||
#else
|
||||
|
||||
if (kernel_2_6) {
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &total);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &free);;
|
||||
|
||||
total *= 1024;
|
||||
free *= 1024;
|
||||
used = total - free;
|
||||
|
||||
} else {
|
||||
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu %lu", &total, &used);
|
||||
}
|
||||
|
||||
fclose(fp);
|
||||
#endif /* HAVE_LIBGTOP */
|
||||
swap_val = (int) ((((float) used) / total) * 100.0);
|
||||
|
||||
/*printf ("Swap: %lu %lu %d%%\n", total, used, swap_val); */
|
||||
|
||||
D(("Swap: %d%% (%lu/%lu)\n", swap_val, used, total));
|
||||
Epplet_gadget_data_changed(swap_bar);
|
||||
if (used < 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "S: %lub", used);
|
||||
} else if (used < 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "S: %luK", used / 1024);
|
||||
} else if (used < 1024 * 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "S: %luM", used / (1024 * 1024));
|
||||
} else {
|
||||
Esnprintf(buff, sizeof(buff), "S: %luG", used / (1024 * 1024 * 1024));
|
||||
}
|
||||
Epplet_change_label(swap_label, buff);
|
||||
|
||||
Esync();
|
||||
Epplet_timer(timer_cb, NULL, 3.0, "TIMER");
|
||||
return;
|
||||
}
|
||||
|
||||
if( kernel_2_6 ) {
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &total);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &free);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &buffers);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &cached);
|
||||
|
||||
total *= 1024;
|
||||
free *= 1024;
|
||||
buffers *= 1024;
|
||||
cached *= 1024;
|
||||
used = total - free;
|
||||
|
||||
} else {
|
||||
|
||||
fgets(buff, sizeof(buff), fp); /* Ignore the first line */
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu %lu %*u %*u %lu %lu",
|
||||
&total, &used, &buffers, &cached);
|
||||
}
|
||||
|
||||
#endif /* HAVE_LIBGTOP */
|
||||
|
||||
used -= (buffers + cached);
|
||||
mem_val = (int) ((((float) used) / total) * 100.0);
|
||||
D(("%d = 100 * %lu / %lu\n", (100 * used) / total, used, total));
|
||||
D(("Memory: %d%% (%lu/%lu)\n", mem_val, used, total));
|
||||
Epplet_gadget_data_changed(mem_bar);
|
||||
if (used < 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "M: %lub", used);
|
||||
} else if (used < 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "M: %luK", used / 1024);
|
||||
} else if (used < 1024 * 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "M: %luM", used / (1024 * 1024));
|
||||
} else {
|
||||
Esnprintf(buff, sizeof(buff), "M: %luG", used / (1024 * 1024 * 1024));
|
||||
}
|
||||
Epplet_change_label(mem_label, buff);
|
||||
|
||||
#ifdef HAVE_LIBGTOP
|
||||
glibtop_get_swap (&swap);
|
||||
check=0;
|
||||
|
||||
do {
|
||||
total=(unsigned long)swap.total;
|
||||
used=(unsigned long)swap.used;
|
||||
} while (swap.total==0 && swap.used==0 && check++<15);
|
||||
#else
|
||||
|
||||
if( kernel_2_6 ) {
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &total);
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu", &free);;
|
||||
|
||||
total *= 1024;
|
||||
free *= 1024;
|
||||
used = total - free;
|
||||
|
||||
} else {
|
||||
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %lu %lu", &total, &used);
|
||||
}
|
||||
|
||||
fclose(fp);
|
||||
#endif /* HAVE_LIBGTOP */
|
||||
swap_val = (int) ((((float) used) / total) * 100.0);
|
||||
|
||||
/*printf ("Swap: %lu %lu %d%%\n", total, used, swap_val); */
|
||||
|
||||
D(("Swap: %d%% (%lu/%lu)\n", swap_val, used, total));
|
||||
Epplet_gadget_data_changed(swap_bar);
|
||||
if (used < 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "S: %lub", used);
|
||||
} else if (used < 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "S: %luK", used / 1024);
|
||||
} else if (used < 1024 * 1024 * 1024) {
|
||||
Esnprintf(buff, sizeof(buff), "S: %luM", used / (1024 * 1024));
|
||||
} else {
|
||||
Esnprintf(buff, sizeof(buff), "S: %luG", used / (1024 * 1024 * 1024));
|
||||
}
|
||||
Epplet_change_label(swap_label, buff);
|
||||
|
||||
Esync();
|
||||
Epplet_timer(timer_cb, NULL, 3.0, "TIMER");
|
||||
return;
|
||||
data = NULL;
|
||||
data = NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
close_cb(void *data) {
|
||||
close_cb(void *data)
|
||||
{
|
||||
|
||||
Epplet_unremember();
|
||||
Esync();
|
||||
exit(0);
|
||||
data = NULL;
|
||||
Epplet_unremember();
|
||||
Esync();
|
||||
exit(0);
|
||||
data = NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
title_cb(void *data) {
|
||||
title_cb(void *data)
|
||||
{
|
||||
|
||||
show_title = !show_title;
|
||||
if (show_title) {
|
||||
Epplet_gadget_move(mem_label, 3, 13);
|
||||
Epplet_gadget_move(swap_label, 3, 30);
|
||||
Epplet_gadget_move(mem_bar, 3, 22);
|
||||
Epplet_gadget_move(swap_bar, 3, 39);
|
||||
Epplet_gadget_show(title);
|
||||
} else {
|
||||
Epplet_gadget_move(mem_label, 4, 4);
|
||||
Epplet_gadget_move(swap_label, 4, 24);
|
||||
Epplet_gadget_move(mem_bar, 4, 14);
|
||||
Epplet_gadget_move(swap_bar, 4, 36);
|
||||
Epplet_gadget_hide(title);
|
||||
}
|
||||
Epplet_modify_config("title", (show_title ? "1" : "0"));
|
||||
Epplet_redraw();
|
||||
return;
|
||||
data = NULL;
|
||||
show_title = !show_title;
|
||||
if (show_title) {
|
||||
Epplet_gadget_move(mem_label, 3, 13);
|
||||
Epplet_gadget_move(swap_label, 3, 30);
|
||||
Epplet_gadget_move(mem_bar, 3, 22);
|
||||
Epplet_gadget_move(swap_bar, 3, 39);
|
||||
Epplet_gadget_show(title);
|
||||
} else {
|
||||
Epplet_gadget_move(mem_label, 4, 4);
|
||||
Epplet_gadget_move(swap_label, 4, 24);
|
||||
Epplet_gadget_move(mem_bar, 4, 14);
|
||||
Epplet_gadget_move(swap_bar, 4, 36);
|
||||
Epplet_gadget_hide(title);
|
||||
}
|
||||
Epplet_modify_config("title", (show_title ? "1" : "0"));
|
||||
Epplet_redraw();
|
||||
return;
|
||||
data = NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
in_cb(void *data, Window w) {
|
||||
in_cb(void *data, Window w)
|
||||
{
|
||||
|
||||
if (w == Epplet_get_main_window()) {
|
||||
Epplet_gadget_show(close_button);
|
||||
Epplet_gadget_show(cfg_button);
|
||||
}
|
||||
return;
|
||||
data = NULL;
|
||||
if (w == Epplet_get_main_window()) {
|
||||
Epplet_gadget_show(close_button);
|
||||
Epplet_gadget_show(cfg_button);
|
||||
}
|
||||
return;
|
||||
data = NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
out_cb(void *data, Window w) {
|
||||
out_cb(void *data, Window w)
|
||||
{
|
||||
|
||||
if (w == Epplet_get_main_window()) {
|
||||
Epplet_gadget_hide(close_button);
|
||||
Epplet_gadget_hide(cfg_button);
|
||||
}
|
||||
return;
|
||||
data = NULL;
|
||||
if (w == Epplet_get_main_window()) {
|
||||
Epplet_gadget_hide(close_button);
|
||||
Epplet_gadget_hide(cfg_button);
|
||||
}
|
||||
return;
|
||||
data = NULL;
|
||||
}
|
||||
|
||||
int
|
||||
main(int argc, char **argv) {
|
||||
main(int argc, char **argv)
|
||||
{
|
||||
|
||||
int prio;
|
||||
int prio;
|
||||
|
||||
|
||||
/* check for Kernel 2.6 */
|
||||
FILE *fp;
|
||||
char version[8], buff[1024];
|
||||
/* check for Kernel 2.6 */
|
||||
FILE *fp;
|
||||
char version[8], buff[1024];
|
||||
|
||||
if ((fp = fopen("/proc/version", "r")) == NULL) {
|
||||
D(("Failed to open /proc/version -- %s\nWill assume not 2.6 kernel"
|
||||
, strerror(errno)));
|
||||
return;
|
||||
}
|
||||
if ((fp = fopen("/proc/version", "r")) == NULL) {
|
||||
D(("Failed to open /proc/version -- %s\nWill assume not 2.6 kernel", strerror(errno)));
|
||||
return;
|
||||
}
|
||||
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %*s %s", version);
|
||||
|
||||
if(version[2] == '6') {
|
||||
kernel_2_6 = 1;
|
||||
}
|
||||
fgets(buff, sizeof(buff), fp);
|
||||
sscanf(buff, "%*s %*s %s", version);
|
||||
|
||||
close(fp);
|
||||
/* end check for Kernel 2.6 */
|
||||
if (version[2] == '6') {
|
||||
kernel_2_6 = 1;
|
||||
}
|
||||
|
||||
atexit(Epplet_cleanup);
|
||||
prio = getpriority(PRIO_PROCESS, getpid());
|
||||
setpriority(PRIO_PROCESS, getpid(), prio + 10);
|
||||
Epplet_Init("E-MemWatch", "0.1", "Enlightenment RAM/Swap Monitor Epplet", 3, 3, argc, argv, 0);
|
||||
Epplet_load_config();
|
||||
show_title = atoi(Epplet_query_config_def("title", "1"));
|
||||
close(fp);
|
||||
/* end check for Kernel 2.6 */
|
||||
|
||||
title = Epplet_create_label(3, 3, "Mem Used", 1);
|
||||
if (show_title) {
|
||||
mem_label = Epplet_create_label(3, 13, "M:", 1);
|
||||
swap_label = Epplet_create_label(3, 30, "S:", 1);
|
||||
mem_bar = Epplet_create_hbar(3, 22, 42, 7, 0, &mem_val);
|
||||
swap_bar = Epplet_create_hbar(3, 39, 42, 7, 0, &swap_val);
|
||||
Epplet_gadget_show(title);
|
||||
} else {
|
||||
mem_label = Epplet_create_label(4, 4, "M:", 1);
|
||||
swap_label = Epplet_create_label(4, 24, "S:", 1);
|
||||
mem_bar = Epplet_create_hbar(4, 14, 40, 8, 0, &mem_val);
|
||||
swap_bar = Epplet_create_hbar(4, 36, 40, 8, 0, &swap_val);
|
||||
}
|
||||
close_button = Epplet_create_button(NULL, NULL, 2, 2, 0, 0, "CLOSE", 0, NULL, close_cb, NULL);
|
||||
cfg_button = Epplet_create_button(NULL, NULL, 33, 2, 0, 0, "CONFIGURE", 0, NULL, title_cb, NULL);
|
||||
Epplet_gadget_show(mem_label);
|
||||
Epplet_gadget_show(mem_bar);
|
||||
Epplet_gadget_show(swap_label);
|
||||
Epplet_gadget_show(swap_bar);
|
||||
Epplet_show();
|
||||
atexit(Epplet_cleanup);
|
||||
prio = getpriority(PRIO_PROCESS, getpid());
|
||||
setpriority(PRIO_PROCESS, getpid(), prio + 10);
|
||||
Epplet_Init("E-MemWatch", "0.1", "Enlightenment RAM/Swap Monitor Epplet", 3, 3, argc, argv, 0);
|
||||
Epplet_load_config();
|
||||
show_title = atoi(Epplet_query_config_def("title", "1"));
|
||||
|
||||
Epplet_register_focus_in_handler(in_cb, NULL);
|
||||
Epplet_register_focus_out_handler(out_cb, NULL);
|
||||
timer_cb(NULL); /* Set everything up */
|
||||
Epplet_Loop();
|
||||
title = Epplet_create_label(3, 3, "Mem Used", 1);
|
||||
if (show_title) {
|
||||
mem_label = Epplet_create_label(3, 13, "M:", 1);
|
||||
swap_label = Epplet_create_label(3, 30, "S:", 1);
|
||||
mem_bar = Epplet_create_hbar(3, 22, 42, 7, 0, &mem_val);
|
||||
swap_bar = Epplet_create_hbar(3, 39, 42, 7, 0, &swap_val);
|
||||
Epplet_gadget_show(title);
|
||||
} else {
|
||||
mem_label = Epplet_create_label(4, 4, "M:", 1);
|
||||
swap_label = Epplet_create_label(4, 24, "S:", 1);
|
||||
mem_bar = Epplet_create_hbar(4, 14, 40, 8, 0, &mem_val);
|
||||
swap_bar = Epplet_create_hbar(4, 36, 40, 8, 0, &swap_val);
|
||||
}
|
||||
close_button = Epplet_create_button(NULL, NULL, 2, 2, 0, 0, "CLOSE", 0, NULL, close_cb, NULL);
|
||||
cfg_button = Epplet_create_button(NULL, NULL, 33, 2, 0, 0, "CONFIGURE", 0, NULL, title_cb, NULL);
|
||||
Epplet_gadget_show(mem_label);
|
||||
Epplet_gadget_show(mem_bar);
|
||||
Epplet_gadget_show(swap_label);
|
||||
Epplet_gadget_show(swap_bar);
|
||||
Epplet_show();
|
||||
|
||||
return 0;
|
||||
Epplet_register_focus_in_handler(in_cb, NULL);
|
||||
Epplet_register_focus_out_handler(out_cb, NULL);
|
||||
timer_cb(NULL); /* Set everything up */
|
||||
Epplet_Loop();
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue