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

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

?? ldebug.c

?? 這個是一個嵌入式腳本支持引擎, 體積十分小巧
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*** $Id: ldebug.c,v 2.29.1.6 2008/05/08 16:56:26 roberto Exp $** Debug Interface** See Copyright Notice in lua.h*/#include <stdarg.h>#include <stddef.h>#include <string.h>#define ldebug_c#define LUA_CORE#include "lua.h"#include "lapi.h"#include "lcode.h"#include "ldebug.h"#include "ldo.h"#include "lfunc.h"#include "lobject.h"#include "lopcodes.h"#include "lstate.h"#include "lstring.h"#include "ltable.h"#include "ltm.h"#include "lvm.h"static const char *getfuncname (lua_State *L, CallInfo *ci, const char **name);static int currentpc (lua_State *L, CallInfo *ci) {  if (!isLua(ci)) return -1;  /* function is not a Lua function? */  if (ci == L->ci)    ci->savedpc = L->savedpc;  return pcRel(ci->savedpc, ci_func(ci)->l.p);}static int currentline (lua_State *L, CallInfo *ci) {  int pc = currentpc(L, ci);  if (pc < 0)    return -1;  /* only active lua functions have current-line information */  else    return getline(ci_func(ci)->l.p, pc);}/*** this function can be called asynchronous (e.g. during a signal)*/LUA_API int lua_sethook (lua_State *L, lua_Hook func, int mask, int count) {  if (func == NULL || mask == 0) {  /* turn off hooks? */    mask = 0;    func = NULL;  }  L->hook = func;  L->basehookcount = count;  resethookcount(L);  L->hookmask = cast_byte(mask);  return 1;}LUA_API lua_Hook lua_gethook (lua_State *L) {  return L->hook;}LUA_API int lua_gethookmask (lua_State *L) {  return L->hookmask;}LUA_API int lua_gethookcount (lua_State *L) {  return L->basehookcount;}LUA_API int lua_getstack (lua_State *L, int level, lua_Debug *ar) {  int status;  CallInfo *ci;  lua_lock(L);  for (ci = L->ci; level > 0 && ci > L->base_ci; ci--) {    level--;    if (f_isLua(ci))  /* Lua function? */      level -= ci->tailcalls;  /* skip lost tail calls */  }  if (level == 0 && ci > L->base_ci) {  /* level found? */    status = 1;    ar->i_ci = cast_int(ci - L->base_ci);  }  else if (level < 0) {  /* level is of a lost tail call? */    status = 1;    ar->i_ci = 0;  }  else status = 0;  /* no such level */  lua_unlock(L);  return status;}static Proto *getluaproto (CallInfo *ci) {  return (isLua(ci) ? ci_func(ci)->l.p : NULL);}static const char *findlocal (lua_State *L, CallInfo *ci, int n) {  const char *name;  Proto *fp = getluaproto(ci);  if (fp && (name = luaF_getlocalname(fp, n, currentpc(L, ci))) != NULL)    return name;  /* is a local variable in a Lua function */  else {    StkId limit = (ci == L->ci) ? L->top : (ci+1)->func;    if (limit - ci->base >= n && n > 0)  /* is 'n' inside 'ci' stack? */      return "(*temporary)";    else      return NULL;  }}LUA_API const char *lua_getlocal (lua_State *L, const lua_Debug *ar, int n) {  CallInfo *ci = L->base_ci + ar->i_ci;  const char *name = findlocal(L, ci, n);  lua_lock(L);  if (name)      luaA_pushobject(L, ci->base + (n - 1));  lua_unlock(L);  return name;}LUA_API const char *lua_setlocal (lua_State *L, const lua_Debug *ar, int n) {  CallInfo *ci = L->base_ci + ar->i_ci;  const char *name = findlocal(L, ci, n);  lua_lock(L);  if (name)      setobjs2s(L, ci->base + (n - 1), L->top - 1);  L->top--;  /* pop value */  lua_unlock(L);  return name;}static void funcinfo (lua_Debug *ar, Closure *cl) {  if (cl->c.isC) {    ar->source = "=[C]";    ar->linedefined = -1;    ar->lastlinedefined = -1;    ar->what = "C";  }  else {    ar->source = getstr(cl->l.p->source);    ar->linedefined = cl->l.p->linedefined;    ar->lastlinedefined = cl->l.p->lastlinedefined;    ar->what = (ar->linedefined == 0) ? "main" : "Lua";  }  luaO_chunkid(ar->short_src, ar->source, LUA_IDSIZE);}static void info_tailcall (lua_Debug *ar) {  ar->name = ar->namewhat = "";  ar->what = "tail";  ar->lastlinedefined = ar->linedefined = ar->currentline = -1;  ar->source = "=(tail call)";  luaO_chunkid(ar->short_src, ar->source, LUA_IDSIZE);  ar->nups = 0;}static void collectvalidlines (lua_State *L, Closure *f) {  if (f == NULL || f->c.isC) {    setnilvalue(L->top);  }  else {    Table *t = luaH_new(L, 0, 0);    int *lineinfo = f->l.p->lineinfo;    int i;    for (i=0; i<f->l.p->sizelineinfo; i++)      setbvalue(luaH_setnum(L, t, lineinfo[i]), 1);    sethvalue(L, L->top, t);   }  incr_top(L);}static int auxgetinfo (lua_State *L, const char *what, lua_Debug *ar,                    Closure *f, CallInfo *ci) {  int status = 1;  if (f == NULL) {    info_tailcall(ar);    return status;  }  for (; *what; what++) {    switch (*what) {      case 'S': {        funcinfo(ar, f);        break;      }      case 'l': {        ar->currentline = (ci) ? currentline(L, ci) : -1;        break;      }      case 'u': {        ar->nups = f->c.nupvalues;        break;      }      case 'n': {        ar->namewhat = (ci) ? getfuncname(L, ci, &ar->name) : NULL;        if (ar->namewhat == NULL) {          ar->namewhat = "";  /* not found */          ar->name = NULL;        }        break;      }      case 'L':      case 'f':  /* handled by lua_getinfo */        break;      default: status = 0;  /* invalid option */    }  }  return status;}LUA_API int lua_getinfo (lua_State *L, const char *what, lua_Debug *ar) {  int status;  Closure *f = NULL;  CallInfo *ci = NULL;  lua_lock(L);  if (*what == '>') {    StkId func = L->top - 1;    luai_apicheck(L, ttisfunction(func));    what++;  /* skip the '>' */    f = clvalue(func);    L->top--;  /* pop function */  }  else if (ar->i_ci != 0) {  /* no tail call? */    ci = L->base_ci + ar->i_ci;    lua_assert(ttisfunction(ci->func));    f = clvalue(ci->func);  }  status = auxgetinfo(L, what, ar, f, ci);  if (strchr(what, 'f')) {    if (f == NULL) setnilvalue(L->top);    else setclvalue(L, L->top, f);    incr_top(L);  }  if (strchr(what, 'L'))    collectvalidlines(L, f);  lua_unlock(L);  return status;}/*** {======================================================** Symbolic Execution and code checker** =======================================================*/#define check(x)		if (!(x)) return 0;#define checkjump(pt,pc)	check(0 <= pc && pc < pt->sizecode)#define checkreg(pt,reg)	check((reg) < (pt)->maxstacksize)static int precheck (const Proto *pt) {  check(pt->maxstacksize <= MAXSTACK);  check(pt->numparams+(pt->is_vararg & VARARG_HASARG) <= pt->maxstacksize);  check(!(pt->is_vararg & VARARG_NEEDSARG) ||              (pt->is_vararg & VARARG_HASARG));  check(pt->sizeupvalues <= pt->nups);  check(pt->sizelineinfo == pt->sizecode || pt->sizelineinfo == 0);  check(pt->sizecode > 0 && GET_OPCODE(pt->code[pt->sizecode-1]) == OP_RETURN);  return 1;}#define checkopenop(pt,pc)	luaG_checkopenop((pt)->code[(pc)+1])int luaG_checkopenop (Instruction i) {  switch (GET_OPCODE(i)) {    case OP_CALL:    case OP_TAILCALL:    case OP_RETURN:    case OP_SETLIST: {      check(GETARG_B(i) == 0);      return 1;    }    default: return 0;  /* invalid instruction after an open call */  }}static int checkArgMode (const Proto *pt, int r, enum OpArgMask mode) {  switch (mode) {    case OpArgN: check(r == 0); break;    case OpArgU: break;    case OpArgR: checkreg(pt, r); break;    case OpArgK:      check(ISK(r) ? INDEXK(r) < pt->sizek : r < pt->maxstacksize);      break;  }  return 1;}static Instruction symbexec (const Proto *pt, int lastpc, int reg) {  int pc;  int last;  /* stores position of last instruction that changed `reg' */  last = pt->sizecode-1;  /* points to final return (a `neutral' instruction) */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美一区在线观看| 一区二区三区不卡在线观看| 日韩精品一区二区三区视频播放 | 91原创在线视频| 成人一区二区三区视频| 国产精品66部| 东方欧美亚洲色图在线| 成人av网在线| 色综合中文综合网| 中文字幕av一区二区三区免费看| 久久精品在线免费观看| 国产日韩亚洲欧美综合| 国产精品私人自拍| 亚洲精品中文字幕在线观看| 亚洲午夜精品网| 日本少妇一区二区| 激情综合色播五月| 国产精品99久久久| 99久久精品免费| 欧洲精品在线观看| 91麻豆精品国产91久久久资源速度 | 亚洲综合在线免费观看| 亚洲国产sm捆绑调教视频| 亚洲资源在线观看| 午夜免费欧美电影| 久久99精品一区二区三区| 国产精品中文字幕一区二区三区| www.欧美日韩| 中文字幕在线一区二区三区| 欧美激情一区二区三区全黄| 国产精品福利在线播放| 国产精品一卡二卡| 成人91在线观看| 欧美日韩视频在线观看一区二区三区 | 精品一区二区在线观看| 国产成人av资源| 在线观看一区二区视频| 欧美日韩国产a| 国产精品美女久久久久aⅴ| 欧美亚一区二区| 91精品国产综合久久福利| 久久综合色婷婷| 亚洲免费观看高清完整版在线| 午夜精品久久久久久久蜜桃app| 久久av老司机精品网站导航| 97se亚洲国产综合自在线| 51精品国自产在线| 亚洲欧洲国产日本综合| 日本va欧美va精品发布| 成人av小说网| 欧美tk丨vk视频| 中文字幕一区在线观看视频| 欧美96一区二区免费视频| a4yy欧美一区二区三区| 精品乱人伦小说| 一区二区视频在线| 极品尤物av久久免费看| 欧美午夜精品久久久| 久久久激情视频| 日韩不卡一区二区| 91麻豆免费在线观看| 欧美mv和日韩mv国产网站| 一区二区三区在线免费视频| 韩国一区二区三区| 欧美精品 国产精品| 国产精品久久久爽爽爽麻豆色哟哟| 日韩精品一二三四| 97久久久精品综合88久久| 精品精品国产高清a毛片牛牛| 亚洲中国最大av网站| 成人在线综合网| 日韩视频一区二区| 亚洲国产日韩a在线播放| 成年人午夜久久久| 久久久久久9999| 蜜桃久久av一区| 欧美日韩在线播放| 亚洲精品免费电影| 97精品视频在线观看自产线路二| 久久久久久**毛片大全| 久久精品国产亚洲aⅴ| 欧美日韩免费高清一区色橹橹 | 国产在线一区二区| 91.xcao| 亚洲一区二区三区影院| 91欧美一区二区| 中文字幕一区二区三区四区不卡| 国产麻豆成人精品| 精品久久久久香蕉网| 捆绑紧缚一区二区三区视频| 在线播放亚洲一区| 五月婷婷欧美视频| 欧美日韩免费观看一区二区三区 | 一道本成人在线| 自拍偷拍欧美精品| 99视频精品在线| 国产精品第一页第二页第三页 | 欧美国产97人人爽人人喊| 国产美女在线精品| ww久久中文字幕| 国产精一品亚洲二区在线视频| 亚洲精品一区二区在线观看| 韩国毛片一区二区三区| 久久久三级国产网站| 成人综合婷婷国产精品久久| 国产精品国产三级国产普通话蜜臀 | 亚洲成人自拍偷拍| 99精品久久只有精品| 国产精品视频一区二区三区不卡| 国产成人精品影院| 国产精品色哟哟| av中文字幕不卡| 自拍偷拍国产精品| 欧美综合一区二区三区| 亚洲成av人影院在线观看网| 欧美一区二区视频在线观看2022| 久久国内精品自在自线400部| 亚洲精品一区二区三区福利| 国产成人综合在线观看| 国产精品久久久久影院| 色狠狠一区二区三区香蕉| 亚洲国产欧美一区二区三区丁香婷| 7777女厕盗摄久久久| 麻豆国产精品官网| 欧美激情一区二区三区全黄| 91视频在线看| 视频一区在线播放| 欧美精品一区二区在线观看| 成人动漫视频在线| 亚洲一二三专区| 日韩精品一区二区三区swag| 国产成人在线影院 | 成人网页在线观看| 亚洲欧美日韩在线不卡| 欧美日本国产一区| 国产专区综合网| 亚洲精品国产精华液| 日韩一区二区三区视频在线| 国产精品99久久久久久宅男| 亚洲精品成人少妇| 日韩一区二区麻豆国产| 国产91在线看| 五月综合激情日本mⅴ| 国产色产综合色产在线视频| 91久久人澡人人添人人爽欧美| 青娱乐精品视频| 18成人在线观看| 日韩欧美成人激情| 99国产精品视频免费观看| 首页国产丝袜综合| 亚洲欧洲韩国日本视频| 日韩欧美亚洲国产另类| 成人动漫av在线| 麻豆成人免费电影| 亚洲裸体xxx| 久久婷婷国产综合国色天香| 91激情在线视频| 国产乱子伦视频一区二区三区| 一区二区三区国产| 国产性天天综合网| 欧美日韩精品一区二区在线播放| 国产成人免费在线观看不卡| 亚洲电影第三页| 国产精品久久久久国产精品日日| 日韩欧美第一区| 欧美性感一类影片在线播放| 高清国产一区二区| 麻豆成人久久精品二区三区小说| 亚洲最新在线观看| 18涩涩午夜精品.www| 久久亚洲二区三区| 欧美精品在欧美一区二区少妇| av在线播放不卡| 国产一二精品视频| 视频一区二区三区入口| 亚洲欧洲制服丝袜| 欧美激情综合五月色丁香小说| 欧美v国产在线一区二区三区| 欧美日韩一区二区三区四区五区| proumb性欧美在线观看| 国产剧情一区二区| 紧缚奴在线一区二区三区| 日韩精品欧美成人高清一区二区| 亚洲欧洲美洲综合色网| 国产欧美久久久精品影院| 精品少妇一区二区三区在线播放 | 欧美性猛片aaaaaaa做受| 99久久精品国产观看| 国产不卡视频在线播放| 精品在线免费视频| 蜜桃一区二区三区在线| 性欧美大战久久久久久久久| 亚洲精品免费视频| 中文字幕欧美激情| 国产欧美日韩综合| 久久久久久久网| 久久精品视频一区二区| 精品久久一二三区| 精品美女在线播放| 久久久久久综合|