mirror of
https://github.com/lua/lua
synced 2024-12-26 04:16:52 +03:00
more controled use of `sprintf'
This commit is contained in:
parent
2779ceeb12
commit
8b88ab07f7
27
lobject.c
27
lobject.c
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: lobject.c,v 1.53 2000/10/09 13:47:32 roberto Exp roberto $
|
** $Id: lobject.c,v 1.54 2000/10/10 19:53:20 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
|
||||||
*/
|
*/
|
||||||
@ -76,10 +76,13 @@ int luaO_str2d (const char *s, Number *result) { /* LUA_NUMBER */
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* maximum length of a string format for `luaO_verror' */
|
||||||
|
#define MAX_VERROR 280
|
||||||
|
|
||||||
/* this function needs to handle only '%d' and '%.XXs' formats */
|
/* this function needs to handle only '%d' and '%.XXs' formats */
|
||||||
void luaO_verror (lua_State *L, const char *fmt, ...) {
|
void luaO_verror (lua_State *L, const char *fmt, ...) {
|
||||||
va_list argp;
|
va_list argp;
|
||||||
char buff[600]; /* to hold formatted message */
|
char buff[MAX_VERROR]; /* to hold formatted message */
|
||||||
va_start(argp, fmt);
|
va_start(argp, fmt);
|
||||||
vsprintf(buff, fmt, argp);
|
vsprintf(buff, fmt, argp);
|
||||||
va_end(argp);
|
va_end(argp);
|
||||||
@ -88,8 +91,10 @@ void luaO_verror (lua_State *L, const char *fmt, ...) {
|
|||||||
|
|
||||||
|
|
||||||
void luaO_chunkid (char *out, const char *source, int bufflen) {
|
void luaO_chunkid (char *out, const char *source, int bufflen) {
|
||||||
if (*source == '=')
|
if (*source == '=') {
|
||||||
sprintf(out, "%.*s", bufflen-1, source+1); /* remove first char */
|
strncpy(out, source+1, bufflen); /* remove first char */
|
||||||
|
out[bufflen-1] = '\0'; /* ensures null termination */
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
if (*source == '@') {
|
if (*source == '@') {
|
||||||
int l;
|
int l;
|
||||||
@ -98,19 +103,23 @@ void luaO_chunkid (char *out, const char *source, int bufflen) {
|
|||||||
l = strlen(source);
|
l = strlen(source);
|
||||||
if (l>bufflen) {
|
if (l>bufflen) {
|
||||||
source += (l-bufflen); /* get last part of file name */
|
source += (l-bufflen); /* get last part of file name */
|
||||||
sprintf(out, "file `...%s'", source);
|
sprintf(out, "file `...%.99s'", source);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
sprintf(out, "file `%s'", source);
|
sprintf(out, "file `%.99s'", source);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
int len = strcspn(source, "\n"); /* stop at first newline */
|
int len = strcspn(source, "\n"); /* stop at first newline */
|
||||||
bufflen -= sizeof("string \"%.*s...\"");
|
bufflen -= sizeof("string \"%.*s...\"");
|
||||||
if (len > bufflen) len = bufflen;
|
if (len > bufflen) len = bufflen;
|
||||||
if (source[len] != '\0') /* must truncate? */
|
if (source[len] != '\0') { /* must truncate? */
|
||||||
sprintf(out, "string \"%.*s...\"", len, source);
|
strcpy(out, "string \"");
|
||||||
|
out += strlen(out);
|
||||||
|
strncpy(out, source, len);
|
||||||
|
strcpy(out+len, "...\"");
|
||||||
|
}
|
||||||
else
|
else
|
||||||
sprintf(out, "string \"%s\"", source);
|
sprintf(out, "string \"%.99s\"", source);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
8
lua.c
8
lua.c
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: lua.c,v 1.53 2000/10/09 15:46:43 roberto Exp roberto $
|
** $Id: lua.c,v 1.54 2000/10/17 13:36:24 roberto Exp roberto $
|
||||||
** Lua stand-alone interpreter
|
** Lua stand-alone interpreter
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
@ -115,7 +115,7 @@ static void print_message (void) {
|
|||||||
|
|
||||||
|
|
||||||
static void print_version (void) {
|
static void print_version (void) {
|
||||||
printf("%s %s\n", LUA_VERSION, LUA_COPYRIGHT);
|
printf("%.80s %.80s\n", LUA_VERSION, LUA_COPYRIGHT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -255,7 +255,7 @@ static int handle_argv (char *argv[], struct Options *opt) {
|
|||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
if (ldo(lua_dostring, argv[i]) != 0) {
|
if (ldo(lua_dostring, argv[i]) != 0) {
|
||||||
fprintf(stderr, "lua: error running argument `%s'\n", argv[i]);
|
fprintf(stderr, "lua: error running argument `%.99s'\n", argv[i]);
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -289,7 +289,7 @@ static void getstacksize (int argc, char *argv[], struct Options *opt) {
|
|||||||
if (argc >= 2 && argv[1][0] == '-' && argv[1][1] == 's') {
|
if (argc >= 2 && argv[1][0] == '-' && argv[1][1] == 's') {
|
||||||
int stacksize = atoi(&argv[1][2]);
|
int stacksize = atoi(&argv[1][2]);
|
||||||
if (stacksize <= 0) {
|
if (stacksize <= 0) {
|
||||||
fprintf(stderr, "lua: invalid stack size ('%s')\n", &argv[1][2]);
|
fprintf(stderr, "lua: invalid stack size ('%.20s')\n", &argv[1][2]);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
opt->stacksize = stacksize;
|
opt->stacksize = stacksize;
|
||||||
|
5
lzio.h
5
lzio.h
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
** $Id: lzio.h,v 1.5 1999/08/16 20:52:00 roberto Exp roberto $
|
** $Id: lzio.h,v 1.6 2000/05/24 13:54:49 roberto Exp roberto $
|
||||||
** Buffered streams
|
** Buffered streams
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
@ -33,9 +33,12 @@ size_t zread (ZIO* z, void* b, size_t n); /* read next n bytes */
|
|||||||
#define zname(z) ((z)->name)
|
#define zname(z) ((z)->name)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* --------- Private Part ------------------ */
|
/* --------- Private Part ------------------ */
|
||||||
|
|
||||||
|
#ifndef ZBSIZE
|
||||||
#define ZBSIZE 256 /* buffer size */
|
#define ZBSIZE 256 /* buffer size */
|
||||||
|
#endif
|
||||||
|
|
||||||
struct zio {
|
struct zio {
|
||||||
size_t n; /* bytes still unread */
|
size_t n; /* bytes still unread */
|
||||||
|
Loading…
Reference in New Issue
Block a user