mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-11 18:38:45 +00:00
getting set for 1.4.0
git-svn-id: https://conky.svn.sourceforge.net/svnroot/conky/trunk/conky@525 7f574dfc-610e-0410-a909-a81674777703
This commit is contained in:
parent
9d54a08e65
commit
a99f1c48e7
@ -3,6 +3,6 @@
|
|||||||
|
|
||||||
aclocal-1.9
|
aclocal-1.9
|
||||||
libtoolize --force
|
libtoolize --force
|
||||||
autoheader
|
autoheader-2.59
|
||||||
automake-1.9 -a
|
automake-1.9 -a
|
||||||
autoconf
|
autoconf-2.59
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
AC_INIT([Conky],[1.4.0_CVS_20060126],[brenden1@users.sourceforge.net])
|
AC_INIT([Conky],[1.4.0],[brenden1@users.sourceforge.net])
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE(conky, 1.4.0_CVS_20060126)
|
AM_INIT_AUTOMAKE(conky, 1.4.0)
|
||||||
AM_CONFIG_HEADER(src/config.h)
|
AM_CONFIG_HEADER(src/config.h)
|
||||||
AC_PROG_LIBTOOL
|
AC_PROG_LIBTOOL
|
||||||
PKG_PROG_PKG_CONFIG([0.17.2])
|
PKG_PROG_PKG_CONFIG([0.17.2])
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
.\" -*- coding: us-ascii -*-
|
.\" -*- coding: us-ascii -*-
|
||||||
.TH conky 1 2006-01-01
|
.TH conky 1 2006-02-12
|
||||||
.SH NAME
|
.SH NAME
|
||||||
conky \- A system monitor for X originally based on the torsmo code, but more kickass. It just keeps on given'er. Yeah.
|
conky \- A system monitor for X originally based on the torsmo code, but more kickass. It just keeps on given'er. Yeah.
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
<firstname>Brenden</firstname>
|
<firstname>Brenden</firstname>
|
||||||
<surname>Matthews</surname>
|
<surname>Matthews</surname>
|
||||||
</author>
|
</author>
|
||||||
<date>2006-01-01</date>
|
<date>2006-02-12</date>
|
||||||
</refentryinfo>
|
</refentryinfo>
|
||||||
|
|
||||||
<refmeta>
|
<refmeta>
|
||||||
|
73
src/conky.c
73
src/conky.c
@ -407,7 +407,7 @@ static int special_index; /* used when drawing */
|
|||||||
|
|
||||||
static struct special_t *new_special(char *buf, int t)
|
static struct special_t *new_special(char *buf, int t)
|
||||||
{
|
{
|
||||||
if (special_count >= 256)
|
if (special_count >= 512)
|
||||||
CRIT_ERR("too many special things in text");
|
CRIT_ERR("too many special things in text");
|
||||||
|
|
||||||
buf[0] = SPECIAL_CHAR;
|
buf[0] = SPECIAL_CHAR;
|
||||||
@ -921,7 +921,6 @@ enum text_object_type {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct thread_info_s {
|
struct thread_info_s {
|
||||||
pthread_mutex_t mutex;
|
|
||||||
pthread_t thread;
|
pthread_t thread;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1009,6 +1008,7 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
|
|||||||
typedef struct thread_info_s *thread_info;
|
typedef struct thread_info_s *thread_info;
|
||||||
static thread_info thread_list[MAX_THREADS];
|
static thread_info thread_list[MAX_THREADS];
|
||||||
static int thread_count = 0;
|
static int thread_count = 0;
|
||||||
|
static int threads_runnable = 1;
|
||||||
|
|
||||||
int register_thread(struct thread_info_s *new_thread)
|
int register_thread(struct thread_info_s *new_thread)
|
||||||
{
|
{
|
||||||
@ -1021,24 +1021,6 @@ int register_thread(struct thread_info_s *new_thread)
|
|||||||
return thread_count - 1;
|
return thread_count - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void lock_all_threads()
|
|
||||||
{
|
|
||||||
if (thread_count) {
|
|
||||||
ERR("trying to end all threads");
|
|
||||||
int i, ret;
|
|
||||||
// now we wait to get the locks
|
|
||||||
for (i = 0; i < thread_count; i++) {
|
|
||||||
usleep(50);
|
|
||||||
ret = pthread_mutex_lock(&(thread_list[i]->mutex));
|
|
||||||
if (ret) {
|
|
||||||
ERR("giving up on thread %i", (int)thread_list[i]->thread);
|
|
||||||
} else {
|
|
||||||
ERR("locked %i of %i", i+1, thread_count);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void replace_thread(struct thread_info_s *new_thread, int pos) // this isn't even used anymore; oh wells
|
void replace_thread(struct thread_info_s *new_thread, int pos) // this isn't even used anymore; oh wells
|
||||||
{
|
{
|
||||||
if (pos >= 0 && pos < MAX_THREADS) {
|
if (pos >= 0 && pos < MAX_THREADS) {
|
||||||
@ -1050,39 +1032,25 @@ void replace_thread(struct thread_info_s *new_thread, int pos) // this isn't eve
|
|||||||
|
|
||||||
void *threaded_exec(struct text_object *obj) { // pthreads are really beginning to piss me off
|
void *threaded_exec(struct text_object *obj) { // pthreads are really beginning to piss me off
|
||||||
double update_time;
|
double update_time;
|
||||||
int unlock;
|
int run_code = threads_runnable;
|
||||||
while (1) {
|
while (threads_runnable == run_code) {
|
||||||
update_time = get_time();
|
update_time = get_time();
|
||||||
if (pthread_mutex_trylock(&(obj->data.execi.thread_info.mutex))) {
|
|
||||||
pthread_exit(NULL);
|
|
||||||
}
|
|
||||||
char *p2 = obj->data.execi.buffer;
|
char *p2 = obj->data.execi.buffer;
|
||||||
FILE *fp = popen(obj->data.execi.cmd,"r");
|
FILE *fp = popen(obj->data.execi.cmd,"r");
|
||||||
int n2 = fread(p2, 1, TEXT_BUFFER_SIZE, fp);
|
int n2 = fread(p2, 1, TEXT_BUFFER_SIZE, fp);
|
||||||
(void) pclose(fp);
|
(void) pclose(fp);
|
||||||
p2[n2] = '\0';
|
p2[n2] = '\0';
|
||||||
if (n2 && p2[n2 - 1] == '\n')
|
if (n2 && p2[n2 - 1] == '\n') {
|
||||||
p2[n2 - 1] = '\0';
|
p2[n2 - 1] = '\0';
|
||||||
|
}
|
||||||
while (*p2) {
|
while (*p2) {
|
||||||
if (*p2 == '\001')
|
if (*p2 == '\001') {
|
||||||
*p2 = ' ';
|
*p2 = ' ';
|
||||||
|
}
|
||||||
p2++;
|
p2++;
|
||||||
}
|
}
|
||||||
obj->data.execi.last_update = update_time;
|
obj->data.execi.last_update = update_time;
|
||||||
unlock = pthread_mutex_unlock(&(obj->data.execi.thread_info.mutex));
|
|
||||||
if (unlock) {
|
|
||||||
ERR("error %i unlocking thread", unlock);
|
|
||||||
pthread_exit(NULL);
|
|
||||||
}
|
|
||||||
usleep(100); // prevent race condition
|
usleep(100); // prevent race condition
|
||||||
if (pthread_mutex_trylock(&(obj->data.execi.thread_info.mutex))) {
|
|
||||||
pthread_exit(NULL);
|
|
||||||
}
|
|
||||||
unlock = pthread_mutex_unlock(&(obj->data.execi.thread_info.mutex));
|
|
||||||
if (unlock) {
|
|
||||||
ERR("error %i unlocking thread", unlock);
|
|
||||||
pthread_exit(NULL);
|
|
||||||
}
|
|
||||||
if (get_time() - obj->data.execi.last_update > obj->data.execi.interval) {
|
if (get_time() - obj->data.execi.last_update > obj->data.execi.interval) {
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
@ -1093,7 +1061,9 @@ void *threaded_exec(struct text_object *obj) { // pthreads are really beginning
|
|||||||
usleep(delay);
|
usleep(delay);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
ERR("exiting thread");
|
||||||
pthread_exit(NULL);
|
pthread_exit(NULL);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct text_object *new_text_object_internal()
|
static struct text_object *new_text_object_internal()
|
||||||
@ -2237,7 +2207,6 @@ void parse_conky_vars(char * text, char * p, struct information *cur) {
|
|||||||
static void generate_text_internal(char *p, int p_max_size, struct text_object *objs, unsigned int object_count, struct information *cur)
|
static void generate_text_internal(char *p, int p_max_size, struct text_object *objs, unsigned int object_count, struct information *cur)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
for (i = 0; i < object_count; i++) {
|
for (i = 0; i < object_count; i++) {
|
||||||
struct text_object *obj = &objs[i];
|
struct text_object *obj = &objs[i];
|
||||||
|
|
||||||
@ -2660,14 +2629,10 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
|
|||||||
OBJ(texeci) {
|
OBJ(texeci) {
|
||||||
if (obj->data.execi.pos < 0) {
|
if (obj->data.execi.pos < 0) {
|
||||||
obj->data.execi.last_update = current_update_time;
|
obj->data.execi.last_update = current_update_time;
|
||||||
pthread_mutex_init(&(obj->data.execi.thread_info.mutex), NULL);
|
if (pthread_create(&(obj->data.execi.thread_info.thread), NULL, (void*)threaded_exec, (void*) obj)) {
|
||||||
if (!obj->data.execi.thread_info.thread && !pthread_mutex_trylock(&(obj->data.execi.thread_info.mutex))) {
|
ERR("Error starting thread");
|
||||||
if (pthread_create(&(obj->data.execi.thread_info.thread), NULL, (void*)threaded_exec, (void*) obj)) {
|
|
||||||
ERR("Error starting thread");
|
|
||||||
}
|
|
||||||
obj->data.execi.pos = register_thread(&(obj->data.execi.thread_info));
|
|
||||||
pthread_mutex_unlock(&(obj->data.execi.thread_info.mutex));
|
|
||||||
}
|
}
|
||||||
|
obj->data.execi.pos = register_thread(&(obj->data.execi.thread_info));
|
||||||
}
|
}
|
||||||
snprintf(p, p_max_size, "%s", obj->data.execi.buffer);
|
snprintf(p, p_max_size, "%s", obj->data.execi.buffer);
|
||||||
}
|
}
|
||||||
@ -4674,7 +4639,8 @@ static void load_config_file(const char *);
|
|||||||
/* reload the config file */
|
/* reload the config file */
|
||||||
void reload_config(void)
|
void reload_config(void)
|
||||||
{
|
{
|
||||||
lock_all_threads();
|
//lock_all_threads();
|
||||||
|
threads_runnable++;
|
||||||
#if defined(XMMS) || defined(BMP) || defined(AUDACIOUS) || defined(INFOPIPE)
|
#if defined(XMMS) || defined(BMP) || defined(AUDACIOUS) || defined(INFOPIPE)
|
||||||
if (info.xmms.thread) {
|
if (info.xmms.thread) {
|
||||||
if (destroy_xmms_thread()!=0)
|
if (destroy_xmms_thread()!=0)
|
||||||
@ -4716,7 +4682,8 @@ void reload_config(void)
|
|||||||
|
|
||||||
void clean_up(void)
|
void clean_up(void)
|
||||||
{
|
{
|
||||||
lock_all_threads();
|
//lock_all_threads();
|
||||||
|
threads_runnable++;
|
||||||
#ifdef X11
|
#ifdef X11
|
||||||
#ifdef XDBE
|
#ifdef XDBE
|
||||||
if (use_xdbe) {
|
if (use_xdbe) {
|
||||||
@ -5256,7 +5223,11 @@ else if (strcasecmp(name, a) == 0 || strcasecmp(name, b) == 0)
|
|||||||
set_transparent = string_to_bool(value);
|
set_transparent = string_to_bool(value);
|
||||||
}
|
}
|
||||||
CONF("own_window_colour") {
|
CONF("own_window_colour") {
|
||||||
background_colour = get_x11_color(value);
|
if (value) {
|
||||||
|
background_colour = get_x11_color(value);
|
||||||
|
} else {
|
||||||
|
ERR("Invalid colour for own_winder_colour (try omitting the '#' for hex colours");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
CONF("stippled_borders") {
|
CONF("stippled_borders") {
|
||||||
|
@ -49,7 +49,7 @@
|
|||||||
#define TOP_PID 3
|
#define TOP_PID 3
|
||||||
#define TOP_MEM 4
|
#define TOP_MEM 4
|
||||||
|
|
||||||
#define TEXT_BUFFER_SIZE 1024
|
#define TEXT_BUFFER_SIZE 1280
|
||||||
#define P_MAX_SIZE ((TEXT_BUFFER_SIZE * 4) - 2)
|
#define P_MAX_SIZE ((TEXT_BUFFER_SIZE * 4) - 2)
|
||||||
|
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
|
Loading…
Reference in New Issue
Block a user