small changes in 'luaO_pushvfstring'
This commit is contained in:
28
lobject.c
28
lobject.c
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: lobject.c,v 2.34 2009/11/26 11:39:20 roberto Exp roberto $
|
** $Id: lobject.c,v 2.35 2010/02/05 19:09:09 roberto Exp roberto $
|
||||||
** Some generic functions over Lua objects
|
** Some generic functions over Lua objects
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
@@ -116,16 +116,15 @@ int luaO_str2d (const char *s, lua_Number *result) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void pushstr (lua_State *L, const char *str) {
|
static void pushstr (lua_State *L, const char *str, size_t l) {
|
||||||
setsvalue2s(L, L->top, luaS_new(L, str));
|
setsvalue2s(L, L->top, luaS_newlstr(L, str, l));
|
||||||
incr_top(L);
|
incr_top(L);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* this function handles only `%d', `%c', %f, %p, and `%s' formats */
|
/* this function handles only `%d', `%c', %f, %p, and `%s' formats */
|
||||||
const char *luaO_pushvfstring (lua_State *L, const char *fmt, va_list argp) {
|
const char *luaO_pushvfstring (lua_State *L, const char *fmt, va_list argp) {
|
||||||
int n = 1;
|
int n = 0;
|
||||||
pushstr(L, "");
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
const char *e = strchr(fmt, '%');
|
const char *e = strchr(fmt, '%');
|
||||||
if (e == NULL) break;
|
if (e == NULL) break;
|
||||||
@@ -135,14 +134,13 @@ const char *luaO_pushvfstring (lua_State *L, const char *fmt, va_list argp) {
|
|||||||
case 's': {
|
case 's': {
|
||||||
const char *s = va_arg(argp, char *);
|
const char *s = va_arg(argp, char *);
|
||||||
if (s == NULL) s = "(null)";
|
if (s == NULL) s = "(null)";
|
||||||
pushstr(L, s);
|
pushstr(L, s, strlen(s));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'c': {
|
case 'c': {
|
||||||
char buff[2];
|
char buff;
|
||||||
buff[0] = cast(char, va_arg(argp, int));
|
buff = cast(char, va_arg(argp, int));
|
||||||
buff[1] = '\0';
|
pushstr(L, &buff, 1);
|
||||||
pushstr(L, buff);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'd': {
|
case 'd': {
|
||||||
@@ -157,12 +155,12 @@ const char *luaO_pushvfstring (lua_State *L, const char *fmt, va_list argp) {
|
|||||||
}
|
}
|
||||||
case 'p': {
|
case 'p': {
|
||||||
char buff[4*sizeof(void *) + 8]; /* should be enough space for a `%p' */
|
char buff[4*sizeof(void *) + 8]; /* should be enough space for a `%p' */
|
||||||
sprintf(buff, "%p", va_arg(argp, void *));
|
int l = sprintf(buff, "%p", va_arg(argp, void *));
|
||||||
pushstr(L, buff);
|
pushstr(L, buff, l);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case '%': {
|
case '%': {
|
||||||
pushstr(L, "%");
|
pushstr(L, "%", 1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
@@ -175,8 +173,8 @@ const char *luaO_pushvfstring (lua_State *L, const char *fmt, va_list argp) {
|
|||||||
n += 2;
|
n += 2;
|
||||||
fmt = e+2;
|
fmt = e+2;
|
||||||
}
|
}
|
||||||
pushstr(L, fmt);
|
pushstr(L, fmt, strlen(fmt));
|
||||||
luaV_concat(L, n+1);
|
if (n > 0) luaV_concat(L, n + 1);
|
||||||
return svalue(L->top - 1);
|
return svalue(L->top - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user