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

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

?? liolib.c

?? 這個是一個嵌入式腳本支持引擎, 體積十分小巧
?? C
字號:
/*** $Id: liolib.c,v 2.73.1.3 2008/01/18 17:47:43 roberto Exp $** Standard I/O (and system) library** See Copyright Notice in lua.h*/#include <errno.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#define liolib_c#define LUA_LIB#include "lua.h"#include "lauxlib.h"#include "lualib.h"#define IO_INPUT	1#define IO_OUTPUT	2static const char *const fnames[] = {"input", "output"};static int pushresult (lua_State *L, int i, const char *filename) {  int en = errno;  /* calls to Lua API may change this value */  if (i) {    lua_pushboolean(L, 1);    return 1;  }  else {    lua_pushnil(L);    if (filename)      lua_pushfstring(L, "%s: %s", filename, strerror(en));    else      lua_pushfstring(L, "%s", strerror(en));    lua_pushinteger(L, en);    return 3;  }}static void fileerror (lua_State *L, int arg, const char *filename) {  lua_pushfstring(L, "%s: %s", filename, strerror(errno));  luaL_argerror(L, arg, lua_tostring(L, -1));}#define tofilep(L)	((FILE **)luaL_checkudata(L, 1, LUA_FILEHANDLE))static int io_type (lua_State *L) {  void *ud;  luaL_checkany(L, 1);  ud = lua_touserdata(L, 1);  lua_getfield(L, LUA_REGISTRYINDEX, LUA_FILEHANDLE);  if (ud == NULL || !lua_getmetatable(L, 1) || !lua_rawequal(L, -2, -1))    lua_pushnil(L);  /* not a file */  else if (*((FILE **)ud) == NULL)    lua_pushliteral(L, "closed file");  else    lua_pushliteral(L, "file");  return 1;}static FILE *tofile (lua_State *L) {  FILE **f = tofilep(L);  if (*f == NULL)    luaL_error(L, "attempt to use a closed file");  return *f;}/*** When creating file handles, always creates a `closed' file handle** before opening the actual file; so, if there is a memory error, the** file is not left opened.*/static FILE **newfile (lua_State *L) {  FILE **pf = (FILE **)lua_newuserdata(L, sizeof(FILE *));  *pf = NULL;  /* file handle is currently `closed' */  luaL_getmetatable(L, LUA_FILEHANDLE);  lua_setmetatable(L, -2);  return pf;}/*** function to (not) close the standard files stdin, stdout, and stderr*/static int io_noclose (lua_State *L) {  lua_pushnil(L);  lua_pushliteral(L, "cannot close standard file");  return 2;}/*** function to close 'popen' files*/static int io_pclose (lua_State *L) {  FILE **p = tofilep(L);  int ok = lua_pclose(L, *p);  *p = NULL;  return pushresult(L, ok, NULL);}/*** function to close regular files*/static int io_fclose (lua_State *L) {  FILE **p = tofilep(L);  int ok = (fclose(*p) == 0);  *p = NULL;  return pushresult(L, ok, NULL);}static int aux_close (lua_State *L) {  lua_getfenv(L, 1);  lua_getfield(L, -1, "__close");  return (lua_tocfunction(L, -1))(L);}static int io_close (lua_State *L) {  if (lua_isnone(L, 1))    lua_rawgeti(L, LUA_ENVIRONINDEX, IO_OUTPUT);  tofile(L);  /* make sure argument is a file */  return aux_close(L);}static int io_gc (lua_State *L) {  FILE *f = *tofilep(L);  /* ignore closed files */  if (f != NULL)    aux_close(L);  return 0;}static int io_tostring (lua_State *L) {  FILE *f = *tofilep(L);  if (f == NULL)    lua_pushliteral(L, "file (closed)");  else    lua_pushfstring(L, "file (%p)", f);  return 1;}static int io_open (lua_State *L) {  const char *filename = luaL_checkstring(L, 1);  const char *mode = luaL_optstring(L, 2, "r");  FILE **pf = newfile(L);  *pf = fopen(filename, mode);  return (*pf == NULL) ? pushresult(L, 0, filename) : 1;}/*** this function has a separated environment, which defines the** correct __close for 'popen' files*/static int io_popen (lua_State *L) {  const char *filename = luaL_checkstring(L, 1);  const char *mode = luaL_optstring(L, 2, "r");  FILE **pf = newfile(L);  *pf = lua_popen(L, filename, mode);  return (*pf == NULL) ? pushresult(L, 0, filename) : 1;}static int io_tmpfile (lua_State *L) {  FILE **pf = newfile(L);  *pf = tmpfile();  return (*pf == NULL) ? pushresult(L, 0, NULL) : 1;}static FILE *getiofile (lua_State *L, int findex) {  FILE *f;  lua_rawgeti(L, LUA_ENVIRONINDEX, findex);  f = *(FILE **)lua_touserdata(L, -1);  if (f == NULL)    luaL_error(L, "standard %s file is closed", fnames[findex - 1]);  return f;}static int g_iofile (lua_State *L, int f, const char *mode) {  if (!lua_isnoneornil(L, 1)) {    const char *filename = lua_tostring(L, 1);    if (filename) {      FILE **pf = newfile(L);      *pf = fopen(filename, mode);      if (*pf == NULL)        fileerror(L, 1, filename);    }    else {      tofile(L);  /* check that it's a valid file handle */      lua_pushvalue(L, 1);    }    lua_rawseti(L, LUA_ENVIRONINDEX, f);  }  /* return current value */  lua_rawgeti(L, LUA_ENVIRONINDEX, f);  return 1;}static int io_input (lua_State *L) {  return g_iofile(L, IO_INPUT, "r");}static int io_output (lua_State *L) {  return g_iofile(L, IO_OUTPUT, "w");}static int io_readline (lua_State *L);static void aux_lines (lua_State *L, int idx, int toclose) {  lua_pushvalue(L, idx);  lua_pushboolean(L, toclose);  /* close/not close file when finished */  lua_pushcclosure(L, io_readline, 2);}static int f_lines (lua_State *L) {  tofile(L);  /* check that it's a valid file handle */  aux_lines(L, 1, 0);  return 1;}static int io_lines (lua_State *L) {  if (lua_isnoneornil(L, 1)) {  /* no arguments? */    /* will iterate over default input */    lua_rawgeti(L, LUA_ENVIRONINDEX, IO_INPUT);    return f_lines(L);  }  else {    const char *filename = luaL_checkstring(L, 1);    FILE **pf = newfile(L);    *pf = fopen(filename, "r");    if (*pf == NULL)      fileerror(L, 1, filename);    aux_lines(L, lua_gettop(L), 1);    return 1;  }}/*** {======================================================** READ** =======================================================*/static int read_number (lua_State *L, FILE *f) {  lua_Number d;  if (fscanf(f, LUA_NUMBER_SCAN, &d) == 1) {    lua_pushnumber(L, d);    return 1;  }  else return 0;  /* read fails */}static int test_eof (lua_State *L, FILE *f) {  int c = getc(f);  ungetc(c, f);  lua_pushlstring(L, NULL, 0);  return (c != EOF);}static int read_line (lua_State *L, FILE *f) {  luaL_Buffer b;  luaL_buffinit(L, &b);  for (;;) {    size_t l;    char *p = luaL_prepbuffer(&b);    if (fgets(p, LUAL_BUFFERSIZE, f) == NULL) {  /* eof? */      luaL_pushresult(&b);  /* close buffer */      return (lua_objlen(L, -1) > 0);  /* check whether read something */    }    l = strlen(p);    if (l == 0 || p[l-1] != '\n')      luaL_addsize(&b, l);    else {      luaL_addsize(&b, l - 1);  /* do not include `eol' */      luaL_pushresult(&b);  /* close buffer */      return 1;  /* read at least an `eol' */    }  }}static int read_chars (lua_State *L, FILE *f, size_t n) {  size_t rlen;  /* how much to read */  size_t nr;  /* number of chars actually read */  luaL_Buffer b;  luaL_buffinit(L, &b);  rlen = LUAL_BUFFERSIZE;  /* try to read that much each time */  do {    char *p = luaL_prepbuffer(&b);    if (rlen > n) rlen = n;  /* cannot read more than asked */    nr = fread(p, sizeof(char), rlen, f);    luaL_addsize(&b, nr);    n -= nr;  /* still have to read `n' chars */  } while (n > 0 && nr == rlen);  /* until end of count or eof */  luaL_pushresult(&b);  /* close buffer */  return (n == 0 || lua_objlen(L, -1) > 0);}static int g_read (lua_State *L, FILE *f, int first) {  int nargs = lua_gettop(L) - 1;  int success;  int n;  clearerr(f);  if (nargs == 0) {  /* no arguments? */    success = read_line(L, f);    n = first+1;  /* to return 1 result */  }  else {  /* ensure stack space for all results and for auxlib's buffer */    luaL_checkstack(L, nargs+LUA_MINSTACK, "too many arguments");    success = 1;    for (n = first; nargs-- && success; n++) {      if (lua_type(L, n) == LUA_TNUMBER) {        size_t l = (size_t)lua_tointeger(L, n);        success = (l == 0) ? test_eof(L, f) : read_chars(L, f, l);      }      else {        const char *p = lua_tostring(L, n);        luaL_argcheck(L, p && p[0] == '*', n, "invalid option");        switch (p[1]) {          case 'n':  /* number */            success = read_number(L, f);            break;          case 'l':  /* line */            success = read_line(L, f);            break;          case 'a':  /* file */            read_chars(L, f, ~((size_t)0));  /* read MAX_SIZE_T chars */            success = 1; /* always success */            break;          default:            return luaL_argerror(L, n, "invalid format");        }      }    }  }  if (ferror(f))    return pushresult(L, 0, NULL);  if (!success) {    lua_pop(L, 1);  /* remove last result */    lua_pushnil(L);  /* push nil instead */  }  return n - first;}static int io_read (lua_State *L) {  return g_read(L, getiofile(L, IO_INPUT), 1);}static int f_read (lua_State *L) {  return g_read(L, tofile(L), 2);}static int io_readline (lua_State *L) {  FILE *f = *(FILE **)lua_touserdata(L, lua_upvalueindex(1));  int sucess;  if (f == NULL)  /* file is already closed? */    luaL_error(L, "file is already closed");  sucess = read_line(L, f);  if (ferror(f))    return luaL_error(L, "%s", strerror(errno));  if (sucess) return 1;  else {  /* EOF */    if (lua_toboolean(L, lua_upvalueindex(2))) {  /* generator created file? */      lua_settop(L, 0);      lua_pushvalue(L, lua_upvalueindex(1));      aux_close(L);  /* close it */    }    return 0;  }}/* }====================================================== */static int g_write (lua_State *L, FILE *f, int arg) {  int nargs = lua_gettop(L) - 1;  int status = 1;  for (; nargs--; arg++) {    if (lua_type(L, arg) == LUA_TNUMBER) {      /* optimization: could be done exactly as for strings */      status = status &&          fprintf(f, LUA_NUMBER_FMT, lua_tonumber(L, arg)) > 0;    }    else {      size_t l;      const char *s = luaL_checklstring(L, arg, &l);      status = status && (fwrite(s, sizeof(char), l, f) == l);    }  }  return pushresult(L, status, NULL);}static int io_write (lua_State *L) {  return g_write(L, getiofile(L, IO_OUTPUT), 1);}static int f_write (lua_State *L) {  return g_write(L, tofile(L), 2);}static int f_seek (lua_State *L) {  static const int mode[] = {SEEK_SET, SEEK_CUR, SEEK_END};  static const char *const modenames[] = {"set", "cur", "end", NULL};  FILE *f = tofile(L);  int op = luaL_checkoption(L, 2, "cur", modenames);  long offset = luaL_optlong(L, 3, 0);  op = fseek(f, offset, mode[op]);  if (op)    return pushresult(L, 0, NULL);  /* error */  else {    lua_pushinteger(L, ftell(f));    return 1;  }}static int f_setvbuf (lua_State *L) {  static const int mode[] = {_IONBF, _IOFBF, _IOLBF};  static const char *const modenames[] = {"no", "full", "line", NULL};  FILE *f = tofile(L);  int op = luaL_checkoption(L, 2, NULL, modenames);  lua_Integer sz = luaL_optinteger(L, 3, LUAL_BUFFERSIZE);  int res = setvbuf(f, NULL, mode[op], sz);  return pushresult(L, res == 0, NULL);}static int io_flush (lua_State *L) {  return pushresult(L, fflush(getiofile(L, IO_OUTPUT)) == 0, NULL);}static int f_flush (lua_State *L) {  return pushresult(L, fflush(tofile(L)) == 0, NULL);}static const luaL_Reg iolib[] = {  {"close", io_close},  {"flush", io_flush},  {"input", io_input},  {"lines", io_lines},  {"open", io_open},  {"output", io_output},  {"popen", io_popen},  {"read", io_read},  {"tmpfile", io_tmpfile},  {"type", io_type},  {"write", io_write},  {NULL, NULL}};static const luaL_Reg flib[] = {  {"close", io_close},  {"flush", f_flush},  {"lines", f_lines},  {"read", f_read},  {"seek", f_seek},  {"setvbuf", f_setvbuf},  {"write", f_write},  {"__gc", io_gc},  {"__tostring", io_tostring},  {NULL, NULL}};static void createmeta (lua_State *L) {  luaL_newmetatable(L, LUA_FILEHANDLE);  /* create metatable for file handles */  lua_pushvalue(L, -1);  /* push metatable */  lua_setfield(L, -2, "__index");  /* metatable.__index = metatable */  luaL_register(L, NULL, flib);  /* file methods */}static void createstdfile (lua_State *L, FILE *f, int k, const char *fname) {  *newfile(L) = f;  if (k > 0) {    lua_pushvalue(L, -1);    lua_rawseti(L, LUA_ENVIRONINDEX, k);  }  lua_pushvalue(L, -2);  /* copy environment */  lua_setfenv(L, -2);  /* set it */  lua_setfield(L, -3, fname);}static void newfenv (lua_State *L, lua_CFunction cls) {  lua_createtable(L, 0, 1);  lua_pushcfunction(L, cls);  lua_setfield(L, -2, "__close");}LUALIB_API int luaopen_io (lua_State *L) {  createmeta(L);  /* create (private) environment (with fields IO_INPUT, IO_OUTPUT, __close) */  newfenv(L, io_fclose);  lua_replace(L, LUA_ENVIRONINDEX);  /* open library */  luaL_register(L, LUA_IOLIBNAME, iolib);  /* create (and set) default files */  newfenv(L, io_noclose);  /* close function for default files */  createstdfile(L, stdin, IO_INPUT, "stdin");  createstdfile(L, stdout, IO_OUTPUT, "stdout");  createstdfile(L, stderr, 0, "stderr");  lua_pop(L, 1);  /* pop environment for default files */  lua_getfield(L, -1, "popen");  newfenv(L, io_pclose);  /* create environment for 'popen' */  lua_setfenv(L, -2);  /* set fenv for 'popen' */  lua_pop(L, 1);  /* pop 'popen' */  return 1;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美不卡视频一区| 国产校园另类小说区| 黄色精品一二区| 国产精品免费观看视频| 91精品福利在线一区二区三区 | 国产亚洲精品免费| 欧美中文字幕一区| 国产成人在线看| 免费一区二区视频| 午夜影院久久久| 国产精品乱码一区二三区小蝌蚪| 在线电影院国产精品| 99久久久久久| 国产做a爰片久久毛片| 亚洲风情在线资源站| 国产精品美女www爽爽爽| 精品国产不卡一区二区三区| 欧美系列亚洲系列| 成人激情电影免费在线观看| 韩国成人精品a∨在线观看| 三级亚洲高清视频| 亚洲综合在线第一页| 中文字幕高清不卡| 国产偷国产偷亚洲高清人白洁| 日韩一级片网址| 欧美卡1卡2卡| 欧美日韩中文精品| 91国产视频在线观看| 91看片淫黄大片一级在线观看| 丁香婷婷综合五月| 国产91在线观看| 国产一区福利在线| 极品少妇xxxx精品少妇偷拍 | 一区二区三区四区不卡在线 | 不卡的av在线播放| 国产美女一区二区| 激情另类小说区图片区视频区| 奇米综合一区二区三区精品视频| 日日夜夜免费精品视频| 亚洲大片精品永久免费| 亚洲国产中文字幕| 午夜在线成人av| 日本va欧美va欧美va精品| 日本在线观看不卡视频| 日韩电影在线一区二区三区| 日产国产欧美视频一区精品| 青青草国产精品亚洲专区无| 久久狠狠亚洲综合| 国模套图日韩精品一区二区| 国产乱人伦偷精品视频不卡| 国产大陆亚洲精品国产| yourporn久久国产精品| 97精品国产露脸对白| 日本福利一区二区| 欧美日韩国产大片| 日韩一区二区三区在线| 久久久美女毛片| 国产精品久久久久aaaa| 一区二区三区四区五区视频在线观看 | 久久综合色之久久综合| 久久欧美中文字幕| 国产精品狼人久久影院观看方式| 亚洲色图欧美激情| 亚洲国产精品视频| 精品一区二区国语对白| 成人网页在线观看| 91豆麻精品91久久久久久| 在线成人免费观看| 久久天堂av综合合色蜜桃网| 综合久久国产九一剧情麻豆| 午夜激情久久久| 国产在线观看一区二区| 99久久免费国产| 欧美丰满少妇xxxxx高潮对白| 精品久久久久久久久久久院品网 | 亚洲一区二区在线免费看| 日产欧产美韩系列久久99| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 久久综合av免费| 国产精品久久久久久久久免费樱桃 | 日韩精品欧美精品| 国产夫妻精品视频| 欧美色精品在线视频| 精品噜噜噜噜久久久久久久久试看| 欧美激情综合五月色丁香| 亚洲成av人影院在线观看网| 国产乱子轮精品视频| 欧美在线一二三四区| 久久午夜国产精品| 亚洲成在人线在线播放| 国产精品资源网| 欧美日本一道本| 国产精品麻豆网站| 美女久久久精品| 日本高清无吗v一区| 国产三级欧美三级日产三级99| 亚洲夂夂婷婷色拍ww47| 国产99精品视频| 日韩一级高清毛片| 亚洲影院理伦片| 国产盗摄女厕一区二区三区 | 亚洲色图制服诱惑| 久久精品国产第一区二区三区| 一本一本久久a久久精品综合麻豆| 日韩一区二区三区免费看| 黄一区二区三区| 欧美在线三级电影| 亚洲国产成人在线| 久久精品二区亚洲w码| 欧美性一级生活| 国产精品进线69影院| 国产在线精品一区二区三区不卡 | 国产精品日日摸夜夜摸av| 日本成人中文字幕在线视频| 在线免费观看日本一区| 国产精品久久久久影视| 国产一区二区在线观看免费| 欧美一区二区成人6969| 亚洲国产精品人人做人人爽| 欧美中文一区二区三区| 亚洲色图欧美偷拍| 99综合电影在线视频| 欧美精品一区二区三区很污很色的| 舔着乳尖日韩一区| 欧美性一级生活| 一区二区三区四区视频精品免费| 99久久精品99国产精品| 中文一区二区在线观看| 国产麻豆91精品| 精品国产一区二区三区av性色| 免费成人深夜小野草| 7777精品伊人久久久大香线蕉完整版| 亚洲最快最全在线视频| 一本色道久久综合精品竹菊| ...中文天堂在线一区| 99九九99九九九视频精品| 1024成人网色www| 91视频91自| 一区二区激情视频| 欧美主播一区二区三区| 亚洲一区二区三区在线看| 欧美日韩你懂得| 奇米综合一区二区三区精品视频| 欧美一区二区三区思思人| 日本免费在线视频不卡一不卡二| 日韩一区二区在线观看视频| 美国三级日本三级久久99 | 亚洲成人免费影院| 精品视频123区在线观看| 日韩中文字幕一区二区三区| 欧美日韩国产小视频| 免费观看91视频大全| 亚洲精品在线三区| 国产成人欧美日韩在线电影| 亚洲国产精品精华液ab| 95精品视频在线| 亚洲成人动漫精品| 欧美一级爆毛片| 国产福利精品导航| 亚洲精品国产视频| 欧美一级在线视频| 国产大陆a不卡| 亚洲视频一区二区免费在线观看| 99精品视频在线观看免费| 亚洲一区影音先锋| 日韩午夜在线观看视频| 国产福利一区二区三区视频在线| 国产精品电影院| 欧美日韩视频一区二区| 国内精品嫩模私拍在线| 午夜精品一区二区三区免费视频 | 中文字幕日韩一区二区| 在线中文字幕不卡| 亚洲福利视频一区| 国产午夜精品一区二区三区视频| 91麻豆视频网站| 日韩激情一二三区| 国产精品毛片大码女人| 538prom精品视频线放| 国产成人aaa| 亚瑟在线精品视频| 国产欧美一区二区在线观看| 欧美性色黄大片| 国产精品一区专区| 午夜婷婷国产麻豆精品| 国产日产欧美一区二区三区| 欧美体内she精视频| 国产裸体歌舞团一区二区| 亚洲综合色噜噜狠狠| 久久久国产精品麻豆| 欧美日韩一二三区| 成人免费毛片a| 国产精品乱子久久久久| 欧美电影一区二区| 91国偷自产一区二区开放时间| 国产乱子伦一区二区三区国色天香| 亚洲高清视频的网址| 国产精品污污网站在线观看| 日韩一本二本av| 欧美日韩亚洲高清一区二区|