aboutsummaryrefslogtreecommitdiffstats
AgeCommit message (Expand)AuthorFilesLines
2010-01-17fixed memory leak in using strdup() instead of strdupa()volker1-0/+6
2010-01-15Ticket 182volker3-21/+31
2010-01-15strdupa uses alloca which is not available everywhere. strdup is used insteadvolker1-2/+2
2010-01-05plugins work on MacOS X: proc_stat, cpuinfovolker4-7/+87
2010-01-03linker error with LW_ABP correctedmichael2-14/+16
2010-01-03update to autoconf 2.65michael3-328/+403
2009-11-22indentationmichael1-1/+1
2009-11-22indentationmichael1-0/+1
2009-11-22add event.h to extra sourcesmichael1-1/+1
2009-11-22Logic Way ABP08 ABP09 enhancements by Arndt Kritznermichael1-7/+141
2009-11-21Remove warnings from mpris pluginedman0072-5/+4
2009-11-21Fix the dbus/pkg-config confgure (Now the configure script will probably requ...edman0072-2/+12
2009-11-21* Fix segfault on shutdown in drv_picoLCDGraphic.cedman0072-2/+8
2009-11-20special commandline parameters for X11volker4-3/+56
2009-11-19Make the dbus plugin shutdown without showing dbus leaks when compiled with -...edman0072-10/+12
2009-11-19drv_PICGraphic.cedman0071-1/+1
2009-11-18the DBus plugin is now disabled when dbus is not installed instead of stoppin...edman0072-4/+5
2009-11-18Prevent HD44780 and HD44780_I2C from building at the same timeedman0072-18/+24
2009-11-18disabling some driver if no parport availablevolker3-46/+74
2009-11-18Removed warning for the mpris dbus pluginedman0071-0/+2
2009-11-18MatrixOrbitalGXpre { line-height: 125%; margin: 0; } td.linenos pre { color: #000000; background-color: #f0f0f0; padding: 0 5px 0 5px; } span.linenos { color: #000000; background-color: #f0f0f0; padding: 0 5px 0 5px; } td.linenos pre.special { color: #000000; background-color: #ffffc0; padding: 0 5px 0 5px; } span.linenos.special { color: #000000; background-color: #ffffc0; padding: 0 5px 0 5px; } .highlight .hll { background-color: #ffffcc } .highlight .c { color: #888888 } /* Comment */ .highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */ .highlight .k { color: #008800; font-weight: bold } /* Keyword */ .highlight .ch { color: #888888 } /* Comment.Hashbang */ .highlight .cm { color: #888888 } /* Comment.Multiline */ .highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */ .highlight .cpf { color: #888888 } /* Comment.PreprocFile */ .highlight .c1 { color: #888888 } /* Comment.Single */ .highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */ .highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */ .highlight .ge { font-style: italic } /* Generic.Emph */ .highlight .gr { color: #aa0000 } /* Generic.Error */ .highlight .gh { color: #333333 } /* Generic.Heading */ .highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */ .highlight .go { color: #888888 } /* Generic.Output */ .highlight .gp { color: #555555 } /* Generic.Prompt */ .highlight .gs { font-weight: bold } /* Generic.Strong */ .highlight .gu { color: #666666 } /* Generic.Subheading */ .highlight .gt { color: #aa0000 } /* Generic.Traceback */ .highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */ .highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */ .highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */ .highlight .kp { color: #008800 } /* Keyword.Pseudo */ .highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */ .highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */ .highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */ .highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */ .highlight .na { color: #336699 } /* Name.Attribute */ .highlight .nb { color: #003388 } /* Name.Builtin */ .highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */ .highlight .no { color: #003366; font-weight: bold } /* Name.Constant */ .highlight .nd { color: #555555 } /* Name.Decorator */ .highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */ .highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */ .highlight .nl { color: #336699; font-style: italic } /* Name.Label */ .highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highl11-9104/+17487
2009-09-23indentationmichael1-4/+4
2009-09-23indentationmichael1-1/+2
2009-09-23suppress compiler warningmichael1-9/+4
2009-09-23warn() => info()michael1-1/+1
2009-09-22added support for Z-10 speaker to G-15 drivervolker1-13/+54
2009-08-21evaluator bug fixed (thanks to lleo19)michael1-0/+1
2009-07-18indent runmichael2-325/+236
2009-07-18asterix extensions by gabrielortizlour@gmail.commichael1-0/+116
2009-05-19icon frame patch by Marcus Brownmichael2-5/+14
2009-05-11update autoconfmichux4-3144/+4091
2009-05-11add qnap log plugin, thanks to rolf tralowmichux3-0/+537
2009-04-15indentmichux1-232/+225
2009-04-15timer fix for vnc drivermichux1-1/+11
n class="cm">/* * exported functions: * * int plugin_init_loadavg (void) * adds functions for load average * */ #include "config.h" #include <stdlib.h> #include <stdio.h> #include <string.h> #include <errno.h> #include <unistd.h> #include <sys/types.h> #include <sys/stat.h> #include <sys/time.h> #include <fcntl.h> #include "debug.h" #include "plugin.h" #ifndef HAVE_GETLOADAVG static int fd = -2; int getloadavg (double loadavg[], int nelem) { char buf[65], *p; ssize_t nread; int i; if (fd == -2) fd = open ("/proc/loadavg", O_RDONLY); if (fd < 0) return -1; lseek(fd,0,SEEK_SET); nread = read (fd, buf, sizeof buf - 1); if (nread < 0) return -1; buf[nread - 1] = '\0'; if (nelem > 3) nelem = 3; p = buf; for (i = 0; i < nelem; ++i) { char *endp; loadavg[i] = strtod (p, &endp); if (endp == NULL || endp == p) /* This should not happen. The format of /proc/loadavg must have changed. Don't return with what we have, signal an error. */ return -1; p = endp; } return i; } #endif static void my_loadavg (RESULT *result, RESULT *arg1) { static int nelem=-1; int index,age; static double loadavg[3]; static struct timeval last_value; struct timeval now; gettimeofday(&now,NULL); age = (now.tv_sec - last_value.tv_sec)*1000 + (now.tv_usec - last_value.tv_usec)/1000; /* reread every 10 msec only */ if (nelem==-1 || age==0 || age>10) { nelem=getloadavg(loadavg, 3); if (nelem<0) { error ("getloadavg() failed!"); SetResult(&result, R_STRING, ""); return; } last_value=now; } index=R2N(arg1); if (index<1 || index>nelem) { error ("loadavg(%d): index out of range!", index); SetResult(&result, R_STRING, ""); return; } SetResult(&result, R_NUMBER, &(loadavg[index-1])); return; } int plugin_init_loadavg (void) { AddFunction ("loadavg", 1, my_loadavg); return 0; } void plugin_exit_loadavg(void) { #ifndef HAVE_GETLOADAVG if (fd>0) close(fd); fd=-2; #endif }