mirror of https://github.com/rusefi/lua.git
'%' must be '%%' to avoid formatting problems
This commit is contained in:
parent
beb2aa5a46
commit
24434b59f7
10
lstrlib.c
10
lstrlib.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: lstrlib.c,v 1.99 2003/05/14 14:35:54 roberto Exp roberto $
|
** $Id: lstrlib.c,v 1.100 2003/10/07 20:13:41 roberto Exp roberto $
|
||||||
** Standard library for string operations and pattern-matching
|
** Standard library for string operations and pattern-matching
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -200,7 +200,7 @@ static const char *luaI_classend (MatchState *ms, const char *p) {
|
||||||
switch (*p++) {
|
switch (*p++) {
|
||||||
case ESC: {
|
case ESC: {
|
||||||
if (*p == '\0')
|
if (*p == '\0')
|
||||||
luaL_error(ms->L, "malformed pattern (ends with `%')");
|
luaL_error(ms->L, "malformed pattern (ends with `%%')");
|
||||||
return p+1;
|
return p+1;
|
||||||
}
|
}
|
||||||
case '[': {
|
case '[': {
|
||||||
|
@ -682,7 +682,7 @@ static const char *scanformat (lua_State *L, const char *strfrmt,
|
||||||
luaL_error(L, "invalid format (width or precision too long)");
|
luaL_error(L, "invalid format (width or precision too long)");
|
||||||
if (p-strfrmt+2 > MAX_FORMAT) /* +2 to include `%' and the specifier */
|
if (p-strfrmt+2 > MAX_FORMAT) /* +2 to include `%' and the specifier */
|
||||||
luaL_error(L, "invalid format (too long)");
|
luaL_error(L, "invalid format (too long)");
|
||||||
form[0] = '%';
|
form[0] = ESC;
|
||||||
strncpy(form+1, strfrmt, p-strfrmt+1);
|
strncpy(form+1, strfrmt, p-strfrmt+1);
|
||||||
form[p-strfrmt+2] = 0;
|
form[p-strfrmt+2] = 0;
|
||||||
return p;
|
return p;
|
||||||
|
@ -697,9 +697,9 @@ static int str_format (lua_State *L) {
|
||||||
luaL_Buffer b;
|
luaL_Buffer b;
|
||||||
luaL_buffinit(L, &b);
|
luaL_buffinit(L, &b);
|
||||||
while (strfrmt < strfrmt_end) {
|
while (strfrmt < strfrmt_end) {
|
||||||
if (*strfrmt != '%')
|
if (*strfrmt != ESC)
|
||||||
luaL_putchar(&b, *strfrmt++);
|
luaL_putchar(&b, *strfrmt++);
|
||||||
else if (*++strfrmt == '%')
|
else if (*++strfrmt == ESC)
|
||||||
luaL_putchar(&b, *strfrmt++); /* %% */
|
luaL_putchar(&b, *strfrmt++); /* %% */
|
||||||
else { /* format item */
|
else { /* format item */
|
||||||
char form[MAX_FORMAT]; /* to store the format (`%...') */
|
char form[MAX_FORMAT]; /* to store the format (`%...') */
|
||||||
|
|
Loading…
Reference in New Issue