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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lparser.c

?? 這個是一個嵌入式腳本支持引擎, 體積十分小巧
?? C
?? 第 1 頁 / 共 3 頁
字號:
  int rkkey;  if (ls->t.token == TK_NAME) {    luaY_checklimit(fs, cc->nh, MAX_INT, "items in a constructor");    checkname(ls, &key);  }  else  /* ls->t.token == '[' */    yindex(ls, &key);  cc->nh++;  checknext(ls, '=');  rkkey = luaK_exp2RK(fs, &key);  expr(ls, &val);  luaK_codeABC(fs, OP_SETTABLE, cc->t->u.s.info, rkkey, luaK_exp2RK(fs, &val));  fs->freereg = reg;  /* free registers */}static void closelistfield (FuncState *fs, struct ConsControl *cc) {  if (cc->v.k == VVOID) return;  /* there is no list item */  luaK_exp2nextreg(fs, &cc->v);  cc->v.k = VVOID;  if (cc->tostore == LFIELDS_PER_FLUSH) {    luaK_setlist(fs, cc->t->u.s.info, cc->na, cc->tostore);  /* flush */    cc->tostore = 0;  /* no more items pending */  }}static void lastlistfield (FuncState *fs, struct ConsControl *cc) {  if (cc->tostore == 0) return;  if (hasmultret(cc->v.k)) {    luaK_setmultret(fs, &cc->v);    luaK_setlist(fs, cc->t->u.s.info, cc->na, LUA_MULTRET);    cc->na--;  /* do not count last expression (unknown number of elements) */  }  else {    if (cc->v.k != VVOID)      luaK_exp2nextreg(fs, &cc->v);    luaK_setlist(fs, cc->t->u.s.info, cc->na, cc->tostore);  }}static void listfield (LexState *ls, struct ConsControl *cc) {  expr(ls, &cc->v);  luaY_checklimit(ls->fs, cc->na, MAX_INT, "items in a constructor");  cc->na++;  cc->tostore++;}static void constructor (LexState *ls, expdesc *t) {  /* constructor -> ?? */  FuncState *fs = ls->fs;  int line = ls->linenumber;  int pc = luaK_codeABC(fs, OP_NEWTABLE, 0, 0, 0);  struct ConsControl cc;  cc.na = cc.nh = cc.tostore = 0;  cc.t = t;  init_exp(t, VRELOCABLE, pc);  init_exp(&cc.v, VVOID, 0);  /* no value (yet) */  luaK_exp2nextreg(ls->fs, t);  /* fix it at stack top (for gc) */  checknext(ls, '{');  do {    lua_assert(cc.v.k == VVOID || cc.tostore > 0);    if (ls->t.token == '}') break;    closelistfield(fs, &cc);    switch(ls->t.token) {      case TK_NAME: {  /* may be listfields or recfields */        luaX_lookahead(ls);        if (ls->lookahead.token != '=')  /* expression? */          listfield(ls, &cc);        else          recfield(ls, &cc);        break;      }      case '[': {  /* constructor_item -> recfield */        recfield(ls, &cc);        break;      }      default: {  /* constructor_part -> listfield */        listfield(ls, &cc);        break;      }    }  } while (testnext(ls, ',') || testnext(ls, ';'));  check_match(ls, '}', '{', line);  lastlistfield(fs, &cc);  SETARG_B(fs->f->code[pc], luaO_int2fb(cc.na)); /* set initial array size */  SETARG_C(fs->f->code[pc], luaO_int2fb(cc.nh));  /* set initial table size */}/* }====================================================================== */static void parlist (LexState *ls) {  /* parlist -> [ param { `,' param } ] */  FuncState *fs = ls->fs;  Proto *f = fs->f;  int nparams = 0;  f->is_vararg = 0;  if (ls->t.token != ')') {  /* is `parlist' not empty? */    do {      switch (ls->t.token) {        case TK_NAME: {  /* param -> NAME */          new_localvar(ls, str_checkname(ls), nparams++);          break;        }        case TK_DOTS: {  /* param -> `...' */          luaX_next(ls);#if defined(LUA_COMPAT_VARARG)          /* use `arg' as default name */          new_localvarliteral(ls, "arg", nparams++);          f->is_vararg = VARARG_HASARG | VARARG_NEEDSARG;#endif          f->is_vararg |= VARARG_ISVARARG;          break;        }        default: luaX_syntaxerror(ls, "<name> or " LUA_QL("...") " expected");      }    } while (!f->is_vararg && testnext(ls, ','));  }  adjustlocalvars(ls, nparams);  f->numparams = cast_byte(fs->nactvar - (f->is_vararg & VARARG_HASARG));  luaK_reserveregs(fs, fs->nactvar);  /* reserve register for parameters */}static void body (LexState *ls, expdesc *e, int needself, int line) {  /* body ->  `(' parlist `)' chunk END */  FuncState new_fs;  open_func(ls, &new_fs);  new_fs.f->linedefined = line;  checknext(ls, '(');  if (needself) {    new_localvarliteral(ls, "self", 0);    adjustlocalvars(ls, 1);  }  parlist(ls);  checknext(ls, ')');  chunk(ls);  new_fs.f->lastlinedefined = ls->linenumber;  check_match(ls, TK_END, TK_FUNCTION, line);  close_func(ls);  pushclosure(ls, &new_fs, e);}static int explist1 (LexState *ls, expdesc *v) {  /* explist1 -> expr { `,' expr } */  int n = 1;  /* at least one expression */  expr(ls, v);  while (testnext(ls, ',')) {    luaK_exp2nextreg(ls->fs, v);    expr(ls, v);    n++;  }  return n;}static void funcargs (LexState *ls, expdesc *f) {  FuncState *fs = ls->fs;  expdesc args;  int base, nparams;  int line = ls->linenumber;  switch (ls->t.token) {    case '(': {  /* funcargs -> `(' [ explist1 ] `)' */      if (line != ls->lastline)        luaX_syntaxerror(ls,"ambiguous syntax (function call x new statement)");      luaX_next(ls);      if (ls->t.token == ')')  /* arg list is empty? */        args.k = VVOID;      else {        explist1(ls, &args);        luaK_setmultret(fs, &args);      }      check_match(ls, ')', '(', line);      break;    }    case '{': {  /* funcargs -> constructor */      constructor(ls, &args);      break;    }    case TK_STRING: {  /* funcargs -> STRING */      codestring(ls, &args, ls->t.seminfo.ts);      luaX_next(ls);  /* must use `seminfo' before `next' */      break;    }    default: {      luaX_syntaxerror(ls, "function arguments expected");      return;    }  }  lua_assert(f->k == VNONRELOC);  base = f->u.s.info;  /* base register for call */  if (hasmultret(args.k))    nparams = LUA_MULTRET;  /* open call */  else {    if (args.k != VVOID)      luaK_exp2nextreg(fs, &args);  /* close last argument */    nparams = fs->freereg - (base+1);  }  init_exp(f, VCALL, luaK_codeABC(fs, OP_CALL, base, nparams+1, 2));  luaK_fixline(fs, line);  fs->freereg = base+1;  /* call remove function and arguments and leaves                            (unless changed) one result */}/*** {======================================================================** Expression parsing** =======================================================================*/static void prefixexp (LexState *ls, expdesc *v) {  /* prefixexp -> NAME | '(' expr ')' */  switch (ls->t.token) {    case '(': {      int line = ls->linenumber;      luaX_next(ls);      expr(ls, v);      check_match(ls, ')', '(', line);      luaK_dischargevars(ls->fs, v);      return;    }    case TK_NAME: {      singlevar(ls, v);      return;    }    default: {      luaX_syntaxerror(ls, "unexpected symbol");      return;    }  }}static void primaryexp (LexState *ls, expdesc *v) {  /* primaryexp ->        prefixexp { `.' NAME | `[' exp `]' | `:' NAME funcargs | funcargs } */  FuncState *fs = ls->fs;  prefixexp(ls, v);  for (;;) {    switch (ls->t.token) {      case '.': {  /* field */        field(ls, v);        break;      }      case '[': {  /* `[' exp1 `]' */        expdesc key;        luaK_exp2anyreg(fs, v);        yindex(ls, &key);        luaK_indexed(fs, v, &key);        break;      }      case ':': {  /* `:' NAME funcargs */        expdesc key;        luaX_next(ls);        checkname(ls, &key);        luaK_self(fs, v, &key);        funcargs(ls, v);        break;      }      case '(': case TK_STRING: case '{': {  /* funcargs */        luaK_exp2nextreg(fs, v);        funcargs(ls, v);        break;      }      default: return;    }  }}static void simpleexp (LexState *ls, expdesc *v) {  /* simpleexp -> NUMBER | STRING | NIL | true | false | ... |                  constructor | FUNCTION body | primaryexp */  switch (ls->t.token) {    case TK_NUMBER: {      init_exp(v, VKNUM, 0);      v->u.nval = ls->t.seminfo.r;      break;    }    case TK_STRING: {      codestring(ls, v, ls->t.seminfo.ts);      break;    }    case TK_NIL: {      init_exp(v, VNIL, 0);      break;    }    case TK_TRUE: {      init_exp(v, VTRUE, 0);      break;    }    case TK_FALSE: {      init_exp(v, VFALSE, 0);      break;    }    case TK_DOTS: {  /* vararg */      FuncState *fs = ls->fs;      check_condition(ls, fs->f->is_vararg,                      "cannot use " LUA_QL("...") " outside a vararg function");      fs->f->is_vararg &= ~VARARG_NEEDSARG;  /* don't need 'arg' */      init_exp(v, VVARARG, luaK_codeABC(fs, OP_VARARG, 0, 1, 0));      break;    }    case '{': {  /* constructor */      constructor(ls, v);      return;    }    case TK_FUNCTION: {      luaX_next(ls);      body(ls, v, 0, ls->linenumber);      return;    }    default: {      primaryexp(ls, v);      return;    }  }  luaX_next(ls);}static UnOpr getunopr (int op) {  switch (op) {    case TK_NOT: return OPR_NOT;    case '-': return OPR_MINUS;    case '#': return OPR_LEN;    default: return OPR_NOUNOPR;  }}static BinOpr getbinopr (int op) {  switch (op) {    case '+': return OPR_ADD;    case '-': return OPR_SUB;    case '*': return OPR_MUL;    case '/': return OPR_DIV;    case '%': return OPR_MOD;    case '^': return OPR_POW;    case TK_CONCAT: return OPR_CONCAT;    case TK_NE: return OPR_NE;    case TK_EQ: return OPR_EQ;    case '<': return OPR_LT;    case TK_LE: return OPR_LE;    case '>': return OPR_GT;    case TK_GE: return OPR_GE;    case TK_AND: return OPR_AND;    case TK_OR: return OPR_OR;    default: return OPR_NOBINOPR;  }}static const struct {  lu_byte left;  /* left priority for each binary operator */  lu_byte right; /* right priority */} priority[] = {  /* ORDER OPR */   {6, 6}, {6, 6}, {7, 7}, {7, 7}, {7, 7},  /* `+' `-' `/' `%' */   {10, 9}, {5, 4},                 /* power and concat (right associative) */   {3, 3}, {3, 3},                  /* equality and inequality */   {3, 3}, {3, 3}, {3, 3}, {3, 3},  /* order */   {2, 2}, {1, 1}                   /* logical (and/or) */};#define UNARY_PRIORITY	8  /* priority for unary operators *//*** subexpr -> (simpleexp | unop subexpr) { binop subexpr }** where `binop' is any binary operator with a priority higher than `limit'*/static BinOpr subexpr (LexState *ls, expdesc *v, unsigned int limit) {  BinOpr op;  UnOpr uop;  enterlevel(ls);  uop = getunopr(ls->t.token);  if (uop != OPR_NOUNOPR) {    luaX_next(ls);    subexpr(ls, v, UNARY_PRIORITY);    luaK_prefix(ls->fs, uop, v);  }  else simpleexp(ls, v);  /* expand while operators have priorities higher than `limit' */  op = getbinopr(ls->t.token);  while (op != OPR_NOBINOPR && priority[op].left > limit) {    expdesc v2;    BinOpr nextop;    luaX_next(ls);    luaK_infix(ls->fs, op, v);    /* read sub-expression with higher priority */    nextop = subexpr(ls, &v2, priority[op].right);    luaK_posfix(ls->fs, op, v, &v2);    op = nextop;  }  leavelevel(ls);  return op;  /* return first untreated operator */}static void expr (LexState *ls, expdesc *v) {  subexpr(ls, v, 0);}/* }==================================================================== *//*** {======================================================================** Rules for Statements** =======================================================================*/static int block_follow (int token) {  switch (token) {    case TK_ELSE: case TK_ELSEIF: case TK_END:    case TK_UNTIL: case TK_EOS:      return 1;    default: return 0;  }}static void block (LexState *ls) {  /* block -> chunk */  FuncState *fs = ls->fs;  BlockCnt bl;  enterblock(fs, &bl, 0);  chunk(ls);  lua_assert(bl.breaklist == NO_JUMP);  leaveblock(fs);}/*** structure to chain all variables in the left-hand side of an** assignment

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
大白屁股一区二区视频| 极品尤物av久久免费看| 国产成人午夜99999| 欧美伊人久久久久久久久影院 | 99麻豆久久久国产精品免费| 欧美精品电影在线播放| 成人欧美一区二区三区在线播放| 日韩国产精品久久久久久亚洲| 91原创在线视频| 精品日韩99亚洲| 亚洲国产人成综合网站| 91玉足脚交白嫩脚丫在线播放| 精品久久99ma| 亚洲美女免费在线| 懂色av一区二区夜夜嗨| 精品国产一区二区三区久久影院 | 中文字幕亚洲精品在线观看| 日本一区二区三区国色天香| 亚洲色图欧美在线| 国产91精品精华液一区二区三区| 日韩欧美精品三级| 日韩1区2区3区| 欧美久久一二三四区| 亚洲一二三区在线观看| 91免费看片在线观看| 欧美激情自拍偷拍| 东方欧美亚洲色图在线| 久久麻豆一区二区| 国产精品乡下勾搭老头1| 26uuu国产日韩综合| 免费成人深夜小野草| 7777精品伊人久久久大香线蕉的| 亚洲高清一区二区三区| 欧美日韩高清一区二区不卡| 亚洲国产精品久久一线不卡| 欧美亚洲高清一区| 亚洲精品国产一区二区三区四区在线| 不卡一区二区三区四区| 亚洲婷婷综合色高清在线| 成人动漫一区二区在线| 国产网红主播福利一区二区| 国内精品写真在线观看| 久久色视频免费观看| 国产精品一区在线| 国产欧美日韩精品a在线观看| 久久国产精品72免费观看| 欧美久久久一区| 丝袜脚交一区二区| 日韩视频一区在线观看| 日韩国产精品久久| 日韩欧美精品在线视频| 精品一区二区三区在线视频| 精品欧美一区二区久久| 狠狠色丁香婷婷综合久久片| 久久亚洲春色中文字幕久久久| 国产成人精品www牛牛影视| 欧美韩国日本一区| 色哟哟精品一区| 亚洲图片欧美视频| 日韩精品一区在线| 成人精品视频一区二区三区| 91免费视频大全| 香蕉乱码成人久久天堂爱免费| 日韩一区二区视频| 国产精品18久久久久| 成人欧美一区二区三区白人 | 91网址在线看| 亚洲国产毛片aaaaa无费看| 欧美一区二区三区啪啪| 国模少妇一区二区三区| 国产精品家庭影院| 欧美日韩一级二级三级| 精品一区二区三区日韩| 国产精品素人一区二区| 在线观看视频一区二区| 毛片基地黄久久久久久天堂| 久久精品亚洲精品国产欧美kt∨ | 日本在线不卡视频一二三区| 久久综合九色欧美综合狠狠| 亚洲最大成人综合| 欧美成人三级电影在线| 成人午夜激情在线| 亚洲成人手机在线| 欧美精品一区二| 成人在线视频一区| 337p日本欧洲亚洲大胆色噜噜| 丁香六月久久综合狠狠色| 一区二区三区在线影院| 日韩欧美一级二级三级| 成人av网址在线观看| 日韩在线一区二区| 国产精品成人网| 7777精品伊人久久久大香线蕉超级流畅| 激情亚洲综合在线| 亚洲精品成人在线| 精品国偷自产国产一区| 91网址在线看| 国产一区二区剧情av在线| 亚洲精品中文在线影院| 精品久久久久久最新网址| 99精品视频一区二区| 人人超碰91尤物精品国产| 国产精品第五页| 欧美一区二区三区男人的天堂| 成人激情图片网| 美女一区二区在线观看| 亚洲精品菠萝久久久久久久| 精品国产欧美一区二区| 欧美专区亚洲专区| 国产成人av网站| 日本va欧美va瓶| 一区二区三区在线视频免费观看 | 色婷婷久久综合| 国产剧情一区在线| 日日嗨av一区二区三区四区| 中文字幕 久热精品 视频在线| 日韩欧美一区在线观看| 色拍拍在线精品视频8848| 国产精品亚洲人在线观看| 日韩中文欧美在线| 亚洲永久精品国产| 国产精品麻豆欧美日韩ww| 精品国产一区二区国模嫣然| 欧美精品久久久久久久多人混战| 91社区在线播放| 成人午夜视频免费看| 国产一区91精品张津瑜| 天堂成人免费av电影一区| 怡红院av一区二区三区| 中文字幕国产一区| 久久九九久久九九| 欧美tickling挠脚心丨vk| 欧美日韩国产小视频| 99久久精品国产观看| 福利一区二区在线观看| 国产在线精品视频| 精品一区精品二区高清| 日本欧美肥老太交大片| 亚洲成人福利片| 亚洲黄色免费电影| 亚洲欧美经典视频| 亚洲素人一区二区| 欧美激情在线免费观看| 国产三级三级三级精品8ⅰ区| 欧美一级生活片| 91.com在线观看| 欧美在线视频你懂得| 91亚洲大成网污www| av色综合久久天堂av综合| 国产成人在线视频网址| 国产精品1024| 国产99一区视频免费| 成人性生交大片免费看在线播放| 国产酒店精品激情| 东方aⅴ免费观看久久av| 成人影视亚洲图片在线| 成人激情免费电影网址| 成人av电影在线观看| 9久草视频在线视频精品| 91农村精品一区二区在线| 91啦中文在线观看| 91久久久免费一区二区| 欧美性感一类影片在线播放| 欧美三级中文字幕| 91精品国产91久久久久久最新毛片 | 日韩在线播放一区二区| 日韩av不卡在线观看| 麻豆久久久久久| 国产主播一区二区| 国产成人精品一区二区三区网站观看| 国产成人日日夜夜| 福利一区福利二区| 91美女视频网站| 欧美日韩黄视频| 欧美tk—视频vk| 日本一区二区动态图| 亚洲丝袜制服诱惑| 亚洲大片一区二区三区| 日本va欧美va瓶| 国产很黄免费观看久久| 不卡的av中国片| 91成人免费在线视频| 制服丝袜日韩国产| 久久久久久免费毛片精品| 国产精品的网站| 亚洲一区二区三区自拍| 美女网站在线免费欧美精品| 国产成人免费高清| 色婷婷久久久亚洲一区二区三区| 欧美日韩免费高清一区色橹橹| 欧美一区日本一区韩国一区| 国产人成一区二区三区影院| 亚洲男人天堂av网| 蜜桃av噜噜一区| 成人午夜电影网站| 欧美日韩一区在线| 久久久久久一级片| 一区二区在线观看免费| 捆绑调教美女网站视频一区| 成人国产精品免费观看视频|