mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-16 20:18:07 +00:00
Merge remote branch 'origin/master' into lua-config
This commit is contained in:
commit
07746cdd5a
@ -43,6 +43,7 @@ endif(CMAKE_SYSTEM_NAME MATCHES "Linux")
|
|||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "FreeBSD")
|
if(CMAKE_SYSTEM_NAME MATCHES "FreeBSD")
|
||||||
set(OS_FREEBSD true)
|
set(OS_FREEBSD true)
|
||||||
|
set(conky_libs ${conky_libs} -lkvm -ldevstat)
|
||||||
endif(CMAKE_SYSTEM_NAME MATCHES "FreeBSD")
|
endif(CMAKE_SYSTEM_NAME MATCHES "FreeBSD")
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "OpenBSD")
|
if(CMAKE_SYSTEM_NAME MATCHES "OpenBSD")
|
||||||
|
@ -1600,8 +1600,7 @@
|
|||||||
digits.</member>
|
digits.</member>
|
||||||
<member>
|
<member>
|
||||||
<command>string</command>Argument is enclosed in
|
<command>string</command>Argument is enclosed in
|
||||||
quotation mark or the checks for double and long failed
|
quotation marks (")</member>
|
||||||
before.</member>
|
|
||||||
</simplelist>Valid operands are: '>', '<', '>=',
|
</simplelist>Valid operands are: '>', '<', '>=',
|
||||||
'<=', '==', '!='.
|
'<=', '==', '!='.
|
||||||
<para /></listitem>
|
<para /></listitem>
|
||||||
@ -3075,12 +3074,14 @@
|
|||||||
<command>
|
<command>
|
||||||
<option>scroll</option>
|
<option>scroll</option>
|
||||||
</command>
|
</command>
|
||||||
<option>length (step) text</option>
|
<option>(direction) length (step) text</option>
|
||||||
</term>
|
</term>
|
||||||
<listitem>Scroll 'text' by 'step' characters showing
|
<listitem>Scroll 'text' by 'step' characters to the left
|
||||||
|
or right (set 'direction' to 'left' or 'right') showing
|
||||||
'length' number of characters at the same time. The text
|
'length' number of characters at the same time. The text
|
||||||
may also contain variables. 'step' is optional and defaults
|
may also contain variables. 'step' is optional and defaults
|
||||||
to 1 if not set. If a var creates output on multiple lines
|
to 1 if not set. 'direction' is optional and defaults to left
|
||||||
|
if not set. If a var creates output on multiple lines
|
||||||
then the lines are placed behind each other separated with
|
then the lines are placed behind each other separated with
|
||||||
a '|'-sign. If you change the textcolor inside $scroll it
|
a '|'-sign. If you change the textcolor inside $scroll it
|
||||||
will automatically have it's old value back at the end of
|
will automatically have it's old value back at the end of
|
||||||
|
@ -126,11 +126,9 @@ enum arg_type get_arg_type(const char *arg)
|
|||||||
const char *p, *e;
|
const char *p, *e;
|
||||||
|
|
||||||
p = arg;
|
p = arg;
|
||||||
e = arg + strlen(arg);
|
e = arg + strlen(arg)-1;
|
||||||
|
|
||||||
if (*(e - 1) == ' ')
|
while (p != e && *e && *e == ' ')
|
||||||
e--;
|
|
||||||
while (*e && *e == ' ')
|
|
||||||
e--;
|
e--;
|
||||||
while (p != e && *p == ' ')
|
while (p != e && *p == ' ')
|
||||||
p++;
|
p++;
|
||||||
@ -140,23 +138,23 @@ enum arg_type get_arg_type(const char *arg)
|
|||||||
|
|
||||||
if (*p == '-') //allow negative values
|
if (*p == '-') //allow negative values
|
||||||
p++;
|
p++;
|
||||||
while (p != e) {
|
while (p <= e) {
|
||||||
if (!isdigit(*p))
|
if (!isdigit(*p))
|
||||||
break;
|
break;
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
if (p == e)
|
if (p == e+1)
|
||||||
return ARG_LONG;
|
return ARG_LONG;
|
||||||
if (*p == '.') {
|
if (*p == '.') {
|
||||||
p++;
|
p++;
|
||||||
while (p != e) {
|
while (p <= e) {
|
||||||
if (!isdigit(*p))
|
if (!isdigit(*p))
|
||||||
return ARG_STRING;
|
return ARG_BAD;
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
return ARG_DOUBLE;
|
return ARG_DOUBLE;
|
||||||
}
|
}
|
||||||
return ARG_STRING;
|
return ARG_BAD;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *arg_to_string(const char *arg)
|
char *arg_to_string(const char *arg)
|
||||||
@ -197,6 +195,8 @@ int compare(const char *expr)
|
|||||||
char *expr_dup;
|
char *expr_dup;
|
||||||
int idx, mtype;
|
int idx, mtype;
|
||||||
enum arg_type type1, type2;
|
enum arg_type type1, type2;
|
||||||
|
long lng_a, lng_b;
|
||||||
|
double dbl_a, dbl_b;
|
||||||
|
|
||||||
idx = find_match_op(expr);
|
idx = find_match_op(expr);
|
||||||
mtype = get_match_type(expr);
|
mtype = get_match_type(expr);
|
||||||
@ -213,6 +213,11 @@ int compare(const char *expr)
|
|||||||
|
|
||||||
type1 = get_arg_type(expr_dup);
|
type1 = get_arg_type(expr_dup);
|
||||||
type2 = get_arg_type(expr_dup + idx + 1);
|
type2 = get_arg_type(expr_dup + idx + 1);
|
||||||
|
if (type1 == ARG_BAD || type2 == ARG_BAD) {
|
||||||
|
NORM_ERR("Bad arguments: '%s' and '%s'", expr_dup, (expr_dup + idx + 1));
|
||||||
|
free(expr_dup);
|
||||||
|
return -2;
|
||||||
|
}
|
||||||
if (type1 == ARG_LONG && type2 == ARG_DOUBLE)
|
if (type1 == ARG_LONG && type2 == ARG_DOUBLE)
|
||||||
type1 = ARG_DOUBLE;
|
type1 = ARG_DOUBLE;
|
||||||
if (type1 == ARG_DOUBLE && type2 == ARG_LONG)
|
if (type1 == ARG_DOUBLE && type2 == ARG_LONG)
|
||||||
@ -220,6 +225,7 @@ int compare(const char *expr)
|
|||||||
if (type1 != type2) {
|
if (type1 != type2) {
|
||||||
NORM_ERR("trying to compare args '%s' and '%s' of different type",
|
NORM_ERR("trying to compare args '%s' and '%s' of different type",
|
||||||
expr_dup, (expr_dup + idx + 1));
|
expr_dup, (expr_dup + idx + 1));
|
||||||
|
free(expr_dup);
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
switch (type1) {
|
switch (type1) {
|
||||||
@ -231,16 +237,23 @@ int compare(const char *expr)
|
|||||||
idx = scompare(a, (enum match_type) mtype, b);
|
idx = scompare(a, (enum match_type) mtype, b);
|
||||||
free(a);
|
free(a);
|
||||||
free(b);
|
free(b);
|
||||||
|
free(expr_dup);
|
||||||
return idx;
|
return idx;
|
||||||
}
|
}
|
||||||
case ARG_LONG:
|
case ARG_LONG:
|
||||||
return lcompare(arg_to_long(expr_dup), (enum match_type) mtype,
|
lng_a = arg_to_long(expr_dup);
|
||||||
arg_to_long(expr_dup + idx + 1));
|
lng_b = arg_to_long(expr_dup + idx + 1);
|
||||||
|
free(expr_dup);
|
||||||
|
return lcompare(lng_a, (enum match_type) mtype, lng_b);
|
||||||
case ARG_DOUBLE:
|
case ARG_DOUBLE:
|
||||||
return dcompare(arg_to_double(expr_dup), (enum match_type) mtype,
|
dbl_a = arg_to_double(expr_dup);
|
||||||
arg_to_double(expr_dup + idx + 1));
|
dbl_b = arg_to_double(expr_dup + idx + 1);
|
||||||
|
free(expr_dup);
|
||||||
|
return dcompare(dbl_a, (enum match_type) mtype, dbl_b);
|
||||||
|
case ARG_BAD: /* make_gcc_happy() */;
|
||||||
}
|
}
|
||||||
/* not reached */
|
/* not reached */
|
||||||
|
free(expr_dup);
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,6 +44,7 @@ enum match_type {
|
|||||||
};
|
};
|
||||||
|
|
||||||
enum arg_type {
|
enum arg_type {
|
||||||
|
ARG_BAD = 0, /* something strange */
|
||||||
ARG_STRING = 1, /* "asdf" */
|
ARG_STRING = 1, /* "asdf" */
|
||||||
ARG_LONG = 2, /* 123456 */
|
ARG_LONG = 2, /* 123456 */
|
||||||
ARG_DOUBLE = 3 /* 12.456 */
|
ARG_DOUBLE = 3 /* 12.456 */
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
#include <machine/apm_bios.h>
|
#include <machine/apm_bios.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#define APMDEV "/dev/apm"
|
#define APMDEV "/dev/apm"
|
||||||
#define APM_UNKNOWN 255
|
#define APM_UNKNOWN 255
|
||||||
|
@ -30,16 +30,8 @@
|
|||||||
#ifndef _BSDAPM_H
|
#ifndef _BSDAPM_H
|
||||||
#define _BSDAPM_H
|
#define _BSDAPM_H
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void print_apm_adapter(struct text_object *, char *, int);
|
void print_apm_adapter(struct text_object *, char *, int);
|
||||||
void print_apm_battery_life(struct text_object *, char *, int);
|
void print_apm_battery_life(struct text_object *, char *, int);
|
||||||
void print_apm_battery_time(struct text_object *, char *, int);
|
void print_apm_battery_time(struct text_object *, char *, int);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _BSDAPM_H */
|
#endif /* _BSDAPM_H */
|
||||||
|
43
src/conky.cc
43
src/conky.cc
@ -64,7 +64,7 @@
|
|||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
#include <ncurses.h>
|
#include <ncurses.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef BUILD_WEATHER_XOAP
|
#ifdef BUILD_WEATHER_XOAP
|
||||||
@ -161,6 +161,10 @@ void *global_cpu = NULL;
|
|||||||
unsigned int max_text_width = 0;
|
unsigned int max_text_width = 0;
|
||||||
int ifup_strictness = IFUP_UP;
|
int ifup_strictness = IFUP_UP;
|
||||||
|
|
||||||
|
#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
|
||||||
|
extern kvm_t *kd;
|
||||||
|
#endif
|
||||||
|
|
||||||
int argc_copy;
|
int argc_copy;
|
||||||
char** argv_copy;
|
char** argv_copy;
|
||||||
|
|
||||||
@ -554,6 +558,13 @@ int percent_print(char *buf, int size, unsigned value)
|
|||||||
return spaced_print(buf, size, "%u", pad_percents, value);
|
return spaced_print(buf, size, "%u", pad_percents, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(__FreeBSD__)
|
||||||
|
unsigned long long llabs(long long num) {
|
||||||
|
if(num < 0) return -num;
|
||||||
|
else return num;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* converts from bytes to human readable format (K, M, G, T)
|
/* converts from bytes to human readable format (K, M, G, T)
|
||||||
*
|
*
|
||||||
* The algorithm always divides by 1024, as unit-conversion of byte
|
* The algorithm always divides by 1024, as unit-conversion of byte
|
||||||
@ -1114,11 +1125,11 @@ static inline void set_foreground_color(long c)
|
|||||||
XSetForeground(display, window.gc, current_color);
|
XSetForeground(display, window.gc, current_color);
|
||||||
}
|
}
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if (output_methods & TO_NCURSES) {
|
if (output_methods & TO_NCURSES) {
|
||||||
attron(COLOR_PAIR(c));
|
attron(COLOR_PAIR(c));
|
||||||
}
|
}
|
||||||
#endif /* NCURSES */
|
#endif /* BUILD_NCURSES */
|
||||||
UNUSED(c);
|
UNUSED(c);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1156,7 +1167,7 @@ static void draw_string(const char *s)
|
|||||||
if ((output_methods & APPEND_FILE) && draw_mode == FG && append_fpointer) {
|
if ((output_methods & APPEND_FILE) && draw_mode == FG && append_fpointer) {
|
||||||
fprintf(append_fpointer, "%s\n", s_with_newlines);
|
fprintf(append_fpointer, "%s\n", s_with_newlines);
|
||||||
}
|
}
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if ((output_methods & TO_NCURSES) && draw_mode == FG) {
|
if ((output_methods & TO_NCURSES) && draw_mode == FG) {
|
||||||
printw("%s", s_with_newlines);
|
printw("%s", s_with_newlines);
|
||||||
}
|
}
|
||||||
@ -1687,11 +1698,11 @@ int draw_each_line_inner(char *s, int special_index, int last_special_applied)
|
|||||||
cur_y += cur_y_add;
|
cur_y += cur_y_add;
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
draw_string(s);
|
draw_string(s);
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if (output_methods & TO_NCURSES) {
|
if (output_methods & TO_NCURSES) {
|
||||||
printw("\n");
|
printw("\n");
|
||||||
}
|
}
|
||||||
#endif /* NCURSES */
|
#endif /* BUILD_NCURSES */
|
||||||
#ifdef BUILD_X11
|
#ifdef BUILD_X11
|
||||||
if (output_methods & TO_X)
|
if (output_methods & TO_X)
|
||||||
cur_y += font_descent();
|
cur_y += font_descent();
|
||||||
@ -1710,11 +1721,11 @@ static int draw_line(char *s, int special_index)
|
|||||||
return draw_each_line_inner(s, special_index, -1);
|
return draw_each_line_inner(s, special_index, -1);
|
||||||
}
|
}
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if (output_methods & TO_NCURSES) {
|
if (output_methods & TO_NCURSES) {
|
||||||
return draw_each_line_inner(s, special_index, -1);
|
return draw_each_line_inner(s, special_index, -1);
|
||||||
}
|
}
|
||||||
#endif /* NCURSES */
|
#endif /* BUILD_NCURSES */
|
||||||
draw_string(s);
|
draw_string(s);
|
||||||
UNUSED(special_index);
|
UNUSED(special_index);
|
||||||
return 0;
|
return 0;
|
||||||
@ -1752,10 +1763,10 @@ static void draw_text(void)
|
|||||||
}
|
}
|
||||||
setup_fonts();
|
setup_fonts();
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
init_pair(COLOR_WHITE, COLOR_WHITE, COLOR_BLACK);
|
init_pair(COLOR_WHITE, COLOR_WHITE, COLOR_BLACK);
|
||||||
attron(COLOR_PAIR(COLOR_WHITE));
|
attron(COLOR_PAIR(COLOR_WHITE));
|
||||||
#endif /* NCURSES */
|
#endif /* BUILD_NCURSES */
|
||||||
for_each_line(text_buffer, draw_line);
|
for_each_line(text_buffer, draw_line);
|
||||||
#if defined(BUILD_LUA) && defined(BUILD_X11)
|
#if defined(BUILD_LUA) && defined(BUILD_X11)
|
||||||
llua_draw_post_hook();
|
llua_draw_post_hook();
|
||||||
@ -2221,7 +2232,7 @@ static void main_loop(void)
|
|||||||
if(t > 0) usleep((useconds_t)t);
|
if(t > 0) usleep((useconds_t)t);
|
||||||
update_text();
|
update_text();
|
||||||
draw_stuff();
|
draw_stuff();
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if(output_methods & TO_NCURSES) {
|
if(output_methods & TO_NCURSES) {
|
||||||
refresh();
|
refresh();
|
||||||
clear();
|
clear();
|
||||||
@ -2369,7 +2380,7 @@ void clean_up(void *memtofree1, void* memtofree2)
|
|||||||
|
|
||||||
free_update_callbacks();
|
free_update_callbacks();
|
||||||
|
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if(output_methods & TO_NCURSES) {
|
if(output_methods & TO_NCURSES) {
|
||||||
endwin();
|
endwin();
|
||||||
}
|
}
|
||||||
@ -2904,6 +2915,7 @@ static int do_config_step(int *line, FILE *fp, char *buf, char **name, char **va
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef BUILD_X11
|
||||||
void setalignment(int* text_alignment, unsigned int windowtype, const char* value, const char *f, int line, bool conffile) {
|
void setalignment(int* text_alignment, unsigned int windowtype, const char* value, const char *f, int line, bool conffile) {
|
||||||
#ifdef OWN_WINDOW
|
#ifdef OWN_WINDOW
|
||||||
if (windowtype == TYPE_DOCK) {
|
if (windowtype == TYPE_DOCK) {
|
||||||
@ -2924,6 +2936,7 @@ void setalignment(int* text_alignment, unsigned int windowtype, const char* valu
|
|||||||
CONF_ERR;
|
CONF_ERR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif /* BUILD_X11 */
|
||||||
|
|
||||||
char load_config_file(const char *f)
|
char load_config_file(const char *f)
|
||||||
{
|
{
|
||||||
@ -3199,7 +3212,7 @@ char load_config_file(const char *f)
|
|||||||
if(string_to_bool(value))
|
if(string_to_bool(value))
|
||||||
output_methods |= TO_STDERR;
|
output_methods |= TO_STDERR;
|
||||||
}
|
}
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
CONF("out_to_ncurses") {
|
CONF("out_to_ncurses") {
|
||||||
if(string_to_bool(value)) {
|
if(string_to_bool(value)) {
|
||||||
initscr();
|
initscr();
|
||||||
@ -3702,7 +3715,7 @@ char load_config_file(const char *f)
|
|||||||
if (!output_methods) {
|
if (!output_methods) {
|
||||||
CRIT_ERR(0, 0, "no output_methods have been selected; exiting");
|
CRIT_ERR(0, 0, "no output_methods have been selected; exiting");
|
||||||
}
|
}
|
||||||
#if defined(NCURSES)
|
#if defined(BUILD_NCURSES)
|
||||||
#if defined(BUILD_X11)
|
#if defined(BUILD_X11)
|
||||||
if ((output_methods & TO_X) && (output_methods & TO_NCURSES)) {
|
if ((output_methods & TO_X) && (output_methods & TO_NCURSES)) {
|
||||||
NORM_ERR("out_to_x and out_to_ncurses are incompatible, turning out_to_ncurses off");
|
NORM_ERR("out_to_x and out_to_ncurses are incompatible, turning out_to_ncurses off");
|
||||||
@ -3714,7 +3727,7 @@ char load_config_file(const char *f)
|
|||||||
NORM_ERR("out_to_ncurses conflicts with out_to_console and out_to_stderr, disabling the later ones");
|
NORM_ERR("out_to_ncurses conflicts with out_to_console and out_to_stderr, disabling the later ones");
|
||||||
output_methods &= ~(TO_STDOUT | TO_STDERR);
|
output_methods &= ~(TO_STDOUT | TO_STDERR);
|
||||||
}
|
}
|
||||||
#endif /* NCURSES */
|
#endif /* BUILD_NCURSES */
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,7 +136,7 @@ static struct text_object *create_plain_text(const char *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* construct_text_object() creates a new text_object */
|
/* construct_text_object() creates a new text_object */
|
||||||
struct text_object *construct_text_object(const char *s, const char *arg, long
|
struct text_object *construct_text_object(char *s, const char *arg, long
|
||||||
line, void **ifblock_opaque, void *free_at_crash)
|
line, void **ifblock_opaque, void *free_at_crash)
|
||||||
{
|
{
|
||||||
// struct text_object *obj = new_text_object();
|
// struct text_object *obj = new_text_object();
|
||||||
@ -1563,9 +1563,8 @@ struct text_object *construct_text_object(const char *s, const char *arg, long
|
|||||||
END OBJ(scroll, 0)
|
END OBJ(scroll, 0)
|
||||||
#ifdef BUILD_X11
|
#ifdef BUILD_X11
|
||||||
/* allocate a follower to reset any color changes */
|
/* allocate a follower to reset any color changes */
|
||||||
obj->next = new_text_object_internal();
|
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
parse_scroll_arg(obj, arg, free_at_crash);
|
parse_scroll_arg(obj, arg, free_at_crash, s);
|
||||||
obj->callbacks.print = &print_scroll;
|
obj->callbacks.print = &print_scroll;
|
||||||
obj->callbacks.free = &free_scroll;
|
obj->callbacks.free = &free_scroll;
|
||||||
END OBJ_ARG(combine, 0, "combine needs arguments: <text1> <text2>")
|
END OBJ_ARG(combine, 0, "combine needs arguments: <text1> <text2>")
|
||||||
|
@ -67,6 +67,8 @@
|
|||||||
#define FREEBSD_DEBUG
|
#define FREEBSD_DEBUG
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
kvm_t *kd;
|
||||||
|
|
||||||
__attribute__((gnu_inline)) inline void
|
__attribute__((gnu_inline)) inline void
|
||||||
proc_find_top(struct process **cpu, struct process **mem);
|
proc_find_top(struct process **cpu, struct process **mem);
|
||||||
|
|
||||||
@ -302,7 +304,7 @@ void get_cpu_count(void)
|
|||||||
info.cpu_count = 0;
|
info.cpu_count = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
info.cpu_usage = malloc((info.cpu_count + 1) * sizeof(float));
|
info.cpu_usage = (float *) malloc((info.cpu_count + 1) * sizeof(float));
|
||||||
if (info.cpu_usage == NULL) {
|
if (info.cpu_usage == NULL) {
|
||||||
CRIT_ERR(NULL, NULL, "malloc");
|
CRIT_ERR(NULL, NULL, "malloc");
|
||||||
}
|
}
|
||||||
@ -331,14 +333,14 @@ void update_cpu_usage(void)
|
|||||||
|
|
||||||
if (!global_cpu) {
|
if (!global_cpu) {
|
||||||
malloc_cpu_size = (info.cpu_count + 1) * sizeof(struct cpu_info);
|
malloc_cpu_size = (info.cpu_count + 1) * sizeof(struct cpu_info);
|
||||||
cpu = malloc(malloc_cpu_size);
|
cpu = (cpu_info *) malloc(malloc_cpu_size);
|
||||||
memset(cpu, 0, malloc_cpu_size);
|
memset(cpu, 0, malloc_cpu_size);
|
||||||
global_cpu = cpu;
|
global_cpu = cpu;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* cpu[0] is overall stats, get it from separate sysctl */
|
/* cpu[0] is overall stats, get it from separate sysctl */
|
||||||
cp_len = CPUSTATES * sizeof(long);
|
cp_len = CPUSTATES * sizeof(long);
|
||||||
cp_time = malloc(cp_len);
|
cp_time = (long int *) malloc(cp_len);
|
||||||
|
|
||||||
if (sysctlbyname("kern.cp_time", cp_time, &cp_len, NULL, 0) < 0) {
|
if (sysctlbyname("kern.cp_time", cp_time, &cp_len, NULL, 0) < 0) {
|
||||||
fprintf(stderr, "Cannot get kern.cp_time\n");
|
fprintf(stderr, "Cannot get kern.cp_time\n");
|
||||||
@ -364,7 +366,7 @@ void update_cpu_usage(void)
|
|||||||
|
|
||||||
/* per-core stats */
|
/* per-core stats */
|
||||||
cp_len = CPUSTATES * sizeof(long) * info.cpu_count;
|
cp_len = CPUSTATES * sizeof(long) * info.cpu_count;
|
||||||
cp_time = malloc(cp_len);
|
cp_time = (long int *) malloc(cp_len);
|
||||||
|
|
||||||
/* on e.g. i386 SMP we may have more values than actual cpus; this will just drop extra values */
|
/* on e.g. i386 SMP we may have more values than actual cpus; this will just drop extra values */
|
||||||
if (sysctlbyname("kern.cp_times", cp_time, &cp_len, NULL, 0) < 0 && errno != ENOMEM) {
|
if (sysctlbyname("kern.cp_times", cp_time, &cp_len, NULL, 0) < 0 && errno != ENOMEM) {
|
||||||
@ -734,7 +736,7 @@ proc_find_top(struct process **cpu, struct process **mem)
|
|||||||
}
|
}
|
||||||
|
|
||||||
p = kvm_getprocs(kd, KERN_PROC_PROC, 0, &n_processes);
|
p = kvm_getprocs(kd, KERN_PROC_PROC, 0, &n_processes);
|
||||||
processes = malloc(n_processes * sizeof(struct process));
|
processes = (process *) malloc(n_processes * sizeof(struct process));
|
||||||
|
|
||||||
for (i = 0; i < n_processes; i++) {
|
for (i = 0; i < n_processes; i++) {
|
||||||
if (!((p[i].ki_flag & P_SYSTEM)) && p[i].ki_comm != NULL) {
|
if (!((p[i].ki_flag & P_SYSTEM)) && p[i].ki_comm != NULL) {
|
||||||
@ -751,7 +753,7 @@ proc_find_top(struct process **cpu, struct process **mem)
|
|||||||
for (i = 0; i < 10 && i < n_processes; i++) {
|
for (i = 0; i < 10 && i < n_processes; i++) {
|
||||||
struct process *tmp, *ttmp;
|
struct process *tmp, *ttmp;
|
||||||
|
|
||||||
tmp = malloc(sizeof(struct process));
|
tmp = (process *) malloc(sizeof(struct process));
|
||||||
tmp->pid = processes[i].pid;
|
tmp->pid = processes[i].pid;
|
||||||
tmp->amount = processes[i].amount;
|
tmp->amount = processes[i].amount;
|
||||||
tmp->name = strndup(processes[i].name, text_buffer_size);
|
tmp->name = strndup(processes[i].name, text_buffer_size);
|
||||||
@ -770,7 +772,7 @@ proc_find_top(struct process **cpu, struct process **mem)
|
|||||||
for (i = 0; i < 10 && i < n_processes; i++) {
|
for (i = 0; i < 10 && i < n_processes; i++) {
|
||||||
struct process *tmp, *ttmp;
|
struct process *tmp, *ttmp;
|
||||||
|
|
||||||
tmp = malloc(sizeof(struct process));
|
tmp = (process *) malloc(sizeof(struct process));
|
||||||
tmp->pid = processes[i].pid;
|
tmp->pid = processes[i].pid;
|
||||||
tmp->amount = processes[i].amount;
|
tmp->amount = processes[i].amount;
|
||||||
tmp->name = strndup(processes[i].name, text_buffer_size);
|
tmp->name = strndup(processes[i].name, text_buffer_size);
|
||||||
|
@ -17,8 +17,6 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
kvm_t *kd;
|
|
||||||
|
|
||||||
int get_entropy_avail(unsigned int *);
|
int get_entropy_avail(unsigned int *);
|
||||||
int get_entropy_poolsize(unsigned int *);
|
int get_entropy_poolsize(unsigned int *);
|
||||||
|
|
||||||
|
@ -51,6 +51,10 @@
|
|||||||
#ifdef HAVE_SYS_MOUNT_H
|
#ifdef HAVE_SYS_MOUNT_H
|
||||||
#include <sys/mount.h>
|
#include <sys/mount.h>
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(__FreeBSD__)
|
||||||
|
#include "freebsd.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#if !defined(HAVE_STRUCT_STATFS_F_FSTYPENAME) && !defined (__OpenBSD__) && !defined(__FreeBSD__)
|
#if !defined(HAVE_STRUCT_STATFS_F_FSTYPENAME) && !defined (__OpenBSD__) && !defined(__FreeBSD__)
|
||||||
#include <mntent.h>
|
#include <mntent.h>
|
||||||
|
@ -52,6 +52,7 @@
|
|||||||
# include <netinet/in.h>
|
# include <netinet/in.h>
|
||||||
# include <arpa/inet.h>
|
# include <arpa/inet.h>
|
||||||
# include <sys/socket.h>
|
# include <sys/socket.h>
|
||||||
|
# include <sys/un.h>
|
||||||
# include <netdb.h>
|
# include <netdb.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -119,6 +120,38 @@ static int do_connect_fail(mpd_Connection *connection,
|
|||||||
}
|
}
|
||||||
#endif /* !WIN32 */
|
#endif /* !WIN32 */
|
||||||
|
|
||||||
|
static int uds_connect(mpd_Connection *connection, const char *host,
|
||||||
|
float timeout)
|
||||||
|
{
|
||||||
|
struct sockaddr_un addr;
|
||||||
|
|
||||||
|
strncpy(addr.sun_path, host, sizeof(addr.sun_path)-1);
|
||||||
|
addr.sun_family = AF_UNIX;
|
||||||
|
addr.sun_path[sizeof(addr.sun_path)-1] = 0;
|
||||||
|
connection->sock = socket(AF_UNIX, SOCK_STREAM, 0);
|
||||||
|
|
||||||
|
if (connection->sock < 0) {
|
||||||
|
snprintf(connection->errorStr, MPD_ERRORSTR_MAX_LENGTH,
|
||||||
|
"problems creating socket: %s", strerror(errno));
|
||||||
|
connection->error = MPD_ERROR_SYSTEM;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
mpd_setConnectionTimeout(connection, timeout);
|
||||||
|
|
||||||
|
/* connect stuff */
|
||||||
|
if (do_connect_fail(connection, (struct sockaddr *)&addr, SUN_LEN(&addr))) {
|
||||||
|
snprintf(connection->errorStr, MPD_ERRORSTR_MAX_LENGTH,
|
||||||
|
"problems cconnecting socket: %s", strerror(errno));
|
||||||
|
closesocket(connection->sock);
|
||||||
|
connection->sock = -1;
|
||||||
|
connection->error = MPD_ERROR_SYSTEM;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef MPD_HAVE_GAI
|
#ifdef MPD_HAVE_GAI
|
||||||
static int mpd_connect(mpd_Connection *connection, const char *host, int port,
|
static int mpd_connect(mpd_Connection *connection, const char *host, int port,
|
||||||
float timeout)
|
float timeout)
|
||||||
@ -129,6 +162,9 @@ static int mpd_connect(mpd_Connection *connection, const char *host, int port,
|
|||||||
struct addrinfo *res = NULL;
|
struct addrinfo *res = NULL;
|
||||||
struct addrinfo *addrinfo = NULL;
|
struct addrinfo *addrinfo = NULL;
|
||||||
|
|
||||||
|
if (*host == '/')
|
||||||
|
return uds_connect(connection, host, timeout);
|
||||||
|
|
||||||
/* Setup hints */
|
/* Setup hints */
|
||||||
hints.ai_flags = AI_ADDRCONFIG;
|
hints.ai_flags = AI_ADDRCONFIG;
|
||||||
hints.ai_family = AF_UNSPEC;
|
hints.ai_family = AF_UNSPEC;
|
||||||
@ -200,6 +236,9 @@ static int mpd_connect(mpd_Connection *connection, const char *host, int port,
|
|||||||
int destlen;
|
int destlen;
|
||||||
struct sockaddr_in sin;
|
struct sockaddr_in sin;
|
||||||
|
|
||||||
|
if (*host == '/')
|
||||||
|
return uds_connect(connection, host, timeout);
|
||||||
|
|
||||||
#ifdef HAVE_GETHOSTBYNAME_R
|
#ifdef HAVE_GETHOSTBYNAME_R
|
||||||
if (gethostbyname_r(rhost, &he, hostbuff, sizeof(hostbuff), &he_res, &he_errno)) { // get the host info
|
if (gethostbyname_r(rhost, &he, hostbuff, sizeof(hostbuff), &he_res, &he_errno)) { // get the host info
|
||||||
snprintf(connection->errorStr, MPD_ERRORSTR_MAX_LENGTH,
|
snprintf(connection->errorStr, MPD_ERRORSTR_MAX_LENGTH,
|
||||||
|
@ -34,29 +34,49 @@
|
|||||||
#include "text_object.h"
|
#include "text_object.h"
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
#define SCROLL_LEFT true
|
||||||
|
#define SCROLL_RIGHT false
|
||||||
|
|
||||||
struct scroll_data {
|
struct scroll_data {
|
||||||
char *text;
|
char *text;
|
||||||
unsigned int show;
|
unsigned int show;
|
||||||
unsigned int step;
|
unsigned int step;
|
||||||
unsigned int start;
|
signed int start;
|
||||||
long resetcolor;
|
long resetcolor;
|
||||||
|
bool direction;
|
||||||
};
|
};
|
||||||
|
|
||||||
void parse_scroll_arg(struct text_object *obj, const char *arg, void *free_at_crash)
|
void parse_scroll_arg(struct text_object *obj, const char *arg, void *free_at_crash, char *free_at_crash2)
|
||||||
{
|
{
|
||||||
struct scroll_data *sd;
|
struct scroll_data *sd;
|
||||||
int n1 = 0, n2 = 0;
|
int n1 = 0, n2 = 0;
|
||||||
|
char dirarg[6];
|
||||||
|
|
||||||
sd = (struct scroll_data *)malloc(sizeof(struct scroll_data));
|
sd = (struct scroll_data *)malloc(sizeof(struct scroll_data));
|
||||||
memset(sd, 0, sizeof(struct scroll_data));
|
memset(sd, 0, sizeof(struct scroll_data));
|
||||||
|
|
||||||
sd->resetcolor = get_current_text_color();
|
sd->resetcolor = get_current_text_color();
|
||||||
sd->step = 1;
|
sd->step = 1;
|
||||||
if (!arg || sscanf(arg, "%u %n", &sd->show, &n1) <= 0)
|
sd->direction = SCROLL_LEFT;
|
||||||
CRIT_ERR(obj, free_at_crash, "scroll needs arguments: <length> [<step>] <text>");
|
|
||||||
|
|
||||||
sscanf(arg + n1, "%u %n", &sd->step, &n2);
|
if (arg && sscanf(arg, "%5s %n", dirarg, &n1) == 1) {
|
||||||
if (*(arg + n1 + n2)) {
|
if (strcasecmp(dirarg, "right") == 0 || strcasecmp(dirarg, "r") == 0)
|
||||||
|
sd->direction = SCROLL_RIGHT;
|
||||||
|
else if ( strcasecmp(dirarg, "left") != 0 && strcasecmp(dirarg, "l") != 0)
|
||||||
|
n1 = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!arg || sscanf(arg + n1, "%u %n", &sd->show, &n2) <= 0) {
|
||||||
|
free(sd);
|
||||||
|
#ifdef BUILD_X11
|
||||||
|
free(obj->next);
|
||||||
|
#endif
|
||||||
|
free(free_at_crash2);
|
||||||
|
CRIT_ERR(obj, free_at_crash, "scroll needs arguments: [left|right] <length> [<step>] <text>");
|
||||||
|
}
|
||||||
|
n1 += n2;
|
||||||
|
|
||||||
|
if(sscanf(arg + n1, "%u %n", &sd->step, &n2) == 1) {
|
||||||
n1 += n2;
|
n1 += n2;
|
||||||
} else {
|
} else {
|
||||||
sd->step = 1;
|
sd->step = 1;
|
||||||
@ -81,8 +101,6 @@ void parse_scroll_arg(struct text_object *obj, const char *arg, void *free_at_cr
|
|||||||
|
|
||||||
#ifdef BUILD_X11
|
#ifdef BUILD_X11
|
||||||
/* add a color object right after scroll to reset any color changes */
|
/* add a color object right after scroll to reset any color changes */
|
||||||
obj->next->data.l = sd->resetcolor;
|
|
||||||
obj->next->callbacks.print = &new_fg;
|
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,7 +149,7 @@ void print_scroll(struct text_object *obj, char *p, int p_max_size)
|
|||||||
}
|
}
|
||||||
p[j] = 0;
|
p[j] = 0;
|
||||||
//count colorchanges in front of the visible part and place that many colorchanges in front of the visible part
|
//count colorchanges in front of the visible part and place that many colorchanges in front of the visible part
|
||||||
for(j = 0; j < sd->start; j++) {
|
for(j = 0; j < (unsigned) sd->start; j++) {
|
||||||
if(buf[j] == SPECIAL_CHAR) frontcolorchanges++;
|
if(buf[j] == SPECIAL_CHAR) frontcolorchanges++;
|
||||||
}
|
}
|
||||||
pwithcolors=(char*)malloc(strlen(p) + 1 + colorchanges - visibcolorchanges);
|
pwithcolors=(char*)malloc(strlen(p) + 1 + colorchanges - visibcolorchanges);
|
||||||
@ -149,10 +167,22 @@ void print_scroll(struct text_object *obj, char *p, int p_max_size)
|
|||||||
strcpy(p, pwithcolors);
|
strcpy(p, pwithcolors);
|
||||||
free(pwithcolors);
|
free(pwithcolors);
|
||||||
//scroll
|
//scroll
|
||||||
sd->start += sd->step;
|
if(sd->direction == SCROLL_LEFT) {
|
||||||
if(buf[sd->start] == 0 || sd->start > strlen(&(buf[0]))){
|
sd->start += sd->step;
|
||||||
sd->start = 0;
|
if(buf[sd->start] == 0 || (unsigned) sd->start > strlen(&(buf[0]))) {
|
||||||
|
sd->start = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(sd->start < 1) {
|
||||||
|
sd->start = strlen(&(buf[0]));
|
||||||
|
}
|
||||||
|
sd->start -= sd->step;
|
||||||
}
|
}
|
||||||
|
#ifdef BUILD_X11
|
||||||
|
//reset color when scroll is finished
|
||||||
|
if (output_methods & TO_X)
|
||||||
|
new_special(p + strlen(p), FG)->arg = sd->resetcolor;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void free_scroll(struct text_object *obj)
|
void free_scroll(struct text_object *obj)
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#ifndef _SCROLL_H
|
#ifndef _SCROLL_H
|
||||||
#define _SCROLL_H
|
#define _SCROLL_H
|
||||||
|
|
||||||
void parse_scroll_arg(struct text_object *, const char *, void *);
|
void parse_scroll_arg(struct text_object *, const char *, void *, char *);
|
||||||
void print_scroll(struct text_object *, char *, int);
|
void print_scroll(struct text_object *, char *, int);
|
||||||
void free_scroll(struct text_object *);
|
void free_scroll(struct text_object *);
|
||||||
|
|
||||||
|
@ -251,7 +251,7 @@ char *scan_graph(struct text_object *obj, const char *args, double defscale)
|
|||||||
* Printing various special text objects
|
* Printing various special text objects
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct special_t *new_special(char *buf, enum special_types t)
|
struct special_t *new_special(char *buf, enum special_types t)
|
||||||
{
|
{
|
||||||
if (special_count >= max_specials) {
|
if (special_count >= max_specials) {
|
||||||
CRIT_ERR(NULL, NULL, "too many special things in text");
|
CRIT_ERR(NULL, NULL, "too many special things in text");
|
||||||
@ -472,10 +472,10 @@ void new_fg(struct text_object *obj, char *p, int p_max_size)
|
|||||||
if (output_methods & TO_X)
|
if (output_methods & TO_X)
|
||||||
new_special(p, FG)->arg = obj->data.l;
|
new_special(p, FG)->arg = obj->data.l;
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
#ifdef NCURSES
|
#ifdef BUILD_NCURSES
|
||||||
if (output_methods & TO_NCURSES)
|
if (output_methods & TO_NCURSES)
|
||||||
new_special(p, FG)->arg = obj->data.l;
|
new_special(p, FG)->arg = obj->data.l;
|
||||||
#endif /* NCURSES */
|
#endif /* BUILD_NCURSES */
|
||||||
UNUSED(obj);
|
UNUSED(obj);
|
||||||
UNUSED(p);
|
UNUSED(p);
|
||||||
UNUSED(p_max_size);
|
UNUSED(p_max_size);
|
||||||
|
@ -121,4 +121,6 @@ void new_alignc(struct text_object *, char *, int);
|
|||||||
void new_goto(struct text_object *, char *, int);
|
void new_goto(struct text_object *, char *, int);
|
||||||
void new_tab(struct text_object *, char *, int);
|
void new_tab(struct text_object *, char *, int);
|
||||||
|
|
||||||
|
struct special_t *new_special(char *buf, enum special_types t);
|
||||||
|
|
||||||
#endif /* _SPECIALS_H */
|
#endif /* _SPECIALS_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user