亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? lparser.c

?? 小型腳本語(yǔ)言開(kāi)發(fā)包,使用于嵌入式開(kāi)發(fā),比較熱門(mén).
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/*** $Id: lparser.c,v 2.42a 2006/06/05 15:57:59 roberto Exp $** Lua Parser** See Copyright Notice in lua.h*/#include <string.h>#define lparser_c#define LUA_CORE#include "lua.h"#include "lcode.h"#include "ldebug.h"#include "ldo.h"#include "lfunc.h"#include "llex.h"#include "lmem.h"#include "lobject.h"#include "lopcodes.h"#include "lparser.h"#include "lstate.h"#include "lstring.h"#include "ltable.h"#define hasmultret(k)		((k) == VCALL || (k) == VVARARG)#define getlocvar(fs, i)	((fs)->f->locvars[(fs)->actvar[i]])#define luaY_checklimit(fs,v,l,m)	if ((v)>(l)) errorlimit(fs,l,m)/*** nodes for block list (list of active blocks)*/typedef struct BlockCnt {  struct BlockCnt *previous;  /* chain */  int breaklist;  /* list of jumps out of this loop */  lu_byte nactvar;  /* # active locals outside the breakable structure */  lu_byte upval;  /* true if some variable in the block is an upvalue */  lu_byte isbreakable;  /* true if `block' is a loop */} BlockCnt;/*** prototypes for recursive non-terminal functions*/static void chunk (LexState *ls);static void expr (LexState *ls, expdesc *v);static void anchor_token (LexState *ls) {  if (ls->t.token == TK_NAME || ls->t.token == TK_STRING) {    TString *ts = ls->t.seminfo.ts;    luaX_newstring(ls, getstr(ts), ts->tsv.len);  }}static void error_expected (LexState *ls, int token) {  luaX_syntaxerror(ls,      luaO_pushfstring(ls->L, LUA_QS " expected", luaX_token2str(ls, token)));}static void errorlimit (FuncState *fs, int limit, const char *what) {  const char *msg = (fs->f->linedefined == 0) ?    luaO_pushfstring(fs->L, "main function has more than %d %s", limit, what) :    luaO_pushfstring(fs->L, "function at line %d has more than %d %s",                            fs->f->linedefined, limit, what);  luaX_lexerror(fs->ls, msg, 0);}static int testnext (LexState *ls, int c) {  if (ls->t.token == c) {    luaX_next(ls);    return 1;  }  else return 0;}static void check (LexState *ls, int c) {  if (ls->t.token != c)    error_expected(ls, c);}static void checknext (LexState *ls, int c) {  check(ls, c);  luaX_next(ls);}#define check_condition(ls,c,msg)	{ if (!(c)) luaX_syntaxerror(ls, msg); }static void check_match (LexState *ls, int what, int who, int where) {  if (!testnext(ls, what)) {    if (where == ls->linenumber)      error_expected(ls, what);    else {      luaX_syntaxerror(ls, luaO_pushfstring(ls->L,             LUA_QS " expected (to close " LUA_QS " at line %d)",              luaX_token2str(ls, what), luaX_token2str(ls, who), where));    }  }}static TString *str_checkname (LexState *ls) {  TString *ts;  check(ls, TK_NAME);  ts = ls->t.seminfo.ts;  luaX_next(ls);  return ts;}static void init_exp (expdesc *e, expkind k, int i) {  e->f = e->t = NO_JUMP;  e->k = k;  e->u.s.info = i;}static void codestring (LexState *ls, expdesc *e, TString *s) {  init_exp(e, VK, luaK_stringK(ls->fs, s));}static void checkname(LexState *ls, expdesc *e) {  codestring(ls, e, str_checkname(ls));}static int registerlocalvar (LexState *ls, TString *varname) {  FuncState *fs = ls->fs;  Proto *f = fs->f;  int oldsize = f->sizelocvars;  luaM_growvector(ls->L, f->locvars, fs->nlocvars, f->sizelocvars,                  LocVar, SHRT_MAX, "too many local variables");  while (oldsize < f->sizelocvars) f->locvars[oldsize++].varname = NULL;  f->locvars[fs->nlocvars].varname = varname;  luaC_objbarrier(ls->L, f, varname);  return fs->nlocvars++;}#define new_localvarliteral(ls,v,n) \  new_localvar(ls, luaX_newstring(ls, "" v, (sizeof(v)/sizeof(char))-1), n)static void new_localvar (LexState *ls, TString *name, int n) {  FuncState *fs = ls->fs;  luaY_checklimit(fs, fs->nactvar+n+1, LUAI_MAXVARS, "local variables");  fs->actvar[fs->nactvar+n] = cast(unsigned short, registerlocalvar(ls, name));}static void adjustlocalvars (LexState *ls, int nvars) {  FuncState *fs = ls->fs;  fs->nactvar = cast_byte(fs->nactvar + nvars);  for (; nvars; nvars--) {    getlocvar(fs, fs->nactvar - nvars).startpc = fs->pc;  }}static void removevars (LexState *ls, int tolevel) {  FuncState *fs = ls->fs;  while (fs->nactvar > tolevel)    getlocvar(fs, --fs->nactvar).endpc = fs->pc;}static int indexupvalue (FuncState *fs, TString *name, expdesc *v) {  int i;  Proto *f = fs->f;  int oldsize = f->sizeupvalues;  for (i=0; i<f->nups; i++) {    if (fs->upvalues[i].k == v->k && fs->upvalues[i].info == v->u.s.info) {      lua_assert(f->upvalues[i] == name);      return i;    }  }  /* new one */  luaY_checklimit(fs, f->nups + 1, LUAI_MAXUPVALUES, "upvalues");  luaM_growvector(fs->L, f->upvalues, f->nups, f->sizeupvalues,                  TString *, MAX_INT, "");  while (oldsize < f->sizeupvalues) f->upvalues[oldsize++] = NULL;  f->upvalues[f->nups] = name;  luaC_objbarrier(fs->L, f, name);  lua_assert(v->k == VLOCAL || v->k == VUPVAL);  fs->upvalues[f->nups].k = cast_byte(v->k);  fs->upvalues[f->nups].info = cast_byte(v->u.s.info);  return f->nups++;}static int searchvar (FuncState *fs, TString *n) {  int i;  for (i=fs->nactvar-1; i >= 0; i--) {    if (n == getlocvar(fs, i).varname)      return i;  }  return -1;  /* not found */}static void markupval (FuncState *fs, int level) {  BlockCnt *bl = fs->bl;  while (bl && bl->nactvar > level) bl = bl->previous;  if (bl) bl->upval = 1;}static int singlevaraux (FuncState *fs, TString *n, expdesc *var, int base) {  if (fs == NULL) {  /* no more levels? */    init_exp(var, VGLOBAL, NO_REG);  /* default is global variable */    return VGLOBAL;  }  else {    int v = searchvar(fs, n);  /* look up at current level */    if (v >= 0) {      init_exp(var, VLOCAL, v);      if (!base)        markupval(fs, v);  /* local will be used as an upval */      return VLOCAL;    }    else {  /* not found at current level; try upper one */      if (singlevaraux(fs->prev, n, var, 0) == VGLOBAL)        return VGLOBAL;      var->u.s.info = indexupvalue(fs, n, var);  /* else was LOCAL or UPVAL */      var->k = VUPVAL;  /* upvalue in this level */      return VUPVAL;    }  }}static void singlevar (LexState *ls, expdesc *var) {  TString *varname = str_checkname(ls);  FuncState *fs = ls->fs;  if (singlevaraux(fs, varname, var, 1) == VGLOBAL)    var->u.s.info = luaK_stringK(fs, varname);  /* info points to global name */}static void adjust_assign (LexState *ls, int nvars, int nexps, expdesc *e) {  FuncState *fs = ls->fs;  int extra = nvars - nexps;  if (hasmultret(e->k)) {    extra++;  /* includes call itself */    if (extra < 0) extra = 0;    luaK_setreturns(fs, e, extra);  /* last exp. provides the difference */    if (extra > 1) luaK_reserveregs(fs, extra-1);  }  else {    if (e->k != VVOID) luaK_exp2nextreg(fs, e);  /* close last expression */    if (extra > 0) {      int reg = fs->freereg;      luaK_reserveregs(fs, extra);      luaK_nil(fs, reg, extra);    }  }}static void enterlevel (LexState *ls) {  if (++ls->L->nCcalls > LUAI_MAXCCALLS)	luaX_lexerror(ls, "chunk has too many syntax levels", 0);}#define leavelevel(ls)	((ls)->L->nCcalls--)static void enterblock (FuncState *fs, BlockCnt *bl, lu_byte isbreakable) {  bl->breaklist = NO_JUMP;  bl->isbreakable = isbreakable;  bl->nactvar = fs->nactvar;  bl->upval = 0;  bl->previous = fs->bl;  fs->bl = bl;  lua_assert(fs->freereg == fs->nactvar);}static void leaveblock (FuncState *fs) {  BlockCnt *bl = fs->bl;  fs->bl = bl->previous;  removevars(fs->ls, bl->nactvar);  if (bl->upval)    luaK_codeABC(fs, OP_CLOSE, bl->nactvar, 0, 0);  /* a block either controls scope or breaks (never both) */  lua_assert(!bl->isbreakable || !bl->upval);  lua_assert(bl->nactvar == fs->nactvar);  fs->freereg = fs->nactvar;  /* free registers */  luaK_patchtohere(fs, bl->breaklist);}static void pushclosure (LexState *ls, FuncState *func, expdesc *v) {  FuncState *fs = ls->fs;  Proto *f = fs->f;  int oldsize = f->sizep;  int i;  luaM_growvector(ls->L, f->p, fs->np, f->sizep, Proto *,                  MAXARG_Bx, "constant table overflow");  while (oldsize < f->sizep) f->p[oldsize++] = NULL;  f->p[fs->np++] = func->f;  luaC_objbarrier(ls->L, f, func->f);  init_exp(v, VRELOCABLE, luaK_codeABx(fs, OP_CLOSURE, 0, fs->np-1));  for (i=0; i<func->f->nups; i++) {    OpCode o = (func->upvalues[i].k == VLOCAL) ? OP_MOVE : OP_GETUPVAL;    luaK_codeABC(fs, o, 0, func->upvalues[i].info, 0);  }}static void open_func (LexState *ls, FuncState *fs) {  lua_State *L = ls->L;  Proto *f = luaF_newproto(L);  fs->f = f;  fs->prev = ls->fs;  /* linked list of funcstates */  fs->ls = ls;  fs->L = L;  ls->fs = fs;  fs->pc = 0;  fs->lasttarget = -1;  fs->jpc = NO_JUMP;  fs->freereg = 0;  fs->nk = 0;  fs->np = 0;  fs->nlocvars = 0;  fs->nactvar = 0;  fs->bl = NULL;  f->source = ls->source;  f->maxstacksize = 2;  /* registers 0/1 are always valid */  fs->h = luaH_new(L, 0, 0);  /* anchor table of constants and prototype (to avoid being collected) */  sethvalue2s(L, L->top, fs->h);  incr_top(L);  setptvalue2s(L, L->top, f);  incr_top(L);}static void close_func (LexState *ls) {  lua_State *L = ls->L;  FuncState *fs = ls->fs;  Proto *f = fs->f;  removevars(ls, 0);  luaK_ret(fs, 0, 0);  /* final return */  luaM_reallocvector(L, f->code, f->sizecode, fs->pc, Instruction);  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, TValue);  f->sizek = fs->nk;  luaM_reallocvector(L, f->p, f->sizep, fs->np, Proto *);  f->sizep = fs->np;  luaM_reallocvector(L, f->locvars, f->sizelocvars, fs->nlocvars, LocVar);  f->sizelocvars = fs->nlocvars;  luaM_reallocvector(L, f->upvalues, f->sizeupvalues, f->nups, TString *);  f->sizeupvalues = f->nups;  lua_assert(luaG_checkcode(f));  lua_assert(fs->bl == NULL);  ls->fs = fs->prev;  L->top -= 2;  /* remove table and prototype from the stack */  /* last token read was anchored in defunct function; must reanchor it */  if (fs) anchor_token(ls);}Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, const char *name) {  struct LexState lexstate;  struct FuncState funcstate;  lexstate.buff = buff;  luaX_setinput(L, &lexstate, z, luaS_new(L, name));  open_func(&lexstate, &funcstate);  funcstate.f->is_vararg = VARARG_ISVARARG;  /* main func. is always vararg */  luaX_next(&lexstate);  /* read first token */  chunk(&lexstate);  check(&lexstate, TK_EOS);  close_func(&lexstate);  lua_assert(funcstate.prev == NULL);  lua_assert(funcstate.f->nups == 0);  lua_assert(lexstate.fs == NULL);  return funcstate.f;}/*============================================================*//* GRAMMAR RULES *//*============================================================*/static void field (LexState *ls, expdesc *v) {  /* field -> ['.' | ':'] NAME */  FuncState *fs = ls->fs;  expdesc key;  luaK_exp2anyreg(fs, v);  luaX_next(ls);  /* skip the dot or colon */  checkname(ls, &key);  luaK_indexed(fs, v, &key);}static void yindex (LexState *ls, expdesc *v) {  /* index -> '[' expr ']' */  luaX_next(ls);  /* skip the '[' */  expr(ls, v);  luaK_exp2val(ls->fs, v);  checknext(ls, ']');}/*** {======================================================================** Rules for Constructors** =======================================================================*/struct ConsControl {  expdesc v;  /* last list item read */  expdesc *t;  /* table descriptor */  int nh;  /* total number of `record' elements */  int na;  /* total number of array elements */  int tostore;  /* number of array elements pending to be stored */};static void recfield (LexState *ls, struct ConsControl *cc) {  /* recfield -> (NAME | `['exp1`]') = exp1 */  FuncState *fs = ls->fs;  int reg = ls->fs->freereg;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色婷婷综合在线| 亚洲视频一二区| 国产欧美一区二区三区沐欲| 久久婷婷国产综合精品青草| 欧美高清在线视频| 亚洲免费大片在线观看| 亚洲高清免费观看| 丝瓜av网站精品一区二区| 国产精品第一页第二页第三页| 亚洲自拍欧美精品| 久久国产三级精品| 91在线视频播放| 欧美精品久久一区| 久久一留热品黄| 亚洲乱码国产乱码精品精98午夜| 日本不卡不码高清免费观看| 国产精品一区二区在线观看网站| 成人黄色在线看| 欧美日韩不卡一区二区| 精品国产亚洲在线| av电影天堂一区二区在线观看| 欧美专区日韩专区| av成人免费在线观看| a4yy欧美一区二区三区| 日韩区在线观看| 亚洲欧美视频一区| 国产乱人伦偷精品视频免下载| 色综合一个色综合亚洲| 精品美女一区二区| 亚洲国产cao| 99精品国产99久久久久久白柏 | 国产精品入口麻豆原神| 亚欧色一区w666天堂| 不卡欧美aaaaa| 欧美日韩国产综合草草| 国产精品久久久久久久久动漫| 青娱乐精品视频| 爽好久久久欧美精品| 日本亚洲天堂网| 精品国产乱码久久久久久夜甘婷婷 | av一区二区三区| 欧美色涩在线第一页| 国产精品久久久久四虎| 成人一二三区视频| 中文字幕日韩av资源站| 国产伦精品一区二区三区视频青涩| 爽爽淫人综合网网站| 亚洲综合男人的天堂| 国内久久精品视频| 国产精品18久久久久| 欧美日韩在线精品一区二区三区激情| 国产精品动漫网站| 国产乱码精品一区二区三区忘忧草| ㊣最新国产の精品bt伙计久久| 亚洲柠檬福利资源导航| 国产不卡视频一区二区三区| 色婷婷激情综合| 国产精品乱码一区二区三区软件 | av高清不卡在线| 成人免费毛片aaaaa**| 中文字幕日韩一区二区| 色成年激情久久综合| 亚洲色图19p| 91精品办公室少妇高潮对白| 久久久午夜精品理论片中文字幕| gogo大胆日本视频一区| 亚洲午夜电影在线| 成人动漫在线一区| 26uuu国产电影一区二区| 美国十次综合导航| 久久这里只有精品6| 国产成人亚洲综合色影视| 亚洲乱码中文字幕| heyzo一本久久综合| 天堂成人国产精品一区| 夜夜揉揉日日人人青青一国产精品| www.色综合.com| 国产精品蜜臀在线观看| 91在线视频观看| 日韩福利电影在线观看| 精品久久久久香蕉网| 欧美国产一区在线| 欧美精品一区二区三区很污很色的| 免费精品99久久国产综合精品| 日本在线播放一区二区三区| 亚洲精品在线观| 欧美一区二区黄| 国产不卡视频在线观看| 午夜婷婷国产麻豆精品| 国产日韩欧美亚洲| 国产欧美日韩亚州综合| 亚洲伦在线观看| 九一九一国产精品| 欧美欧美欧美欧美首页| 91麻豆精东视频| 捆绑调教美女网站视频一区| 粉嫩在线一区二区三区视频| 一区二区三区在线免费| 亚洲欧美综合在线精品| 欧美不卡一区二区三区四区| 久久精品视频网| 亚洲欧洲日产国码二区| 天堂蜜桃一区二区三区 | 亚洲国产中文字幕| 国产91丝袜在线播放九色| 中文字幕一区二区三中文字幕| 日韩欧美aaaaaa| 日韩视频免费观看高清完整版| 国产宾馆实践打屁股91| 欧美高清视频不卡网| 欧美电影免费观看高清完整版在线观看| 国产欧美综合在线观看第十页| 亚洲国产综合91精品麻豆| 亚洲国产精品成人综合 | 欧美大肚乱孕交hd孕妇| 3atv在线一区二区三区| 91久久香蕉国产日韩欧美9色| 麻豆成人免费电影| 福利一区二区在线| 91免费国产在线| 91亚洲永久精品| 欧美日韩一区二区三区在线看| 欧美一级二级在线观看| 成人美女视频在线看| 久久精品国产一区二区| 国产传媒久久文化传媒| 香蕉久久夜色精品国产使用方法| 美女视频黄 久久| 91久久免费观看| 久久蜜桃av一区精品变态类天堂| 亚洲激情av在线| www.久久精品| 精品国产乱码久久久久久闺蜜 | 亚洲乱码精品一二三四区日韩在线| 日本一区二区免费在线| 久久99深爱久久99精品| 777午夜精品免费视频| 在线视频欧美精品| 精品国产乱码久久久久久牛牛 | 日韩美一区二区三区| 国产精品2024| 欧美性大战久久| 成人91在线观看| 国产在线一区二区综合免费视频| 国产精品麻豆一区二区| 91精品国产综合久久蜜臀| 99久久夜色精品国产网站| 久久精品99久久久| 中文字幕的久久| 精品国产一区二区精华| 在线亚洲人成电影网站色www| 99久久国产综合精品麻豆| 成人激情开心网| 欧美三级中文字| 欧美激情综合网| 日韩二区在线观看| 欧美久久久久久蜜桃| 18欧美乱大交hd1984| 国产精品综合在线视频| 天天色综合成人网| 国产成人精品一区二区三区四区 | 欧美色中文字幕| 国产婷婷一区二区| 青草av.久久免费一区| 国产一区二区伦理片| 91麻豆精品国产91| 亚洲第一二三四区| 欧美在线观看视频一区二区三区| 国产精品你懂的在线欣赏| 久久国产尿小便嘘嘘尿| 亚洲黄色免费电影| 国产一区二区福利| 日韩精品一区二区三区swag| 8x8x8国产精品| 精品成人一区二区三区四区| 成人黄色免费短视频| 精品伦理精品一区| 久久久久九九视频| 国产一区二区三区观看| 日韩欧美精品三级| 国产一区欧美日韩| 国产精品高潮呻吟| 欧美一区二区播放| 中文字幕乱码日本亚洲一区二区| 99国产精品99久久久久久| 蜜乳av一区二区三区| 成a人片国产精品| 久久精品国产一区二区| 欧美在线观看视频在线| 色综合色综合色综合色综合色综合| 国产美女视频一区| 国产一区二区精品久久99| 狠狠色狠狠色综合日日91app| 蜜桃传媒麻豆第一区在线观看| 香蕉影视欧美成人| 日韩精品一级二级| 久久99精品网久久| 黄色日韩三级电影| 国产精品亚洲一区二区三区在线| 国内精品久久久久影院色|