Browse Source

BUG: lua_newtag can be called before luaI_IMtable is initialized.

v5-2
Roberto Ierusalimschy 28 years ago
parent
commit
ae067dcddd
  1. 20
      fallback.c

20
fallback.c

@ -3,7 +3,7 @@
** TecCGraf - PUC-Rio
*/
char *rcs_fallback="$Id: fallback.c,v 1.29 1997/03/19 21:12:34 roberto Exp roberto $";
char *rcs_fallback="$Id: fallback.c,v 1.30 1997/03/20 19:20:43 roberto Exp roberto $";
#include <stdio.h>
#include <string.h>
@ -174,12 +174,14 @@ static void init_entry (int tag)
void luaI_initfallbacks (void)
{
int i;
IMtable_size = NUM_TYPES+10;
luaI_IMtable = newvector(IMtable_size, struct IM);
for (i=LUA_T_NIL; i<=LUA_T_USERDATA; i++) {
luaI_IMtable[-i].tp = (lua_Type)i;
init_entry(i);
if (luaI_IMtable == NULL) {
int i;
IMtable_size = NUM_TYPES+10;
luaI_IMtable = newvector(IMtable_size, struct IM);
for (i=LUA_T_NIL; i<=LUA_T_USERDATA; i++) {
luaI_IMtable[-i].tp = (lua_Type)i;
init_entry(i);
}
}
}
@ -187,9 +189,11 @@ int lua_newtag (char *t)
{
int tp;
--last_tag;
if ((-last_tag) >= IMtable_size)
if ((-last_tag) >= IMtable_size) {
luaI_initfallbacks();
IMtable_size = growvector(&luaI_IMtable, IMtable_size,
struct IM, memEM, MAX_INT);
}
tp = -findstring(t, typenames);
if (tp == LUA_T_ARRAY || tp == LUA_T_USERDATA)
luaI_IMtable[-last_tag].tp = tp;

Loading…
Cancel
Save