1
0
mirror of https://github.com/Llewellynvdm/conky.git synced 2025-01-14 19:39:47 +00:00

Merge branch 'master' into lua-config

Conflicts:
	src/conky.cc
This commit is contained in:
Pavel Labath 2010-03-04 18:23:46 +01:00
commit 70d53b770f
8 changed files with 73 additions and 87 deletions

View File

@ -99,31 +99,23 @@ double get_time(void)
return tv.tv_sec + (tv.tv_usec / 1000000.0);
}
/* Converts '~/...' paths to '/home/blah/...' assumes that 'dest' is at least
* DEFAULT_TEXT_BUFFER_SIZE. It's similar to variable_substitute, except only
* cheques for $HOME and ~/ in path */
void to_real_path(char *dest, const char *source)
/* Converts '~/...' paths to '/home/blah/...'
* It's similar to variable_substitute, except only cheques for $HOME and ~/ in path */
std::string to_real_path(const std::string &source)
{
char tmp[DEFAULT_TEXT_BUFFER_SIZE];
if (sscanf(source, "~/%s", tmp) || sscanf(source, "$HOME/%s", tmp)) {
char *homedir = getenv("HOME");
if (homedir) {
snprintf(dest, DEFAULT_TEXT_BUFFER_SIZE, "%s/%s", homedir, tmp);
} else {
NORM_ERR("$HOME environment variable doesn't exist");
strncpy(dest, source, DEFAULT_TEXT_BUFFER_SIZE);
}
} else if (dest != source) { //see changelog 2009-06-29 if you doubt that this check is necessary
strncpy(dest, source, DEFAULT_TEXT_BUFFER_SIZE);
}
const char *homedir = getenv("HOME");
if(source.find("~/") == 0)
return homedir + source.substr(1);
else if(source.find("$HOME/") == 0)
return homedir + source.substr(5);
else
return source;
}
int open_fifo(const char *file, int *reported)
{
char path[DEFAULT_TEXT_BUFFER_SIZE];
int fd = 0;
to_real_path(path, file);
fd = open(file, O_RDONLY | O_NONBLOCK);
if (fd == -1) {
@ -141,10 +133,8 @@ int open_fifo(const char *file, int *reported)
FILE *open_file(const char *file, int *reported)
{
char path[DEFAULT_TEXT_BUFFER_SIZE];
FILE *fp = 0;
to_real_path(path, file);
fp = fopen(file, "r");
if (!fp) {
@ -282,7 +272,7 @@ struct update_cb {
static struct update_cb update_cb_head;
static void *run_update_callback(void *) __attribute__((noreturn));
static void *run_update_callback(void *);
static int threading_started = 0;
@ -373,13 +363,13 @@ static void *run_update_callback(void *data)
{
struct update_cb *ucb = static_cast<struct update_cb *>(data);
if (!ucb || !ucb->func) pthread_exit(NULL);
if (!ucb || !ucb->func) return(NULL);
while (1) {
if (sem_wait(&ucb->start_wait)) pthread_exit(NULL);
if (ucb->running == 0) pthread_exit(NULL);
if (sem_wait(&ucb->start_wait)) return(NULL);
if (ucb->running == 0) return(NULL);
(*ucb->func)();
if (sem_post(&ucb->end_wait)) pthread_exit(NULL);
if (sem_post(&ucb->end_wait)) return(NULL);
}
}

View File

@ -28,6 +28,7 @@
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <string.h>
#include <sys/socket.h>
#include "text_object.h"
@ -60,10 +61,9 @@ struct process *get_first_process(void);
void get_cpu_count(void);
double get_time(void);
/* Converts '~/...' paths to '/home/blah/...' assumes that 'dest' is at least
* DEFAULT_TEXT_BUFFER_SIZE. It's similar to variable_substitute, except only
* cheques for $HOME and ~/ in path */
void to_real_path(char *dest, const char *source);
/* Converts '~/...' paths to '/home/blah/...'
* It's similar to variable_substitute, except only cheques for $HOME and ~/ in path */
std::string to_real_path(const std::string &source);
FILE *open_file(const char *file, int *reported);
int open_fifo(const char *file, int *reported);
void variable_substitute(const char *s, char *dest, unsigned int n);

View File

@ -318,7 +318,7 @@ static char *disp = NULL;
struct information info;
/* path to config file */
char *current_config;
std::string current_config;
/* set to 1 if you want all text to be in uppercase */
static unsigned int stuff_in_uppercase;
@ -2264,12 +2264,14 @@ static void main_loop(void)
break;
}
#ifdef HAVE_SYS_INOTIFY_H
if (!disable_auto_reload && inotify_fd != -1 && inotify_config_wd == -1 && current_config != 0) {
if (!disable_auto_reload && inotify_fd != -1
&& inotify_config_wd == -1 && !current_config.empty()) {
inotify_config_wd = inotify_add_watch(inotify_fd,
current_config,
current_config.c_str(),
IN_MODIFY);
}
if (!disable_auto_reload && inotify_fd != -1 && inotify_config_wd != -1 && current_config != 0) {
if (!disable_auto_reload && inotify_fd != -1
&& inotify_config_wd != -1 && !current_config.empty()) {
int len = 0, idx = 0;
fd_set descriptors;
struct timeval time_to_wait;
@ -2287,13 +2289,13 @@ static void main_loop(void)
struct inotify_event *ev = (struct inotify_event *) &inotify_buff[idx];
if (ev->wd == inotify_config_wd && (ev->mask & IN_MODIFY || ev->mask & IN_IGNORED)) {
/* current_config should be reloaded */
NORM_ERR("'%s' modified, reloading...", current_config);
NORM_ERR("'%s' modified, reloading...", current_config.c_str());
reload_config();
if (ev->mask & IN_IGNORED) {
/* for some reason we get IN_IGNORED here
* sometimes, so we need to re-add the watch */
inotify_config_wd = inotify_add_watch(inotify_fd,
current_config,
current_config.c_str(),
IN_MODIFY);
}
break;
@ -2337,10 +2339,8 @@ void initialisation(int argc, char** argv);
/* reload the config file */
static void reload_config(void)
{
char *current_config_copy = strdup(current_config);
clean_up(NULL, NULL);
sleep(1); /* slight pause */
current_config = current_config_copy;
initialisation(argc_copy, argv_copy);
}
@ -2404,7 +2404,6 @@ void clean_up(void *memtofree1, void* memtofree2)
free_and_zero(tmpstring2);
free_and_zero(text_buffer);
free_and_zero(global_text);
free_and_zero(current_config);
#ifdef BUILD_PORT_MONITORS
tcp_portmon_clear();
@ -3734,40 +3733,39 @@ static const struct option longopts[] = {
void set_current_config() {
/* check if specified config file is valid */
if (current_config) {
if (not current_config.empty()) {
struct stat sb;
if (stat(current_config, &sb) ||
if (stat(current_config.c_str(), &sb) ||
(!S_ISREG(sb.st_mode) && !S_ISLNK(sb.st_mode))) {
NORM_ERR("invalid configuration file '%s'\n", current_config);
free_and_zero(current_config);
NORM_ERR("invalid configuration file '%s'\n", current_config.c_str());
current_config.clear();
}
}
/* load current_config, CONFIG_FILE or SYSTEM_CONFIG_FILE */
if (!current_config) {
if (current_config.empty()) {
/* load default config file */
char buf[DEFAULT_TEXT_BUFFER_SIZE];
FILE *fp;
/* Try to use personal config file first */
to_real_path(buf, CONFIG_FILE);
if (buf[0] && (fp = fopen(buf, "r"))) {
current_config = strndup(buf, max_user_text);
std::string buf = to_real_path(CONFIG_FILE);
if (!buf.empty() && (fp = fopen(buf.c_str(), "r"))) {
current_config = buf;
fclose(fp);
}
/* Try to use system config file if personal config not readable */
if (!current_config && (fp = fopen(SYSTEM_CONFIG_FILE, "r"))) {
current_config = strndup(SYSTEM_CONFIG_FILE, max_user_text);
if (current_config.empty() && (fp = fopen(SYSTEM_CONFIG_FILE, "r"))) {
current_config = SYSTEM_CONFIG_FILE;
fclose(fp);
}
/* No readable config found */
if (!current_config) {
if (current_config.empty()) {
#define NOCFGFILEFOUND "no readable personal or system-wide config file found"
#ifdef BUILD_BUILTIN_CONFIG
current_config = strdup("==builtin==");
current_config = "==builtin==";
NORM_ERR(NOCFGFILEFOUND
", using builtin default");
#else
@ -3800,8 +3798,8 @@ void initialisation(int argc, char **argv) {
}
if(for_scripts == false) {
set_current_config();
load_config_file(current_config);
currentconffile = conftree_add(currentconffile, current_config);
load_config_file(current_config.c_str());
currentconffile = conftree_add(currentconffile, current_config.c_str());
}
/* init specials array */
@ -3907,7 +3905,7 @@ void initialisation(int argc, char **argv) {
#ifdef BUILD_X11
/* load font */
if (out_to_x.get(*state)) {
load_config_file_x11(current_config);
load_config_file_x11(current_config.c_str());
}
#endif /* BUILD_X11 */
@ -4002,7 +4000,6 @@ int main(int argc, char **argv)
argv_copy = argv;
g_signal_pending = 0;
max_user_text = MAX_USER_TEXT_DEFAULT;
current_config = 0;
memset(&info, 0, sizeof(info));
free_templates();
clear_net_stats();
@ -4036,8 +4033,7 @@ int main(int argc, char **argv)
case 'V':
print_version(); /* doesn't return */
case 'c':
free_and_zero(current_config);
current_config = strndup(optarg, max_user_text);
current_config = optarg;
break;
case 'q':
if (!freopen("/dev/null", "w", stderr))
@ -4129,7 +4125,6 @@ int main(int argc, char **argv)
std::cerr << "caught exception: " << e.what() << std::endl;
}
#endif
free(current_config);
return 0;
//////////// XXX ////////////////////////////////

View File

@ -324,7 +324,7 @@ void human_readable(long long, char *, int);
extern unsigned int max_user_text;
/* path to config file */
extern char *current_config;
extern std::string current_config;
#define TO_STDOUT 2
#define TO_STDERR 4

View File

@ -129,7 +129,9 @@ void cimlib_add_image(const char *args)
free(cur);
return;
}
to_real_path(cur->name, cur->name);
strncpy(cur->name, to_real_path(cur->name).c_str(), 1024);
cur->name[1023] = 0;
//
// now we check for optional args
tmp = strstr(args, "-p ");
if (tmp) {

View File

@ -120,7 +120,7 @@ void llua_init(void)
lua_pushstring(lua_L, BUILD_ARCH);
lua_setglobal(lua_L, "conky_build_arch");
lua_pushstring(lua_L, current_config);
lua_pushstring(lua_L, current_config.c_str());
lua_setglobal(lua_L, "conky_config");
lua_pushcfunction(lua_L, &llua_conky_parse);
@ -141,18 +141,17 @@ void llua_init(void)
void llua_load(const char *script)
{
int error;
char path[DEFAULT_TEXT_BUFFER_SIZE];
llua_init();
to_real_path(path, script);
error = luaL_dofile(lua_L, path);
std::string path = to_real_path(script);
error = luaL_dofile(lua_L, path.c_str());
if (error) {
NORM_ERR("llua_load: %s", lua_tostring(lua_L, -1));
lua_pop(lua_L, 1);
#ifdef HAVE_SYS_INOTIFY_H
} else if (!llua_block_notify && inotify_fd != -1) {
llua_append_notify(path);
llua_append_notify(path.c_str());
#endif /* HAVE_SYS_INOTIFY_H */
}
}

View File

@ -44,11 +44,18 @@
struct headtail {
int wantedlines;
char *logfile;
std::string logfile;
char *buffer;
int current_use;
int max_uses;
int reported;
headtail()
: wantedlines(0), buffer(NULL), current_use(0), max_uses(0), reported(0)
{}
~headtail()
{ free(buffer); }
};
static void tailstring(char *string, int endofstring, int wantedlines) {
@ -73,26 +80,21 @@ static void tailstring(char *string, int endofstring, int wantedlines) {
void free_tailhead(struct text_object *obj)
{
struct headtail *ht = (struct headtail *)obj->data.opaque;
if (!ht)
return;
free_and_zero(ht->logfile);
free_and_zero(ht->buffer);
free_and_zero(obj->data.opaque);
obj->data.opaque = NULL;
delete ht;
}
void init_tailhead(const char* type, const char* arg, struct text_object *obj, void* free_at_crash) {
unsigned int args;
struct headtail *ht;
struct headtail *ht = new headtail;
ht = (struct headtail *)malloc(sizeof(struct headtail));
memset(ht, 0, sizeof(struct headtail));
ht->logfile = (char*)malloc(DEFAULT_TEXT_BUFFER_SIZE);
memset(ht->logfile, 0, DEFAULT_TEXT_BUFFER_SIZE);
std::unique_ptr<char []> tmp(new char[DEFAULT_TEXT_BUFFER_SIZE]);
memset(tmp.get(), 0, DEFAULT_TEXT_BUFFER_SIZE);
ht->max_uses = DEFAULT_MAX_HEADTAIL_USES;
args = sscanf(arg, "%s %d %d", ht->logfile, &ht->wantedlines, &ht->max_uses);
// XXX: Buffer overflow ?
args = sscanf(arg, "%s %d %d", tmp.get(), &ht->wantedlines, &ht->max_uses);
if (args < 2 || args > 3) {
free_tailhead(obj);
CRIT_ERR(obj, free_at_crash, "%s needs a file as 1st and a number of lines as 2nd argument", type);
@ -102,7 +104,7 @@ void init_tailhead(const char* type, const char* arg, struct text_object *obj, v
CRIT_ERR(obj, free_at_crash, "invalid arg for %s, next_check must be larger than 0", type);
}
if (ht->wantedlines > 0 && ht->wantedlines <= MAX_HEADTAIL_LINES) {
to_real_path(ht->logfile, ht->logfile);
ht->logfile = to_real_path(tmp.get());
ht->buffer = NULL;
ht->current_use = 0;
} else {
@ -131,9 +133,9 @@ static void print_tailhead(const char* type, struct text_object *obj, char *p, i
strcpy(p, ht->buffer);
ht->current_use++;
}else{ //otherwise find the needed data
if(stat(ht->logfile, &st) == 0) {
if(stat(ht->logfile.c_str(), &st) == 0) {
if (S_ISFIFO(st.st_mode)) {
fd = open_fifo(ht->logfile, &ht->reported);
fd = open_fifo(ht->logfile.c_str(), &ht->reported);
if(fd != -1) {
if(strcmp(type, "head") == 0) {
for(i = 0; linescounted < ht->wantedlines; i++) {
@ -153,7 +155,7 @@ static void print_tailhead(const char* type, struct text_object *obj, char *p, i
}
close(fd);
} else {
fp = open_file(ht->logfile, &ht->reported);
fp = open_file(ht->logfile.c_str(), &ht->reported);
if(fp != NULL) {
if(strcmp(type, "head") == 0) {
for(i = 0; i < ht->wantedlines; i++) {
@ -173,7 +175,7 @@ static void print_tailhead(const char* type, struct text_object *obj, char *p, i
}
ht->buffer = strdup(p);
} else {
CRIT_ERR(NULL, NULL, "$%s can't find information about %s", type, ht->logfile);
CRIT_ERR(NULL, NULL, "$%s can't find information about %s", type, ht->logfile.c_str());
}
}
return;

View File

@ -882,10 +882,9 @@ void load_xoap_keys(void)
FILE *fp;
char *par = (char *) malloc(11 * sizeof(char));
char *key = (char *) malloc(17 * sizeof(char));
char *xoap = (char *) malloc(64 * sizeof(char));
to_real_path(xoap, XOAP_FILE);
fp = fopen(xoap, "r");
std::string xoap = to_real_path(XOAP_FILE);
fp = fopen(xoap.c_str(), "r");
if (fp != NULL) {
if (fscanf(fp, "%10s %16s", par, key) == 2) {
xoap_cc = std::string("?cc=*&link=xoap&prod=xoap&par=")
@ -899,7 +898,6 @@ void load_xoap_keys(void)
}
free(par);
free(key);
free(xoap);
}
void scan_weather_forecast_arg(struct text_object *obj, const char *arg, void *free_at_crash)