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

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

?? ltablib.c

?? lua的即時編譯器。支持lua 5.1.2版本
?? C
字號:
/*** $Id: ltablib.c,v 1.38 2005/10/23 17:38:15 roberto Exp $** Library for Table Manipulation** See Copyright Notice in lua.h*/#include <stddef.h>#define ltablib_c#define LUA_LIB#include "lua.h"#include "lauxlib.h"#include "lualib.h"#define aux_getn(L,n)	(luaL_checktype(L, n, LUA_TTABLE), luaL_getn(L, n))static int foreachi (lua_State *L) {  int i;  int n = aux_getn(L, 1);  luaL_checktype(L, 2, LUA_TFUNCTION);  for (i=1; i <= n; i++) {    lua_pushvalue(L, 2);  /* function */    lua_pushinteger(L, i);  /* 1st argument */    lua_rawgeti(L, 1, i);  /* 2nd argument */    lua_call(L, 2, 1);    if (!lua_isnil(L, -1))      return 1;    lua_pop(L, 1);  /* remove nil result */  }  return 0;}static int foreach (lua_State *L) {  luaL_checktype(L, 1, LUA_TTABLE);  luaL_checktype(L, 2, LUA_TFUNCTION);  lua_pushnil(L);  /* first key */  while (lua_next(L, 1)) {    lua_pushvalue(L, 2);  /* function */    lua_pushvalue(L, -3);  /* key */    lua_pushvalue(L, -3);  /* value */    lua_call(L, 2, 1);    if (!lua_isnil(L, -1))      return 1;    lua_pop(L, 2);  /* remove value and result */  }  return 0;}static int maxn (lua_State *L) {  lua_Number max = 0;  luaL_checktype(L, 1, LUA_TTABLE);  lua_pushnil(L);  /* first key */  while (lua_next(L, 1)) {    lua_pop(L, 1);  /* remove value */    if (lua_type(L, -1) == LUA_TNUMBER) {      lua_Number v = lua_tonumber(L, -1);      if (v > max) max = v;    }  }  lua_pushnumber(L, max);  return 1;}static int getn (lua_State *L) {  lua_pushinteger(L, aux_getn(L, 1));  return 1;}static int setn (lua_State *L) {  luaL_checktype(L, 1, LUA_TTABLE);#ifndef luaL_setn  luaL_setn(L, 1, luaL_checkint(L, 2));#else  luaL_error(L, LUA_QL("setn") " is obsolete");#endif  lua_pushvalue(L, 1);  return 1;}static int tinsert (lua_State *L) {  int e = aux_getn(L, 1) + 1;  /* first empty element */  int pos;  /* where to insert new element */  switch (lua_gettop(L)) {    case 2: {  /* called with only 2 arguments */      pos = e;  /* insert new element at the end */      break;    }    case 3: {      int i;      pos = luaL_checkint(L, 2);  /* 2nd argument is the position */      if (pos > e) e = pos;  /* `grow' array if necessary */      for (i = e; i > pos; i--) {  /* move up elements */        lua_rawgeti(L, 1, i-1);        lua_rawseti(L, 1, i);  /* t[i] = t[i-1] */      }      break;    }    default: {      return luaL_error(L, "wrong number of arguments to " LUA_QL("insert"));    }  }  luaL_setn(L, 1, e);  /* new size */  lua_rawseti(L, 1, pos);  /* t[pos] = v */  return 0;}static int tremove (lua_State *L) {  int e = aux_getn(L, 1);  int pos = luaL_optint(L, 2, e);  if (e == 0) return 0;  /* table is `empty' */  luaL_setn(L, 1, e - 1);  /* t.n = n-1 */  lua_rawgeti(L, 1, pos);  /* result = t[pos] */  for ( ;pos<e; pos++) {    lua_rawgeti(L, 1, pos+1);    lua_rawseti(L, 1, pos);  /* t[pos] = t[pos+1] */  }  lua_pushnil(L);  lua_rawseti(L, 1, e);  /* t[e] = nil */  return 1;}static int tconcat (lua_State *L) {  luaL_Buffer b;  size_t lsep;  int i, last;  const char *sep = luaL_optlstring(L, 2, "", &lsep);  luaL_checktype(L, 1, LUA_TTABLE);  i = luaL_optint(L, 3, 1);  last = luaL_opt(L, luaL_checkint, 4, luaL_getn(L, 1));  luaL_buffinit(L, &b);  for (; i <= last; i++) {    lua_rawgeti(L, 1, i);    luaL_argcheck(L, lua_isstring(L, -1), 1, "table contains non-strings");    luaL_addvalue(&b);    if (i != last)      luaL_addlstring(&b, sep, lsep);  }  luaL_pushresult(&b);  return 1;}/*** {======================================================** Quicksort** (based on `Algorithms in MODULA-3', Robert Sedgewick;**  Addison-Wesley, 1993.)*/static void set2 (lua_State *L, int i, int j) {  lua_rawseti(L, 1, i);  lua_rawseti(L, 1, j);}static int sort_comp (lua_State *L, int a, int b) {  if (!lua_isnil(L, 2)) {  /* function? */    int res;    lua_pushvalue(L, 2);    lua_pushvalue(L, a-1);  /* -1 to compensate function */    lua_pushvalue(L, b-2);  /* -2 to compensate function and `a' */    lua_call(L, 2, 1);    res = lua_toboolean(L, -1);    lua_pop(L, 1);    return res;  }  else  /* a < b? */    return lua_lessthan(L, a, b);}static void auxsort (lua_State *L, int l, int u) {  while (l < u) {  /* for tail recursion */    int i, j;    /* sort elements a[l], a[(l+u)/2] and a[u] */    lua_rawgeti(L, 1, l);    lua_rawgeti(L, 1, u);    if (sort_comp(L, -1, -2))  /* a[u] < a[l]? */      set2(L, l, u);  /* swap a[l] - a[u] */    else      lua_pop(L, 2);    if (u-l == 1) break;  /* only 2 elements */    i = (l+u)/2;    lua_rawgeti(L, 1, i);    lua_rawgeti(L, 1, l);    if (sort_comp(L, -2, -1))  /* a[i]<a[l]? */      set2(L, i, l);    else {      lua_pop(L, 1);  /* remove a[l] */      lua_rawgeti(L, 1, u);      if (sort_comp(L, -1, -2))  /* a[u]<a[i]? */        set2(L, i, u);      else        lua_pop(L, 2);    }    if (u-l == 2) break;  /* only 3 elements */    lua_rawgeti(L, 1, i);  /* Pivot */    lua_pushvalue(L, -1);    lua_rawgeti(L, 1, u-1);    set2(L, i, u-1);    /* a[l] <= P == a[u-1] <= a[u], only need to sort from l+1 to u-2 */    i = l; j = u-1;    for (;;) {  /* invariant: a[l..i] <= P <= a[j..u] */      /* repeat ++i until a[i] >= P */      while (lua_rawgeti(L, 1, ++i), sort_comp(L, -1, -2)) {        if (i>u) luaL_error(L, "invalid order function for sorting");        lua_pop(L, 1);  /* remove a[i] */      }      /* repeat --j until a[j] <= P */      while (lua_rawgeti(L, 1, --j), sort_comp(L, -3, -1)) {        if (j<l) luaL_error(L, "invalid order function for sorting");        lua_pop(L, 1);  /* remove a[j] */      }      if (j<i) {        lua_pop(L, 3);  /* pop pivot, a[i], a[j] */        break;      }      set2(L, i, j);    }    lua_rawgeti(L, 1, u-1);    lua_rawgeti(L, 1, i);    set2(L, u-1, i);  /* swap pivot (a[u-1]) with a[i] */    /* a[l..i-1] <= a[i] == P <= a[i+1..u] */    /* adjust so that smaller half is in [j..i] and larger one in [l..u] */    if (i-l < u-i) {      j=l; i=i-1; l=i+2;    }    else {      j=i+1; i=u; u=j-2;    }    auxsort(L, j, i);  /* call recursively the smaller one */  }  /* repeat the routine for the larger one */}static int sort (lua_State *L) {  int n = aux_getn(L, 1);  luaL_checkstack(L, 40, "");  /* assume array is smaller than 2^40 */  if (!lua_isnoneornil(L, 2))  /* is there a 2nd argument? */    luaL_checktype(L, 2, LUA_TFUNCTION);  lua_settop(L, 2);  /* make sure there is two arguments */  auxsort(L, 1, n);  return 0;}/* }====================================================== */static const luaL_Reg tab_funcs[] = {  {"concat", tconcat},  {"foreach", foreach},  {"foreachi", foreachi},  {"getn", getn},  {"maxn", maxn},  {"insert", tinsert},  {"remove", tremove},  {"setn", setn},  {"sort", sort},  {NULL, NULL}};LUALIB_API int luaopen_table (lua_State *L) {  luaL_register(L, LUA_TABLIBNAME, tab_funcs);  return 1;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品麻豆| 欧美一区二区三区爱爱| 国产成人一级电影| 久久99精品国产.久久久久久| 一个色妞综合视频在线观看| 亚洲另类在线一区| 蜜臀久久久久久久| 精品一区二区三区久久| 国产一区二区三区蝌蚪| 一本大道久久a久久精品综合| 色老头久久综合| 欧美日韩免费视频| 国产欧美日韩三级| 一区二区成人在线观看| 亚洲狠狠爱一区二区三区| 国产激情视频一区二区三区欧美| www.成人在线| 欧美在线短视频| 国产女人18水真多18精品一级做| 一级特黄大欧美久久久| 美女网站一区二区| 欧美区视频在线观看| 国产精品蜜臀av| 亚洲亚洲精品在线观看| 成人18精品视频| 日韩精品一区二区三区视频在线观看| 国产精品久久精品日日| 日本视频在线一区| 色综合久久久久综合99| 欧美国产禁国产网站cc| 日韩中文字幕不卡| 色综合久久综合中文综合网| 国产午夜一区二区三区| 蜜桃视频一区二区三区| www.一区二区| 一区二区三区欧美| 欧洲国产伦久久久久久久| 日本一区二区视频在线| 国产91丝袜在线观看| 久久久激情视频| 丰满少妇久久久久久久| 欧美国产综合一区二区| 国产xxx精品视频大全| 中文字幕的久久| 大陆成人av片| 亚洲欧洲美洲综合色网| 在线中文字幕一区二区| 日韩中文字幕不卡| 欧美日韩你懂的| 久久精品国产一区二区三| 久久久综合精品| 成人av在线影院| 一区二区三区高清| 欧美一级xxx| 国产精品自拍三区| 一区二区在线观看视频| 色诱亚洲精品久久久久久| 久久精品一区四区| 91福利在线观看| 免费在线看一区| 中文字幕中文字幕一区二区| 日韩一区二区麻豆国产| 狠狠狠色丁香婷婷综合激情| 尤物av一区二区| 中文欧美字幕免费| 91精品国产综合久久精品| 国产不卡免费视频| 免费精品视频最新在线| 亚洲国产日韩a在线播放性色| 国产精品久久久久久久久晋中| 91视频在线观看| 高清在线观看日韩| 韩国精品主播一区二区在线观看| 国产日产欧产精品推荐色 | 国产成人午夜精品5599| 免费人成精品欧美精品| 日日夜夜精品视频免费| 亚洲精品中文在线观看| 国产精品网站在线播放| 精品久久久久久久人人人人传媒| 69精品人人人人| 欧美一区二区视频免费观看| 91在线视频官网| 色天天综合色天天久久| 99久久99久久精品免费看蜜桃| 精品中文字幕一区二区| 免费看日韩精品| 美洲天堂一区二卡三卡四卡视频| 蜜臀久久久久久久| 国产高清一区日本| 成人av综合在线| 91高清在线观看| 777欧美精品| 日韩一区二区在线免费观看| 日韩欧美国产精品| 久久久精品天堂| 中文字幕一区二区三区在线观看| 2024国产精品视频| 亚洲国产精品成人综合| 夜夜嗨av一区二区三区| 六月丁香婷婷色狠狠久久| 国产一区三区三区| 99精品国产视频| 日韩欧美精品在线视频| 中文字幕日韩精品一区 | 高清不卡在线观看| 欧亚洲嫩模精品一区三区| 精品国产免费一区二区三区香蕉| 综合欧美亚洲日本| 日本vs亚洲vs韩国一区三区二区| 国产一区二区三区| 欧美视频在线一区二区三区 | 成人黄色电影在线| 精品久久一二三区| 亚洲综合激情另类小说区| 国产成人亚洲精品青草天美| 精品蜜桃在线看| 亚洲男人的天堂网| 国产成人综合视频| 欧美一级高清大全免费观看| 亚洲欧美日韩中文字幕一区二区三区| 乱中年女人伦av一区二区| 色av综合在线| 一区二区三区免费看视频| av一二三不卡影片| 欧美一区二区三区日韩视频| 亚洲一区日韩精品中文字幕| 丁香婷婷综合色啪| 亚洲国产精品传媒在线观看| 懂色一区二区三区免费观看| 久久免费美女视频| eeuss鲁一区二区三区| 亚洲久本草在线中文字幕| 99久久精品免费看国产| 亚洲黄色尤物视频| 欧美三级日韩三级国产三级| 亚洲国产精品久久不卡毛片 | 亚洲成av人影院| 欧美美女网站色| 精品夜夜嗨av一区二区三区| 欧美韩国日本一区| 91在线观看免费视频| 日韩中文欧美在线| 2020国产精品久久精品美国| 国产精品一区二区x88av| 18欧美亚洲精品| 欧美日韩国产系列| 高清国产一区二区三区| 偷拍一区二区三区四区| 久久欧美一区二区| 3d成人动漫网站| 成人综合婷婷国产精品久久蜜臀 | 精品久久久久久最新网址| 国产麻豆精品视频| 一卡二卡三卡日韩欧美| 欧美精品一区二区三区久久久| 99久久久精品免费观看国产蜜| 经典三级在线一区| 亚洲电影在线播放| 日本一区二区三区dvd视频在线| 91黄色免费版| 成人黄页毛片网站| 9i看片成人免费高清| 久久国产三级精品| 免费观看成人鲁鲁鲁鲁鲁视频| 又紧又大又爽精品一区二区| 中文无字幕一区二区三区| 久久精品免视看| 日韩女优制服丝袜电影| 欧美tickle裸体挠脚心vk| 日韩精品综合一本久道在线视频| 欧美日韩国产中文| 欧美一级欧美三级在线观看| 欧美伦理影视网| 5858s免费视频成人| 日韩午夜激情av| 久久av资源网| 蜜桃精品视频在线| 国产亚洲女人久久久久毛片| 9191成人精品久久| 2023国产精品| 国产偷v国产偷v亚洲高清| 欧美精品一区二区三区蜜臀 | 欧美变态tickling挠脚心| 欧美高清你懂得| 97超碰欧美中文字幕| 成人污视频在线观看| 成人深夜福利app| 欧美在线不卡视频| 91精品国产91久久综合桃花| 欧美视频自拍偷拍| 日韩欧美国产精品| 久久免费美女视频| 亚洲精品在线免费观看视频| 久久免费视频一区| 国产精品另类一区| 一区二区三区免费| 奇米精品一区二区三区四区 | 激情综合亚洲精品| 丰满放荡岳乱妇91ww|