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

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

?? lcode.c

?? 腳本語言lua-5.1的源代碼, 非常的經典!
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*** $Id: lcode.c,v 2.24 2005/12/22 16:19:56 roberto Exp $** Code generator for Lua** See Copyright Notice in lua.h*/#include <stdlib.h>#define lcode_c#define LUA_CORE#include "lua.h"#include "lcode.h"#include "ldebug.h"#include "ldo.h"#include "lgc.h"#include "llex.h"#include "lmem.h"#include "lobject.h"#include "lopcodes.h"#include "lparser.h"#include "ltable.h"#define hasjumps(e)	((e)->t != (e)->f)static int isnumeral(expdesc *e) {  return (e->k == VKNUM && e->t == NO_JUMP && e->f == NO_JUMP);}void luaK_nil (FuncState *fs, int from, int n) {  Instruction *previous;  if (fs->pc > fs->lasttarget) {  /* no jumps to current position? */    if (fs->pc == 0)  /* function start? */      return;  /* positions are already clean */    if (GET_OPCODE(*(previous = &fs->f->code[fs->pc-1])) == OP_LOADNIL) {      int pfrom = GETARG_A(*previous);      int pto = GETARG_B(*previous);      if (pfrom <= from && from <= pto+1) {  /* can connect both? */        if (from+n-1 > pto)          SETARG_B(*previous, from+n-1);        return;      }    }  }  luaK_codeABC(fs, OP_LOADNIL, from, from+n-1, 0);  /* else no optimization */}int luaK_jump (FuncState *fs) {  int jpc = fs->jpc;  /* save list of jumps to here */  int j;  fs->jpc = NO_JUMP;  j = luaK_codeAsBx(fs, OP_JMP, 0, NO_JUMP);  luaK_concat(fs, &j, jpc);  /* keep them on hold */  return j;}void luaK_ret (FuncState *fs, int first, int nret) {  luaK_codeABC(fs, OP_RETURN, first, nret+1, 0);}static int condjump (FuncState *fs, OpCode op, int A, int B, int C) {  luaK_codeABC(fs, op, A, B, C);  return luaK_jump(fs);}static void fixjump (FuncState *fs, int pc, int dest) {  Instruction *jmp = &fs->f->code[pc];  int offset = dest-(pc+1);  lua_assert(dest != NO_JUMP);  if (abs(offset) > MAXARG_sBx)    luaX_syntaxerror(fs->ls, "control structure too long");  SETARG_sBx(*jmp, offset);}/*** returns current `pc' and marks it as a jump target (to avoid wrong** optimizations with consecutive instructions not in the same basic block).*/int luaK_getlabel (FuncState *fs) {  fs->lasttarget = fs->pc;  return fs->pc;}static int getjump (FuncState *fs, int pc) {  int offset = GETARG_sBx(fs->f->code[pc]);  if (offset == NO_JUMP)  /* point to itself represents end of list */    return NO_JUMP;  /* end of list */  else    return (pc+1)+offset;  /* turn offset into absolute position */}static Instruction *getjumpcontrol (FuncState *fs, int pc) {  Instruction *pi = &fs->f->code[pc];  if (pc >= 1 && testTMode(GET_OPCODE(*(pi-1))))    return pi-1;  else    return pi;}/*** check whether list has any jump that do not produce a value** (or produce an inverted value)*/static int need_value (FuncState *fs, int list) {  for (; list != NO_JUMP; list = getjump(fs, list)) {    Instruction i = *getjumpcontrol(fs, list);    if (GET_OPCODE(i) != OP_TESTSET) return 1;  }  return 0;  /* not found */}static int patchtestreg (FuncState *fs, int node, int reg) {  Instruction *i = getjumpcontrol(fs, node);  if (GET_OPCODE(*i) != OP_TESTSET)    return 0;  /* cannot patch other instructions */  if (reg != NO_REG && reg != GETARG_B(*i))    SETARG_A(*i, reg);  else  /* no register to put value or register already has the value */    *i = CREATE_ABC(OP_TEST, GETARG_B(*i), 0, GETARG_C(*i));  return 1;}static void removevalues (FuncState *fs, int list) {  for (; list != NO_JUMP; list = getjump(fs, list))      patchtestreg(fs, list, NO_REG);}static void patchlistaux (FuncState *fs, int list, int vtarget, int reg,                          int dtarget) {  while (list != NO_JUMP) {    int next = getjump(fs, list);    if (patchtestreg(fs, list, reg))      fixjump(fs, list, vtarget);    else      fixjump(fs, list, dtarget);  /* jump to default target */    list = next;  }}static void dischargejpc (FuncState *fs) {  patchlistaux(fs, fs->jpc, fs->pc, NO_REG, fs->pc);  fs->jpc = NO_JUMP;}void luaK_patchlist (FuncState *fs, int list, int target) {  if (target == fs->pc)    luaK_patchtohere(fs, list);  else {    lua_assert(target < fs->pc);    patchlistaux(fs, list, target, NO_REG, target);  }}void luaK_patchtohere (FuncState *fs, int list) {  luaK_getlabel(fs);  luaK_concat(fs, &fs->jpc, list);}void luaK_concat (FuncState *fs, int *l1, int l2) {  if (l2 == NO_JUMP) return;  else if (*l1 == NO_JUMP)    *l1 = l2;  else {    int list = *l1;    int next;    while ((next = getjump(fs, list)) != NO_JUMP)  /* find last element */      list = next;    fixjump(fs, list, l2);  }}void luaK_checkstack (FuncState *fs, int n) {  int newstack = fs->freereg + n;  if (newstack > fs->f->maxstacksize) {    if (newstack >= MAXSTACK)      luaX_syntaxerror(fs->ls, "function or expression too complex");    fs->f->maxstacksize = cast_byte(newstack);  }}void luaK_reserveregs (FuncState *fs, int n) {  luaK_checkstack(fs, n);  fs->freereg += n;}static void freereg (FuncState *fs, int reg) {  if (!ISK(reg) && reg >= fs->nactvar) {    fs->freereg--;    lua_assert(reg == fs->freereg);  }}static void freeexp (FuncState *fs, expdesc *e) {  if (e->k == VNONRELOC)    freereg(fs, e->u.s.info);}static int addk (FuncState *fs, TValue *k, TValue *v) {  lua_State *L = fs->L;  TValue *idx = luaH_set(L, fs->h, k);  Proto *f = fs->f;  int oldsize = f->sizek;  if (ttisnumber(idx)) {    lua_assert(luaO_rawequalObj(&fs->f->k[cast_int(nvalue(idx))], v));    return cast_int(nvalue(idx));  }  else {  /* constant not found; create a new entry */    setnvalue(idx, cast_num(fs->nk));    luaM_growvector(L, f->k, fs->nk, f->sizek, TValue,                    MAXARG_Bx, "constant table overflow");    while (oldsize < f->sizek) setnilvalue(&f->k[oldsize++]);    setobj(L, &f->k[fs->nk], v);    luaC_barrier(L, f, v);    return fs->nk++;  }}int luaK_stringK (FuncState *fs, TString *s) {  TValue o;  setsvalue(fs->L, &o, s);  return addk(fs, &o, &o);}int luaK_numberK (FuncState *fs, lua_Number r) {  TValue o;  setnvalue(&o, r);  return addk(fs, &o, &o);}static int boolK (FuncState *fs, int b) {  TValue o;  setbvalue(&o, b);  return addk(fs, &o, &o);}static int nilK (FuncState *fs) {  TValue k, v;  setnilvalue(&v);  /* cannot use nil as key; instead use table itself to represent nil */  sethvalue(fs->L, &k, fs->h);  return addk(fs, &k, &v);}void luaK_setreturns (FuncState *fs, expdesc *e, int nresults) {  if (e->k == VCALL) {  /* expression is an open function call? */    SETARG_C(getcode(fs, e), nresults+1);  }  else if (e->k == VVARARG) {    SETARG_B(getcode(fs, e), nresults+1);    SETARG_A(getcode(fs, e), fs->freereg);    luaK_reserveregs(fs, 1);  }}void luaK_setoneret (FuncState *fs, expdesc *e) {  if (e->k == VCALL) {  /* expression is an open function call? */    e->k = VNONRELOC;    e->u.s.info = GETARG_A(getcode(fs, e));  }  else if (e->k == VVARARG) {    SETARG_B(getcode(fs, e), 2);    e->k = VRELOCABLE;  /* can relocate its simple result */  }}void luaK_dischargevars (FuncState *fs, expdesc *e) {  switch (e->k) {    case VLOCAL: {      e->k = VNONRELOC;      break;    }    case VUPVAL: {      e->u.s.info = luaK_codeABC(fs, OP_GETUPVAL, 0, e->u.s.info, 0);      e->k = VRELOCABLE;      break;    }    case VGLOBAL: {      e->u.s.info = luaK_codeABx(fs, OP_GETGLOBAL, 0, e->u.s.info);      e->k = VRELOCABLE;      break;    }    case VINDEXED: {      freereg(fs, e->u.s.aux);      freereg(fs, e->u.s.info);      e->u.s.info = luaK_codeABC(fs, OP_GETTABLE, 0, e->u.s.info, e->u.s.aux);      e->k = VRELOCABLE;      break;    }    case VVARARG:    case VCALL: {      luaK_setoneret(fs, e);      break;    }    default: break;  /* there is one value available (somewhere) */  }}static int code_label (FuncState *fs, int A, int b, int jump) {  luaK_getlabel(fs);  /* those instructions may be jump targets */  return luaK_codeABC(fs, OP_LOADBOOL, A, b, jump);}static void discharge2reg (FuncState *fs, expdesc *e, int reg) {  luaK_dischargevars(fs, e);  switch (e->k) {    case VNIL: {      luaK_nil(fs, reg, 1);      break;    }    case VFALSE:  case VTRUE: {      luaK_codeABC(fs, OP_LOADBOOL, reg, e->k == VTRUE, 0);      break;    }    case VK: {      luaK_codeABx(fs, OP_LOADK, reg, e->u.s.info);      break;    }    case VKNUM: {      luaK_codeABx(fs, OP_LOADK, reg, luaK_numberK(fs, e->u.nval));      break;    }    case VRELOCABLE: {      Instruction *pc = &getcode(fs, e);      SETARG_A(*pc, reg);      break;    }    case VNONRELOC: {      if (reg != e->u.s.info)        luaK_codeABC(fs, OP_MOVE, reg, e->u.s.info, 0);      break;    }    default: {      lua_assert(e->k == VVOID || e->k == VJMP);      return;  /* nothing to do... */    }  }  e->u.s.info = reg;  e->k = VNONRELOC;}static void discharge2anyreg (FuncState *fs, expdesc *e) {  if (e->k != VNONRELOC) {    luaK_reserveregs(fs, 1);    discharge2reg(fs, e, fs->freereg-1);  }}static void exp2reg (FuncState *fs, expdesc *e, int reg) {  discharge2reg(fs, e, reg);  if (e->k == VJMP)    luaK_concat(fs, &e->t, e->u.s.info);  /* put this jump in `t' list */  if (hasjumps(e)) {    int final;  /* position after whole expression */    int p_f = NO_JUMP;  /* position of an eventual LOAD false */    int p_t = NO_JUMP;  /* position of an eventual LOAD true */    if (need_value(fs, e->t) || need_value(fs, e->f)) {      int fj = (e->k == VJMP) ? NO_JUMP : luaK_jump(fs);      p_f = code_label(fs, reg, 0, 1);      p_t = code_label(fs, reg, 1, 0);      luaK_patchtohere(fs, fj);    }    final = luaK_getlabel(fs);    patchlistaux(fs, e->f, final, reg, p_f);    patchlistaux(fs, e->t, final, reg, p_t);  }  e->f = e->t = NO_JUMP;  e->u.s.info = reg;  e->k = VNONRELOC;}void luaK_exp2nextreg (FuncState *fs, expdesc *e) {  luaK_dischargevars(fs, e);  freeexp(fs, e);  luaK_reserveregs(fs, 1);  exp2reg(fs, e, fs->freereg - 1);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本二三区不卡| 欧美色偷偷大香| 欧美精品一区二区三区一线天视频| 免费成人深夜小野草| 久久精品夜夜夜夜久久| 91在线云播放| 日本免费新一区视频| 久久久久久久久久久电影| 93久久精品日日躁夜夜躁欧美| 国产精品18久久久久久久久 | 久久众筹精品私拍模特| www.亚洲人| 日韩在线a电影| 欧美韩国日本一区| 91麻豆精品91久久久久同性| 国产激情视频一区二区在线观看 | 欧美男女性生活在线直播观看| 美国欧美日韩国产在线播放| 亚洲视频在线观看一区| 精品少妇一区二区三区免费观看| 一本色道久久加勒比精品| 麻豆精品一区二区三区| 老汉av免费一区二区三区 | 91玉足脚交白嫩脚丫在线播放| 亚洲一二三四在线观看| 久久久精品黄色| 欧美国产精品中文字幕| 亚洲综合在线视频| 国产精品素人一区二区| 精品粉嫩超白一线天av| 日本一区二区三区国色天香| 久久免费午夜影院| 亚洲免费资源在线播放| 欧美激情在线观看视频免费| 亚洲另类春色校园小说| 国产精品久久久久久久久免费丝袜 | 免费成人在线视频观看| 国产伦精品一区二区三区在线观看 | 国产网站一区二区| 亚洲欧美欧美一区二区三区| 日本亚洲三级在线| 99久久久国产精品免费蜜臀| 日韩一区二区精品| 日韩午夜在线观看视频| 国产精品福利av| 久久97超碰色| 国产成人综合在线播放| 欧美日韩精品二区第二页| 中文字幕高清一区| 日本欧美久久久久免费播放网| www.色综合.com| 精品国产一区二区国模嫣然| 亚洲主播在线观看| 成人美女视频在线看| 成人黄动漫网站免费app| 丁香六月久久综合狠狠色| 欧美日韩一区二区在线观看视频| 国产精品女人毛片| 久久不见久久见中文字幕免费| 欧美中文字幕亚洲一区二区va在线| 欧美日韩不卡在线| 日韩理论电影院| 丰满放荡岳乱妇91ww| 色婷婷av一区二区三区之一色屋| 久久久精品国产免费观看同学| 亚洲成人一区二区在线观看| 久久av老司机精品网站导航| 欧美揉bbbbb揉bbbbb| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 精品一区二区三区在线观看| 8x8x8国产精品| 夜夜嗨av一区二区三区四季av| 成人av资源网站| 国产精品视频一二三区| 国产不卡视频在线播放| 久久久噜噜噜久久中文字幕色伊伊 | 日韩免费高清电影| 中文字幕欧美日韩一区| 久久不见久久见免费视频7| 91精品国产综合久久久蜜臀图片 | 国产免费观看久久| 国产黄色91视频| 久久久久88色偷偷免费| 国产精品18久久久久久久网站| 久久久精品中文字幕麻豆发布| 激情成人午夜视频| 日本韩国视频一区二区| 亚洲色图欧美偷拍| 在线看日本不卡| 亚洲午夜电影网| 国产成人在线看| 久久精品人人做人人综合 | 中文字幕精品三区| av午夜精品一区二区三区| 中文字幕一区三区| 狠狠色狠狠色综合日日91app| 日韩欧美在线网站| 国产成人精品三级| 亚洲美女免费在线| 欧美久久久久久久久中文字幕| 日本一区二区三区国色天香| eeuss鲁片一区二区三区在线观看| 亚洲日本中文字幕区| 欧美日韩在线三区| 久久99精品久久久| 国产精品久久久久婷婷| 色天使色偷偷av一区二区| 视频一区国产视频| 国产日韩欧美不卡| 欧美午夜精品理论片a级按摩| 国产精品日日摸夜夜摸av| 欧美制服丝袜第一页| 久草中文综合在线| 亚洲欧美一区二区三区国产精品| 欧美日韩中文另类| 成人自拍视频在线观看| 亚洲国产精品久久一线不卡| 久久众筹精品私拍模特| 91久久香蕉国产日韩欧美9色| 七七婷婷婷婷精品国产| 亚洲欧洲成人自拍| 日韩视频免费观看高清完整版 | 精品国产一区久久| 色婷婷综合久久久中文一区二区 | av在线一区二区三区| 日韩av一区二区在线影视| 国产精品乱人伦中文| 日韩欧美综合一区| 欧美在线观看视频一区二区 | 亚洲精品一二三| 337p日本欧洲亚洲大胆精品| 在线精品视频一区二区| 懂色av一区二区三区免费观看| 日韩二区在线观看| 一区二区三区欧美日| 国产日韩欧美综合在线| 日韩精品中午字幕| 宅男在线国产精品| 欧美日韩精品一区二区| 91丨国产丨九色丨pron| 国产激情一区二区三区| 精品亚洲国内自在自线福利| 午夜日韩在线电影| 26uuu欧美| 欧美第一区第二区| 欧美肥妇free| 欧美中文字幕不卡| 欧美视频在线观看一区| 99久久国产综合精品色伊| 国产成人在线视频播放| 国产激情偷乱视频一区二区三区 | 久久久久久99精品| 久久综合资源网| 久久午夜老司机| 久久久久99精品一区| 国产色综合一区| 中文字幕欧美激情一区| 亚洲国产精品传媒在线观看| 国产欧美日韩综合精品一区二区 | 一本一道久久a久久精品| 成人午夜伦理影院| 99久久久久免费精品国产| a级高清视频欧美日韩| av在线播放成人| 色婷婷精品大在线视频| 欧美三级电影网| 日韩一区二区三区在线观看| 91精品婷婷国产综合久久| 日韩免费在线观看| 久久久久久久精| 18成人在线观看| 午夜精品久久久久影视| 日本午夜一区二区| 国产a区久久久| 91首页免费视频| 欧美一区二区网站| 99久久久精品免费观看国产蜜| 95精品视频在线| 欧美电影一区二区| 久久久久久久久久久黄色| 中文字幕日韩一区二区| 亚洲成人免费视频| 狠狠色综合播放一区二区| 色综合久久久久综合体| 欧美精品第1页| 国产女主播视频一区二区| 亚洲午夜久久久久久久久久久| 日韩高清不卡一区二区三区| 国产一区二区电影| 欧洲av在线精品| 精品久久一二三区| 亚洲欧美日韩国产一区二区三区| 亚洲成人免费视| 成人免费视频视频在线观看免费 | 日韩国产欧美在线观看| 成人精品鲁一区一区二区| 欧美日韩视频在线第一区 | 亚洲电影视频在线| 国产a区久久久| 91精品国产一区二区三区|