mirror of https://github.com/rusefi/lua.git
in case of memory allocation errors, sizecode and sizelineinfo can
be different
This commit is contained in:
parent
669129a6d8
commit
c196348717
8
lcode.c
8
lcode.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: lcode.c,v 1.110 2002/08/20 20:03:05 roberto Exp roberto $
|
** $Id: lcode.c,v 1.111 2002/08/21 18:56:33 roberto Exp roberto $
|
||||||
** Code generator for Lua
|
** Code generator for Lua
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -686,14 +686,14 @@ void luaK_fixline (FuncState *fs, int line) {
|
||||||
|
|
||||||
int luaK_code (FuncState *fs, Instruction i, int line) {
|
int luaK_code (FuncState *fs, Instruction i, int line) {
|
||||||
Proto *f = fs->f;
|
Proto *f = fs->f;
|
||||||
int oldsize = f->sizecode;
|
|
||||||
luaK_dischargejpc(fs); /* `pc' will change */
|
luaK_dischargejpc(fs); /* `pc' will change */
|
||||||
/* put new instruction in code array */
|
/* put new instruction in code array */
|
||||||
luaM_growvector(fs->L, f->code, fs->pc, f->sizecode, Instruction,
|
luaM_growvector(fs->L, f->code, fs->pc, f->sizecode, Instruction,
|
||||||
MAX_INT, "code size overflow");
|
MAX_INT, "code size overflow");
|
||||||
f->code[fs->pc] = i;
|
f->code[fs->pc] = i;
|
||||||
if (f->sizecode != oldsize)
|
/* save corresponding line information */
|
||||||
luaM_reallocvector(fs->L, f->lineinfo, oldsize, f->sizecode, int);
|
luaM_growvector(fs->L, f->lineinfo, fs->pc, f->sizelineinfo, int,
|
||||||
|
MAX_INT, "code size overflow");
|
||||||
f->lineinfo[fs->pc] = line;
|
f->lineinfo[fs->pc] = line;
|
||||||
return fs->pc++;
|
return fs->pc++;
|
||||||
}
|
}
|
||||||
|
|
3
ldebug.c
3
ldebug.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: ldebug.c,v 1.133 2002/08/20 20:03:05 roberto Exp roberto $
|
** $Id: ldebug.c,v 1.134 2002/09/05 19:45:42 roberto Exp roberto $
|
||||||
** Debug Interface
|
** Debug Interface
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -248,6 +248,7 @@ LUA_API int lua_getinfo (lua_State *L, const char *what, lua_Debug *ar) {
|
||||||
|
|
||||||
static int precheck (const Proto *pt) {
|
static int precheck (const Proto *pt) {
|
||||||
check(pt->maxstacksize <= MAXSTACK);
|
check(pt->maxstacksize <= MAXSTACK);
|
||||||
|
check(pt->sizelineinfo == pt->sizecode || pt->sizelineinfo == 0);
|
||||||
lua_assert(pt->numparams+pt->is_vararg <= pt->maxstacksize);
|
lua_assert(pt->numparams+pt->is_vararg <= pt->maxstacksize);
|
||||||
check(GET_OPCODE(pt->code[pt->sizecode-1]) == OP_RETURN);
|
check(GET_OPCODE(pt->code[pt->sizecode-1]) == OP_RETURN);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
6
lfunc.c
6
lfunc.c
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: lfunc.c,v 1.58 2002/08/16 14:45:55 roberto Exp roberto $
|
** $Id: lfunc.c,v 1.59 2002/08/30 19:09:21 roberto Exp roberto $
|
||||||
** Auxiliary functions to manipulate prototypes and closures
|
** Auxiliary functions to manipulate prototypes and closures
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -80,6 +80,7 @@ Proto *luaF_newproto (lua_State *L) {
|
||||||
f->sizep = 0;
|
f->sizep = 0;
|
||||||
f->code = NULL;
|
f->code = NULL;
|
||||||
f->sizecode = 0;
|
f->sizecode = 0;
|
||||||
|
f->sizelineinfo = 0;
|
||||||
f->nupvalues = 0;
|
f->nupvalues = 0;
|
||||||
f->numparams = 0;
|
f->numparams = 0;
|
||||||
f->is_vararg = 0;
|
f->is_vararg = 0;
|
||||||
|
@ -95,8 +96,7 @@ Proto *luaF_newproto (lua_State *L) {
|
||||||
|
|
||||||
void luaF_freeproto (lua_State *L, Proto *f) {
|
void luaF_freeproto (lua_State *L, Proto *f) {
|
||||||
luaM_freearray(L, f->code, f->sizecode, Instruction);
|
luaM_freearray(L, f->code, f->sizecode, Instruction);
|
||||||
if (f->lineinfo)
|
luaM_freearray(L, f->lineinfo, f->sizelineinfo, int);
|
||||||
luaM_freearray(L, f->lineinfo, f->sizecode, int);
|
|
||||||
luaM_freearray(L, f->locvars, f->sizelocvars, struct LocVar);
|
luaM_freearray(L, f->locvars, f->sizelocvars, struct LocVar);
|
||||||
luaM_freearray(L, f->k, f->sizek, TObject);
|
luaM_freearray(L, f->k, f->sizek, TObject);
|
||||||
luaM_freearray(L, f->p, f->sizep, Proto *);
|
luaM_freearray(L, f->p, f->sizep, Proto *);
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: lobject.h,v 1.146 2002/09/19 13:03:53 roberto Exp roberto $
|
** $Id: lobject.h,v 1.147 2002/10/08 18:46:08 roberto Exp roberto $
|
||||||
** Type definitions for Lua objects
|
** Type definitions for Lua objects
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -186,6 +186,7 @@ typedef struct Proto {
|
||||||
TString *source;
|
TString *source;
|
||||||
int sizek; /* size of `k' */
|
int sizek; /* size of `k' */
|
||||||
int sizecode;
|
int sizecode;
|
||||||
|
int sizelineinfo;
|
||||||
int sizep; /* size of `p' */
|
int sizep; /* size of `p' */
|
||||||
int sizelocvars;
|
int sizelocvars;
|
||||||
int lineDefined;
|
int lineDefined;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
** $Id: lparser.c,v 1.194 2002/08/30 19:09:21 roberto Exp roberto $
|
** $Id: lparser.c,v 1.195 2002/10/08 18:46:08 roberto Exp roberto $
|
||||||
** Lua Parser
|
** Lua Parser
|
||||||
** See Copyright Notice in lua.h
|
** See Copyright Notice in lua.h
|
||||||
*/
|
*/
|
||||||
|
@ -337,8 +337,9 @@ static void close_func (LexState *ls) {
|
||||||
removevars(ls, 0);
|
removevars(ls, 0);
|
||||||
luaK_codeABC(fs, OP_RETURN, 0, 1, 0); /* final return */
|
luaK_codeABC(fs, OP_RETURN, 0, 1, 0); /* final return */
|
||||||
luaM_reallocvector(L, f->code, f->sizecode, fs->pc, Instruction);
|
luaM_reallocvector(L, f->code, f->sizecode, fs->pc, Instruction);
|
||||||
luaM_reallocvector(L, f->lineinfo, f->sizecode, fs->pc, int);
|
|
||||||
f->sizecode = fs->pc;
|
f->sizecode = fs->pc;
|
||||||
|
luaM_reallocvector(L, f->lineinfo, f->sizelineinfo, fs->pc, int);
|
||||||
|
f->sizelineinfo = fs->pc;
|
||||||
luaM_reallocvector(L, f->k, f->sizek, fs->nk, TObject);
|
luaM_reallocvector(L, f->k, f->sizek, fs->nk, TObject);
|
||||||
f->sizek = fs->nk;
|
f->sizek = fs->nk;
|
||||||
luaM_reallocvector(L, f->p, f->sizep, fs->np, Proto *);
|
luaM_reallocvector(L, f->p, f->sizep, fs->np, Proto *);
|
||||||
|
|
Loading…
Reference in New Issue