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

Ignore spaces in {} when breaking up arguments to $lua

This commit is contained in:
Pavel Labath 2010-06-18 17:55:49 +02:00
parent 945b52b9a6
commit e70df5e477

View File

@ -42,6 +42,8 @@ void llua_rm_notifies(void);
static int llua_block_notify = 0; static int llua_block_notify = 0;
#endif /* HAVE_SYS_INOTIFY_H */ #endif /* HAVE_SYS_INOTIFY_H */
#define MIN(a, b) ( (a) < (b) ? (a) : (b) )
static char *draw_pre_hook = 0; static char *draw_pre_hook = 0;
static char *draw_post_hook = 0; static char *draw_post_hook = 0;
static char *startup_hook = 0; static char *startup_hook = 0;
@ -156,6 +158,34 @@ void llua_load(const char *script)
} }
} }
/*
* Returns the first space-delimited token of the string starting at position *len.
* On return *len contains the length of the token. Spaces inside brackets are ignored, so that
* eg. '${foo bar}' is treated as a single token. Sets *len to zero and *str points to the end of
* the string when there are no more tokens.
*/
static const char* tokenize(const char *str, size_t *len)
{
str += *len;
*len = 0;
while(str && isspace(*str))
++str;
size_t level = 0;
while(str[*len] && (level > 0 || !isspace(str[*len]))) {
switch(str[*len]) {
case '{': ++level; break;
case '}': --level; break;
}
++*len;
}
if(!str[*len] && level > 0)
NORM_ERR("tokenize: improperly nested token: %s", str);
return str;
}
/* /*
llua_do_call does a flexible call to any Lua function llua_do_call does a flexible call to any Lua function
string: <function> [par1] [par2...] string: <function> [par1] [par2...]
@ -166,35 +196,31 @@ static char *llua_do_call(const char *string, int retc)
static char func[64]; static char func[64];
int argc = 0; int argc = 0;
char *tmp = strdup(string); size_t len = 0;
char *ptr = strtok(tmp, " ");
const char *ptr = tokenize(string, &len);
/* proceed only if the function name is present */ /* proceed only if the function name is present */
if (!ptr) { if (!len) {
free(tmp);
return NULL; return NULL;
} }
/* call only conky_ prefixed functions */ /* call only conky_ prefixed functions */
if(strncmp(ptr, LUAPREFIX, strlen(LUAPREFIX)) == 0) { if(strncmp(ptr, LUAPREFIX, strlen(LUAPREFIX)) != 0) {
snprintf(func, 64, "%s", ptr); snprintf(func, sizeof func, "%s", LUAPREFIX);
}else{ } else
snprintf(func, 64, "%s%s", LUAPREFIX, ptr); *func = 0;
} strncat(func, ptr, MIN(len, sizeof(func) - strlen(func) - 1));
/* push the function name to stack */ /* push the function name to stack */
lua_getglobal(lua_L, func); lua_getglobal(lua_L, func);
/* parse all function parameters from args and push them to the stack */ /* parse all function parameters from args and push them to the stack */
ptr = strtok(NULL, " "); while( ptr = tokenize(ptr, &len), len) {
while (ptr) { lua_pushlstring(lua_L, ptr, len);
lua_pushstring(lua_L, ptr);
ptr = strtok(NULL, " ");
argc++; argc++;
} }
free(tmp);
if(lua_pcall(lua_L, argc, retc, 0) != 0) { if(lua_pcall(lua_L, argc, retc, 0) != 0) {
NORM_ERR("llua_do_call: function %s execution failed: %s", func, lua_tostring(lua_L, -1)); NORM_ERR("llua_do_call: function %s execution failed: %s", func, lua_tostring(lua_L, -1));
lua_pop(lua_L, -1); lua_pop(lua_L, -1);