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:
parent
945b52b9a6
commit
e70df5e477
56
src/llua.cc
56
src/llua.cc
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user