mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-26 00:28:25 +00:00
head/tail rewrite patch
diskio read/write patch added check for zlib to configure script git-svn-id: https://conky.svn.sourceforge.net/svnroot/conky/trunk/conky1@823 7f574dfc-610e-0410-a909-a81674777703
This commit is contained in:
parent
39d429b508
commit
5cfe6b093d
6
AUTHORS
6
AUTHORS
@ -13,6 +13,9 @@ Alex <godexsoft at bk dot ru>
|
|||||||
affinity <affy at users dot sourceforge dot net>
|
affinity <affy at users dot sourceforge dot net>
|
||||||
X-Mozilla-Status support
|
X-Mozilla-Status support
|
||||||
|
|
||||||
|
Blondak <blondak_nesercz at users dot sourceforge dot net>
|
||||||
|
diskio read & write patch
|
||||||
|
|
||||||
Bobby Beckmann <bbeckmann at users dot sourceforge dot net>
|
Bobby Beckmann <bbeckmann at users dot sourceforge dot net>
|
||||||
Interface IP and Wireless Quality patch
|
Interface IP and Wireless Quality patch
|
||||||
|
|
||||||
@ -165,6 +168,9 @@ Roman Bogorodskiy <novel at clublife dot ru>
|
|||||||
FreeBSD support
|
FreeBSD support
|
||||||
BMPx support
|
BMPx support
|
||||||
|
|
||||||
|
Ryan Twitchell <tryan2 at rochester dot rr dot com>
|
||||||
|
head/tail rewrite patch
|
||||||
|
|
||||||
Stepan Zastupov <redchrom at gmail dot com>
|
Stepan Zastupov <redchrom at gmail dot com>
|
||||||
WiFi signal level detection support on FreeBSD
|
WiFi signal level detection support on FreeBSD
|
||||||
|
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
2006-12-29
|
2006-12-29
|
||||||
* Update svn ebuild to new sourceforge url scheme.
|
* Update svn ebuild to new sourceforge url scheme.
|
||||||
- requires deletion of existing wc: rm -rf /usr/portage/distfile/svn-src/conky/
|
- requires deletion of existing wc: rm -rf /usr/portage/distfile/svn-src/conky/
|
||||||
|
* Added head/tail rewrite patch (thanks Ryan Twitchell)
|
||||||
|
* Added diskio read/write sf.net patch 1542880 (thanks Blondak)
|
||||||
|
|
||||||
2006-12-26
|
2006-12-26
|
||||||
* Clear conky vars on disconnect/failure to open files.
|
* Clear conky vars on disconnect/failure to open files.
|
||||||
|
@ -33,7 +33,7 @@ DEPEND_COMMON="
|
|||||||
audacious? ( media-sound/audacious )
|
audacious? ( media-sound/audacious )
|
||||||
infopipe? ( media-plugins/xmms-infopipe )
|
infopipe? ( media-plugins/xmms-infopipe )
|
||||||
xmms? ( media-sound/xmms )
|
xmms? ( media-sound/xmms )
|
||||||
xmms2? ( medis-sound/xmms2 )
|
xmms2? ( media-sound/xmms2 )
|
||||||
)"
|
)"
|
||||||
|
|
||||||
RDEPEND="${DEPEND_COMMON}"
|
RDEPEND="${DEPEND_COMMON}"
|
||||||
|
@ -432,6 +432,14 @@ dnl
|
|||||||
AC_CHECK_FUNCS([calloc malloc free popen sysinfo getloadavg])
|
AC_CHECK_FUNCS([calloc malloc free popen sysinfo getloadavg])
|
||||||
AC_SEARCH_LIBS(clock_gettime, [rt], [], AC_MSG_ERROR([clock_gettime() not found]))
|
AC_SEARCH_LIBS(clock_gettime, [rt], [], AC_MSG_ERROR([clock_gettime() not found]))
|
||||||
|
|
||||||
|
dnl
|
||||||
|
dnl Check for zlib
|
||||||
|
dnl
|
||||||
|
|
||||||
|
AC_CHECK_HEADER(zlib.h,
|
||||||
|
[],
|
||||||
|
[AC_MSG_ERROR([zlib is missing; please install the headers first])])
|
||||||
|
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl Check doc stuff
|
dnl Check doc stuff
|
||||||
|
@ -381,6 +381,44 @@
|
|||||||
<para></para></listitem>
|
<para></para></listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term>
|
||||||
|
<command><option>diskio_read</option></command>
|
||||||
|
</term>
|
||||||
|
<listitem>
|
||||||
|
Displays current disk IO for reads.
|
||||||
|
<para></para></listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term>
|
||||||
|
<command><option>diskio_readgraph</option></command>
|
||||||
|
<option>(height),(width) (gradient colour 1) (gradient colour 2) (scale)</option>
|
||||||
|
</term>
|
||||||
|
<listitem>
|
||||||
|
Disk IO graph for reads, colours defined in hex, minus the #. If scale is non-zero, it becomes the scale for the graph.
|
||||||
|
<para></para></listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term>
|
||||||
|
<command><option>diskio_write</option></command>
|
||||||
|
</term>
|
||||||
|
<listitem>
|
||||||
|
Displays current disk IO for writes.
|
||||||
|
<para></para></listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term>
|
||||||
|
<command><option>diskio_writegraph</option></command>
|
||||||
|
<option>(height),(width) (gradient colour 1) (gradient colour 2) (scale)</option>
|
||||||
|
</term>
|
||||||
|
<listitem>
|
||||||
|
Disk IO graph for writes, colours defined in hex, minus the #. If scale is non-zero, it becomes the scale for the graph.
|
||||||
|
<para></para></listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term>
|
<term>
|
||||||
<command><option>downspeed</option></command>
|
<command><option>downspeed</option></command>
|
||||||
|
286
src/conky.c
286
src/conky.c
@ -9,13 +9,11 @@
|
|||||||
#include "conky.h"
|
#include "conky.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <locale.h>
|
#include <locale.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <string.h>
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <termios.h>
|
#include <termios.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -541,53 +539,79 @@ static struct special_t *new_special(char *buf, int t)
|
|||||||
return &specials[special_count++];
|
return &specials[special_count++];
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct tailstring_list {
|
long fwd_fcharfind(FILE* fp, char val, unsigned int step) {
|
||||||
char data[TEXT_BUFFER_SIZE];
|
#define BUFSZ 0x1000
|
||||||
struct tailstring_list *next;
|
long ret = -1;
|
||||||
struct tailstring_list *first;
|
long count = 0;
|
||||||
} tailstring;
|
static char buf[BUFSZ];
|
||||||
|
long orig_pos = ftell(fp);
|
||||||
void addtail(tailstring ** head, char *data_in)
|
long buf_pos = -1;
|
||||||
{
|
long buf_size = BUFSZ;
|
||||||
tailstring *tmp;
|
char* cur_found = NULL;
|
||||||
if ((tmp = malloc(sizeof(*tmp))) == NULL) {
|
while(count < step) {
|
||||||
CRIT_ERR("malloc");
|
if(cur_found == NULL) {
|
||||||
|
buf_size = fread(buf, 1, buf_size, fp);
|
||||||
|
buf_pos = 0;
|
||||||
}
|
}
|
||||||
if (*head == NULL) {
|
cur_found = memchr(buf+buf_pos, val, buf_size-buf_pos);
|
||||||
tmp->first = tmp;
|
if(cur_found != NULL) {
|
||||||
} else {
|
buf_pos = cur_found-buf+1;
|
||||||
tmp->first = (*head)->first;
|
count++;
|
||||||
}
|
}
|
||||||
strncpy(tmp->data, data_in, TEXT_BUFFER_SIZE);
|
else {
|
||||||
tmp->next = *head;
|
if(feof(fp))
|
||||||
*head = tmp;
|
|
||||||
}
|
|
||||||
|
|
||||||
void freetail(tailstring * head)
|
|
||||||
{
|
|
||||||
tailstring *tmp;
|
|
||||||
while (head != NULL) {
|
|
||||||
tmp = head->next;
|
|
||||||
free(head);
|
|
||||||
head = tmp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void freelasttail(tailstring * head)
|
|
||||||
{
|
|
||||||
tailstring * tmp = head;
|
|
||||||
while(tmp != NULL) {
|
|
||||||
if (tmp->next == head->first) {
|
|
||||||
tmp->next = NULL;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
tmp = tmp->next;
|
|
||||||
}
|
}
|
||||||
free(head->first);
|
if(count == step)
|
||||||
while(head != NULL && tmp != NULL) {
|
ret = ftell(fp) - buf_size + buf_pos - 1;
|
||||||
head->first = tmp;
|
fseek(fp, orig_pos, SEEK_SET);
|
||||||
head = head->next;
|
return ret;
|
||||||
|
#undef BUFSZ
|
||||||
|
}
|
||||||
|
|
||||||
|
long rev_fcharfind(FILE* fp, char val, unsigned int step) {
|
||||||
|
#define BUFSZ 0x1000
|
||||||
|
long ret = -1;
|
||||||
|
long count = 0;
|
||||||
|
static char buf[BUFSZ];
|
||||||
|
long orig_pos = ftell(fp);
|
||||||
|
long buf_pos = -1;
|
||||||
|
long file_pos = orig_pos;
|
||||||
|
long buf_size = BUFSZ;
|
||||||
|
char* cur_found;
|
||||||
|
while(count < step) {
|
||||||
|
if(buf_pos <= 0) {
|
||||||
|
if(file_pos > BUFSZ) {
|
||||||
|
fseek(fp, file_pos-BUFSZ, SEEK_SET);
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
buf_size = file_pos;
|
||||||
|
fseek(fp, 0, SEEK_SET);
|
||||||
|
}
|
||||||
|
file_pos = ftell(fp);
|
||||||
|
buf_pos = fread(buf, 1, buf_size, fp);
|
||||||
|
}
|
||||||
|
cur_found =
|
||||||
|
memrchr(
|
||||||
|
buf,
|
||||||
|
(int)val,
|
||||||
|
(size_t)buf_pos);
|
||||||
|
if(cur_found != NULL) {
|
||||||
|
buf_pos = cur_found-buf;
|
||||||
|
count++;
|
||||||
|
} else {
|
||||||
|
buf_pos = -1;
|
||||||
|
if(file_pos == 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fseek(fp, orig_pos, SEEK_SET);
|
||||||
|
if(count == step)
|
||||||
|
ret = file_pos + buf_pos;
|
||||||
|
return ret;
|
||||||
|
#undef BUFSZ
|
||||||
}
|
}
|
||||||
|
|
||||||
static void new_bar(char *buf, int w, int h, int usage)
|
static void new_bar(char *buf, int w, int h, int usage)
|
||||||
@ -900,7 +924,11 @@ enum text_object_type {
|
|||||||
OBJ_cpubar,
|
OBJ_cpubar,
|
||||||
OBJ_cpugraph,
|
OBJ_cpugraph,
|
||||||
OBJ_diskio,
|
OBJ_diskio,
|
||||||
|
OBJ_diskio_read,
|
||||||
|
OBJ_diskio_write,
|
||||||
OBJ_diskiograph,
|
OBJ_diskiograph,
|
||||||
|
OBJ_diskiograph_read,
|
||||||
|
OBJ_diskiograph_write,
|
||||||
OBJ_downspeed,
|
OBJ_downspeed,
|
||||||
OBJ_downspeedf,
|
OBJ_downspeedf,
|
||||||
OBJ_downspeedgraph,
|
OBJ_downspeedgraph,
|
||||||
@ -2169,7 +2197,11 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
|
|||||||
obj->data.cpu_index = 0;
|
obj->data.cpu_index = 0;
|
||||||
}
|
}
|
||||||
END OBJ(diskio, INFO_DISKIO)
|
END OBJ(diskio, INFO_DISKIO)
|
||||||
|
END OBJ(diskio_read, INFO_DISKIO)
|
||||||
|
END OBJ(diskio_write, INFO_DISKIO)
|
||||||
END OBJ(diskiograph, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
|
END OBJ(diskiograph, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
|
||||||
|
END OBJ(diskiograph_read, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
|
||||||
|
END OBJ(diskiograph_write, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
|
||||||
END OBJ(color, 0)
|
END OBJ(color, 0)
|
||||||
#ifdef X11
|
#ifdef X11
|
||||||
obj->data.l = arg ? get_x11_color(arg) : default_fg_color;
|
obj->data.l = arg ? get_x11_color(arg) : default_fg_color;
|
||||||
@ -2472,7 +2504,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
|
|||||||
obj->data.tail.logfile =
|
obj->data.tail.logfile =
|
||||||
malloc(TEXT_BUFFER_SIZE);
|
malloc(TEXT_BUFFER_SIZE);
|
||||||
strcpy(obj->data.tail.logfile, buf);
|
strcpy(obj->data.tail.logfile, buf);
|
||||||
obj->data.tail.wantedlines = n1 - 1;
|
obj->data.tail.wantedlines = n1;
|
||||||
obj->data.tail.interval =
|
obj->data.tail.interval =
|
||||||
update_interval * 2;
|
update_interval * 2;
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
@ -2497,7 +2529,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
|
|||||||
obj->data.tail.logfile =
|
obj->data.tail.logfile =
|
||||||
malloc(TEXT_BUFFER_SIZE);
|
malloc(TEXT_BUFFER_SIZE);
|
||||||
strcpy(obj->data.tail.logfile, buf);
|
strcpy(obj->data.tail.logfile, buf);
|
||||||
obj->data.tail.wantedlines = n1 - 1;
|
obj->data.tail.wantedlines = n1;
|
||||||
obj->data.tail.interval = n2;
|
obj->data.tail.interval = n2;
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
} else {
|
} else {
|
||||||
@ -2532,7 +2564,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
|
|||||||
obj->data.tail.logfile =
|
obj->data.tail.logfile =
|
||||||
malloc(TEXT_BUFFER_SIZE);
|
malloc(TEXT_BUFFER_SIZE);
|
||||||
strcpy(obj->data.tail.logfile, buf);
|
strcpy(obj->data.tail.logfile, buf);
|
||||||
obj->data.tail.wantedlines = n1 - 1;
|
obj->data.tail.wantedlines = n1;
|
||||||
obj->data.tail.interval =
|
obj->data.tail.interval =
|
||||||
update_interval * 2;
|
update_interval * 2;
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
@ -2557,7 +2589,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
|
|||||||
obj->data.tail.logfile =
|
obj->data.tail.logfile =
|
||||||
malloc(TEXT_BUFFER_SIZE);
|
malloc(TEXT_BUFFER_SIZE);
|
||||||
strcpy(obj->data.tail.logfile, buf);
|
strcpy(obj->data.tail.logfile, buf);
|
||||||
obj->data.tail.wantedlines = n1 - 1;
|
obj->data.tail.wantedlines = n1;
|
||||||
obj->data.tail.interval = n2;
|
obj->data.tail.interval = n2;
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
} else {
|
} else {
|
||||||
@ -3414,7 +3446,8 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
|
|||||||
new_font(p, obj->data.s);
|
new_font(p, obj->data.s);
|
||||||
}
|
}
|
||||||
#endif /* X11 */
|
#endif /* X11 */
|
||||||
OBJ(diskio) {
|
void format_diskio(unsigned int diskio_value)
|
||||||
|
{
|
||||||
if (!use_spacer) {
|
if (!use_spacer) {
|
||||||
if (diskio_value > 1024*1024) {
|
if (diskio_value > 1024*1024) {
|
||||||
snprintf(p, p_max_size, "%.1fGiB",
|
snprintf(p, p_max_size, "%.1fGiB",
|
||||||
@ -3441,12 +3474,30 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
OBJ(diskio) {
|
||||||
|
format_diskio(diskio_value);
|
||||||
|
}
|
||||||
|
OBJ(diskio_write) {
|
||||||
|
format_diskio(diskio_write_value);
|
||||||
|
}
|
||||||
|
OBJ(diskio_read) {
|
||||||
|
format_diskio(diskio_read_value);
|
||||||
|
}
|
||||||
OBJ(diskiograph) {
|
OBJ(diskiograph) {
|
||||||
new_graph(p, obj->a,
|
new_graph(p, obj->a,
|
||||||
obj->b, obj->c, obj->d,
|
obj->b, obj->c, obj->d,
|
||||||
diskio_value, obj->e, 1);
|
diskio_value, obj->e, 1);
|
||||||
}
|
}
|
||||||
|
OBJ(diskiograph_read) {
|
||||||
|
new_graph(p, obj->a,
|
||||||
|
obj->b, obj->c, obj->d,
|
||||||
|
diskio_read_value, obj->e, 1);
|
||||||
|
}
|
||||||
|
OBJ(diskiograph_write) {
|
||||||
|
new_graph(p, obj->a,
|
||||||
|
obj->b, obj->c, obj->d,
|
||||||
|
diskio_write_value, obj->e, 1);
|
||||||
|
}
|
||||||
OBJ(downspeed) {
|
OBJ(downspeed) {
|
||||||
if (!use_spacer) {
|
if (!use_spacer) {
|
||||||
snprintf(p, p_max_size, "%d",
|
snprintf(p, p_max_size, "%d",
|
||||||
@ -4593,59 +4644,58 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
|
|||||||
} else {
|
} else {
|
||||||
obj->data.tail.last_update = current_update_time;
|
obj->data.tail.last_update = current_update_time;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int i;
|
long nl, bsize;
|
||||||
int added = 0;
|
int iter;
|
||||||
tailstring *head = NULL;
|
|
||||||
tailstring *headtmp = NULL;
|
|
||||||
tailstring *freetmp = NULL;
|
|
||||||
fp = fopen(obj->data.tail.logfile, "rt");
|
fp = fopen(obj->data.tail.logfile, "rt");
|
||||||
if (fp == NULL) {
|
if (fp == NULL) {
|
||||||
|
/* Send one message, but do not consistently spam on
|
||||||
|
* missing logfiles. */
|
||||||
|
if(obj->data.tail.readlines != 0) {
|
||||||
ERR("tail logfile failed to open");
|
ERR("tail logfile failed to open");
|
||||||
|
strcpy(obj->data.tail.buffer, "Logfile Missing");
|
||||||
|
}
|
||||||
|
obj->data.tail.readlines = 0;
|
||||||
|
snprintf(p, p_max_size, "Logfile Missing");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
obj->data.tail.readlines = 0;
|
obj->data.tail.readlines = 0;
|
||||||
|
/* -1 instead of 0 to avoid counting a trailing newline */
|
||||||
while (fgets(obj->data.tail.buffer, TEXT_BUFFER_SIZE*20, fp) != NULL) {
|
fseek(fp, -1, SEEK_END);
|
||||||
if (added >= 30) {
|
bsize = ftell(fp) + 1;
|
||||||
freelasttail(head);
|
for(iter = obj->data.tail.wantedlines; iter > 0; iter--) {
|
||||||
|
nl = rev_fcharfind(fp, '\n', iter);
|
||||||
|
if(nl >= 0)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
obj->data.tail.readlines = iter;
|
||||||
|
if(obj->data.tail.readlines < obj->data.tail.wantedlines) {
|
||||||
|
fseek(fp, 0, SEEK_SET);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
added++;
|
fseek(fp, nl+1, SEEK_SET);
|
||||||
|
bsize -= ftell(fp);
|
||||||
}
|
}
|
||||||
addtail(&head, obj->data.tail.buffer);
|
/* Make sure bsize is at least 1 byte smaller than
|
||||||
obj->data.tail.readlines++;
|
* the buffer max size. */
|
||||||
|
if(bsize > TEXT_BUFFER_SIZE*20 - 1) {
|
||||||
|
fseek(fp, bsize - TEXT_BUFFER_SIZE*20 - 1, SEEK_CUR);
|
||||||
|
bsize = TEXT_BUFFER_SIZE*20 - 1;
|
||||||
}
|
}
|
||||||
|
bsize = fread(obj->data.tail.buffer, 1, bsize, fp);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
freetmp = head;
|
if(bsize > 0) {
|
||||||
|
/* Clean up trailing newline, make sure the buffer
|
||||||
if (obj->data.tail.readlines > 0) {
|
* is null terminated. */
|
||||||
for (i = 0;i < obj->data.tail.wantedlines + 1 && i < obj->data.tail.readlines; i++) {
|
if(obj->data.tail.buffer[bsize-1] == '\n')
|
||||||
addtail(&headtmp, head->data);
|
obj->data.tail.buffer[bsize-1] = '\0';
|
||||||
head = head->next;
|
else
|
||||||
}
|
obj->data.tail.buffer[bsize] = '\0';
|
||||||
freetail(freetmp);
|
|
||||||
freetmp = headtmp;
|
|
||||||
strcpy(obj->data.tail.buffer, headtmp->data);
|
|
||||||
headtmp = headtmp->next;
|
|
||||||
for (i = 1;i < obj->data.tail.wantedlines + 1 && i < obj->data.tail.readlines; i++) {
|
|
||||||
if (headtmp) {
|
|
||||||
strncat(obj->data.tail.buffer, headtmp->data, (TEXT_BUFFER_SIZE * 20) - strlen(obj->data.tail.buffer)); /* without strlen() at the end this becomes a possible */
|
|
||||||
headtmp = headtmp->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* get rid of any ugly newlines at the end */
|
|
||||||
if (obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] == '\n') {
|
|
||||||
obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] = '\0';
|
|
||||||
}
|
|
||||||
snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
|
snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
|
||||||
|
}
|
||||||
freetail(freetmp);
|
else {
|
||||||
} else {
|
|
||||||
strcpy(obj->data.tail.buffer, "Logfile Empty");
|
strcpy(obj->data.tail.buffer, "Logfile Empty");
|
||||||
snprintf(p, p_max_size, "Logfile Empty");
|
snprintf(p, p_max_size, "Logfile Empty");
|
||||||
} /* if readlines */
|
} /* bsize > 0 */
|
||||||
} /* fp == NULL */
|
} /* fp == NULL */
|
||||||
} /* if cur_upd_time >= */
|
} /* if cur_upd_time >= */
|
||||||
|
|
||||||
@ -4658,43 +4708,48 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
|
|||||||
} else {
|
} else {
|
||||||
obj->data.tail.last_update = current_update_time;
|
obj->data.tail.last_update = current_update_time;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
tailstring *head = NULL;
|
long nl;
|
||||||
tailstring *headtmp = NULL;
|
int iter;
|
||||||
tailstring *freetmp = NULL;
|
|
||||||
fp = fopen(obj->data.tail.logfile, "rt");
|
fp = fopen(obj->data.tail.logfile, "rt");
|
||||||
if (fp == NULL) {
|
if (fp == NULL) {
|
||||||
|
/* Send one message, but do not consistently spam on
|
||||||
|
* missing logfiles. */
|
||||||
|
if(obj->data.tail.readlines != 0) {
|
||||||
ERR("head logfile failed to open");
|
ERR("head logfile failed to open");
|
||||||
|
strcpy(obj->data.tail.buffer, "Logfile Missing");
|
||||||
|
}
|
||||||
|
obj->data.tail.readlines = 0;
|
||||||
|
snprintf(p, p_max_size, "Logfile Missing");
|
||||||
} else {
|
} else {
|
||||||
obj->data.tail.readlines = 0;
|
obj->data.tail.readlines = 0;
|
||||||
while (fgets(obj->data.tail.buffer, TEXT_BUFFER_SIZE*20, fp) != NULL && obj->data.tail.readlines <= obj->data.tail.wantedlines) {
|
for(iter = obj->data.tail.wantedlines; iter > 0; iter--) {
|
||||||
addtail(&head, obj->data.tail.buffer);
|
nl = fwd_fcharfind(fp, '\n', iter);
|
||||||
obj->data.tail.readlines++;
|
if(nl >= 0)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
obj->data.tail.readlines = iter;
|
||||||
|
/* Make sure nl is at least 1 byte smaller than
|
||||||
|
* the buffer max size. */
|
||||||
|
if(nl > TEXT_BUFFER_SIZE*20 - 1) {
|
||||||
|
nl = TEXT_BUFFER_SIZE*20 - 1;
|
||||||
|
}
|
||||||
|
nl = fread(obj->data.tail.buffer, 1, nl, fp);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
freetmp = head;
|
if(nl > 0) {
|
||||||
if (obj->data.tail.readlines > 0) {
|
/* Clean up trailing newline, make sure the buffer
|
||||||
while (head) {
|
* is null terminated. */
|
||||||
addtail(&headtmp, head->data);
|
if (obj->data.tail.buffer[nl-1] == '\n') {
|
||||||
head = head->next;
|
obj->data.tail.buffer[nl-1] = '\0';
|
||||||
}
|
}
|
||||||
freetail(freetmp);
|
else {
|
||||||
freetmp = headtmp;
|
obj->data.tail.buffer[nl] = '\0';
|
||||||
strcpy(obj->data.tail.buffer, headtmp->data);
|
|
||||||
headtmp = headtmp->next;
|
|
||||||
while (headtmp) {
|
|
||||||
strncat(obj->data.tail.buffer, headtmp->data, (TEXT_BUFFER_SIZE * 20) - strlen(obj->data.tail.buffer)); /* without strlen() at the end this becomes a possible */
|
|
||||||
headtmp = headtmp->next;
|
|
||||||
}
|
|
||||||
freetail(freetmp);
|
|
||||||
/* get rid of any ugly newlines at the end */
|
|
||||||
if (obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] == '\n') {
|
|
||||||
obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] = '\0';
|
|
||||||
}
|
}
|
||||||
snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
|
snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
strcpy(obj->data.tail.buffer, "Logfile Empty");
|
strcpy(obj->data.tail.buffer, "Logfile Empty");
|
||||||
snprintf(p, p_max_size, "Logfile Empty");
|
snprintf(p, p_max_size, "Logfile Empty");
|
||||||
} /* if readlines > 0 */
|
} /* nl > 0 */
|
||||||
} /* if fp == null */
|
} /* if fp == null */
|
||||||
} /* cur_upd_time >= */
|
} /* cur_upd_time >= */
|
||||||
|
|
||||||
@ -4808,6 +4863,11 @@ static void generate_text()
|
|||||||
current_update_time = get_time();
|
current_update_time = get_time();
|
||||||
|
|
||||||
update_stuff(cur);
|
update_stuff(cur);
|
||||||
|
/* fix diskio rates to b/s (use update_interval */
|
||||||
|
diskio_read_value = diskio_read_value / update_interval;
|
||||||
|
diskio_write_value = diskio_write_value / update_interval;
|
||||||
|
diskio_value = diskio_value / update_interval;
|
||||||
|
|
||||||
|
|
||||||
/* add things to the buffer */
|
/* add things to the buffer */
|
||||||
|
|
||||||
|
@ -96,6 +96,8 @@ struct net_stat {
|
|||||||
};
|
};
|
||||||
|
|
||||||
unsigned int diskio_value;
|
unsigned int diskio_value;
|
||||||
|
unsigned int diskio_read_value;
|
||||||
|
unsigned int diskio_write_value;
|
||||||
|
|
||||||
struct fs_stat {
|
struct fs_stat {
|
||||||
char *path;
|
char *path;
|
||||||
|
22
src/linux.c
22
src/linux.c
@ -1521,17 +1521,20 @@ void update_top()
|
|||||||
void update_diskio()
|
void update_diskio()
|
||||||
{
|
{
|
||||||
static unsigned int last = UINT_MAX;
|
static unsigned int last = UINT_MAX;
|
||||||
|
static unsigned int last_read = UINT_MAX;
|
||||||
|
static unsigned int last_write = UINT_MAX;
|
||||||
FILE* fp;
|
FILE* fp;
|
||||||
static int rep=0;
|
static int rep=0;
|
||||||
|
|
||||||
char buf[512];
|
char buf[512];
|
||||||
int major, minor;
|
int major, minor;
|
||||||
unsigned int current = 0;
|
unsigned int current = 0;
|
||||||
|
unsigned int current_read = 0;
|
||||||
|
unsigned int current_write = 0;
|
||||||
unsigned int reads, writes = 0;
|
unsigned int reads, writes = 0;
|
||||||
int col_count = 0;
|
int col_count = 0;
|
||||||
|
|
||||||
if (!(fp =open_file("/proc/diskstats", &rep)))
|
if (!(fp =open_file("/proc/diskstats", &rep))) {
|
||||||
{
|
|
||||||
diskio_value=0;
|
diskio_value=0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1539,7 +1542,6 @@ void update_diskio()
|
|||||||
/* read reads and writes from all disks (minor = 0), including
|
/* read reads and writes from all disks (minor = 0), including
|
||||||
* cd-roms and floppies, and summ them up
|
* cd-roms and floppies, and summ them up
|
||||||
*/
|
*/
|
||||||
current = 0;
|
|
||||||
while (!feof(fp)) {
|
while (!feof(fp)) {
|
||||||
fgets(buf, 512, fp);
|
fgets(buf, 512, fp);
|
||||||
col_count = sscanf(buf, "%u %u %*s %*u %*u %u %*u %*u %*u %u",
|
col_count = sscanf(buf, "%u %u %*s %*u %*u %u %*u %*u %*u %u",
|
||||||
@ -1553,6 +1555,8 @@ void update_diskio()
|
|||||||
major != LVM_BLK_MAJOR && major != NBD_MAJOR &&
|
major != LVM_BLK_MAJOR && major != NBD_MAJOR &&
|
||||||
major != RAMDISK_MAJOR && major != LOOP_MAJOR) {
|
major != RAMDISK_MAJOR && major != LOOP_MAJOR) {
|
||||||
current += reads + writes;
|
current += reads + writes;
|
||||||
|
current_read += reads;
|
||||||
|
current_write += writes;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1561,6 +1565,14 @@ void update_diskio()
|
|||||||
* "sectors read", and we therefore have to divide by two to
|
* "sectors read", and we therefore have to divide by two to
|
||||||
* get KB */
|
* get KB */
|
||||||
int tot = ((double)(current-last)/2);
|
int tot = ((double)(current-last)/2);
|
||||||
|
int tot_read = ((double)(current_read-last_read)/2);
|
||||||
|
int tot_write = ((double)(current_write-last_write)/2);
|
||||||
|
|
||||||
|
if (last_read > current_read)
|
||||||
|
tot_read = 0;
|
||||||
|
if (last_write > current_write)
|
||||||
|
tot_write = 0;
|
||||||
|
|
||||||
if (last > current) {
|
if (last > current) {
|
||||||
/* we hit this either if it's the very first time we
|
/* we hit this either if it's the very first time we
|
||||||
* run this, or when /proc/diskstats overflows; while
|
* run this, or when /proc/diskstats overflows; while
|
||||||
@ -1568,8 +1580,12 @@ void update_diskio()
|
|||||||
tot = 0;
|
tot = 0;
|
||||||
}
|
}
|
||||||
last = current;
|
last = current;
|
||||||
|
last_read = current_read;
|
||||||
|
last_write = current_write;
|
||||||
|
|
||||||
diskio_value = tot;
|
diskio_value = tot;
|
||||||
|
diskio_read_value = tot_read;
|
||||||
|
diskio_write_value = tot_write;
|
||||||
|
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user