static int LoadHeader (lua_State* L, ZIO* Z) { int version,swap; Number f=0,tf=TEST_NUMBER; LoadSignature(L,Z); version=ezgetc(L,Z); if (version>VERSION) luaO_verror(L,"`%.99s' too new:\n" " read version %d.%d; expected at most %d.%d", ZNAME(Z),V(version),V(VERSION)); if (version<VERSION0) /* check last major change */ luaO_verror(L,"`%.99s' too old:\n" " read version %d.%d; expected at least %d.%d", ZNAME(Z),V(version),V(VERSION)); swap=(luaU_endianess()!=ezgetc(L,Z)); /* need to swap bytes? */ TESTSIZE(sizeof(int)); TESTSIZE(sizeof(size_t)); TESTSIZE(sizeof(Instruction)); TESTSIZE(SIZE_INSTRUCTION); TESTSIZE(SIZE_OP); TESTSIZE(SIZE_B); TESTSIZE(sizeof(Number)); f=LoadNumber(L,Z,swap); if ((long)f!=(long)tf) /* disregard errors in last bit of fraction */ luaO_verror(L,"unknown number format in `%.99s':\n" " read " NUMBER_FMT "; expected " NUMBER_FMT, ZNAME(Z),f,tf); return swap; }
void luaG_ordererror (lua_State *L, StkId top) { const char *t1 = luaO_typename(top-2); const char *t2 = luaO_typename(top-1); if (t1[2] == t2[2]) luaO_verror(L, "attempt to compare two %.10s values", t1); else luaO_verror(L, "attempt to compare %.10s with %.10s", t1, t2); }
static int luaI_checkevent (lua_State *L, const char *name, int t) { int e = findevent(name); if (e >= TM_N) luaO_verror(L, "event `%.50s' is deprecated", name); if (e == TM_GC && t == LUA_TTABLE) luaO_verror(L, "event `gc' for tables is deprecated"); if (e < 0) luaO_verror(L, "`%.50s' is not a valid event name", name); return e; }
void luaG_typeerror (lua_State *L, StkId o, const char *op) { const char *name; const char *kind = getobjname(L, o, &name); const char *t = luaO_typename(o); if (kind) luaO_verror(L, "attempt to %.30s %.20s `%.40s' (a %.10s value)", op, kind, name, t); else luaO_verror(L, "attempt to %.30s a %.10s value", op, t); }
static void TestSize (lua_State* L, int s, const char* what, ZIO* Z) { int r=ezgetc(L,Z); if (r!=s) luaO_verror(L,"virtual machine mismatch in `%.99s':\n" " %.20s is %d but read %d",ZNAME(Z),what,s,r); }
static void LoadSignature (lua_State* L, ZIO* Z) { const char* s=SIGNATURE; while (*s!=0 && ezgetc(L,Z)==*s) ++s; if (*s!=0) luaO_verror(L,"bad signature in `%.99s'",ZNAME(Z)); }
LUA_API void lua_pushusertag (lua_State *L, void *u, int tag) { /* ORDER LUA_T */ if (!(tag == LUA_ANYTAG || tag == LUA_TUSERDATA || validtag(tag))) luaO_verror(L, "invalid tag for a userdata (%d)", tag); tsvalue(L->top) = luaS_createudata(L, u, tag); ttype(L->top) = LUA_TUSERDATA; api_incr_top(L); }
static void LoadCode (lua_State* L, Proto* tf, ZIO* Z, int swap) { int size=LoadInt(L,Z,swap); tf->code=luaM_newvector(L,size,Instruction); LoadVector(L,tf->code,size,sizeof(*tf->code),Z,swap); if (tf->code[size-1]!=OP_END) luaO_verror(L,"bad code in `%.99s'",ZNAME(Z)); luaF_protook(L,tf,size); }
/* ** load one chunk from a file or buffer ** return main if ok and NULL at EOF */ Proto* luaU_undump (lua_State* L, ZIO* Z) { Proto* tf=NULL; int c=zgetc(Z); if (c==ID_CHUNK) tf=LoadChunk(L,Z); c=zgetc(Z); if (c!=EOZ) luaO_verror(L,"`%.99s' apparently contains more than one chunk",ZNAME(Z)); return tf; }
LUA_API void lua_settag (lua_State *L, int tag) { luaT_realtag(L, tag); switch (ttype(L->top-1)) { case LUA_TTABLE: hvalue(L->top-1)->htag = tag; break; case LUA_TUSERDATA: tsvalue(L->top-1)->u.d.tag = tag; break; default: luaO_verror(L, "cannot change the tag of a %.20s", luaO_typename(L->top-1)); } }
static void unexpectedEOZ (lua_State* L, ZIO* Z) { luaO_verror(L,"unexpected end of file in `%.99s'",ZNAME(Z)); }
void luaX_syntaxerror (LexState *ls, const char *s, const char *token) { char buff[MAXSRC]; luaO_chunkid(buff, ls->source->str, sizeof(buff)); luaO_verror(ls->L, "%.99s;\n last token read: `%.30s' at line %d in %.80s", s, token, ls->linenumber, buff); }