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

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

?? lstrlib.c

?? 這個是一個嵌入式腳本支持引擎, 體積十分小巧
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*** $Id: lstrlib.c,v 1.132.1.4 2008/07/11 17:27:21 roberto Exp $** Standard library for string operations and pattern-matching** See Copyright Notice in lua.h*/#include <ctype.h>#include <stddef.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#define lstrlib_c#define LUA_LIB#include "lua.h"#include "lauxlib.h"#include "lualib.h"/* macro to `unsign' a character */#define uchar(c)        ((unsigned char)(c))static int str_len (lua_State *L) {  size_t l;  luaL_checklstring(L, 1, &l);  lua_pushinteger(L, l);  return 1;}static ptrdiff_t posrelat (ptrdiff_t pos, size_t len) {  /* relative string position: negative means back from end */  if (pos < 0) pos += (ptrdiff_t)len + 1;  return (pos >= 0) ? pos : 0;}static int str_sub (lua_State *L) {  size_t l;  const char *s = luaL_checklstring(L, 1, &l);  ptrdiff_t start = posrelat(luaL_checkinteger(L, 2), l);  ptrdiff_t end = posrelat(luaL_optinteger(L, 3, -1), l);  if (start < 1) start = 1;  if (end > (ptrdiff_t)l) end = (ptrdiff_t)l;  if (start <= end)    lua_pushlstring(L, s+start-1, end-start+1);  else lua_pushliteral(L, "");  return 1;}static int str_reverse (lua_State *L) {  size_t l;  luaL_Buffer b;  const char *s = luaL_checklstring(L, 1, &l);  luaL_buffinit(L, &b);  while (l--) luaL_addchar(&b, s[l]);  luaL_pushresult(&b);  return 1;}static int str_lower (lua_State *L) {  size_t l;  size_t i;  luaL_Buffer b;  const char *s = luaL_checklstring(L, 1, &l);  luaL_buffinit(L, &b);  for (i=0; i<l; i++)    luaL_addchar(&b, tolower(uchar(s[i])));  luaL_pushresult(&b);  return 1;}static int str_upper (lua_State *L) {  size_t l;  size_t i;  luaL_Buffer b;  const char *s = luaL_checklstring(L, 1, &l);  luaL_buffinit(L, &b);  for (i=0; i<l; i++)    luaL_addchar(&b, toupper(uchar(s[i])));  luaL_pushresult(&b);  return 1;}static int str_rep (lua_State *L) {  size_t l;  luaL_Buffer b;  const char *s = luaL_checklstring(L, 1, &l);  int n = luaL_checkint(L, 2);  luaL_buffinit(L, &b);  while (n-- > 0)    luaL_addlstring(&b, s, l);  luaL_pushresult(&b);  return 1;}static int str_byte (lua_State *L) {  size_t l;  const char *s = luaL_checklstring(L, 1, &l);  ptrdiff_t posi = posrelat(luaL_optinteger(L, 2, 1), l);  ptrdiff_t pose = posrelat(luaL_optinteger(L, 3, posi), l);  int n, i;  if (posi <= 0) posi = 1;  if ((size_t)pose > l) pose = l;  if (posi > pose) return 0;  /* empty interval; return no values */  n = (int)(pose -  posi + 1);  if (posi + n <= pose)  /* overflow? */    luaL_error(L, "string slice too long");  luaL_checkstack(L, n, "string slice too long");  for (i=0; i<n; i++)    lua_pushinteger(L, uchar(s[posi+i-1]));  return n;}static int str_char (lua_State *L) {  int n = lua_gettop(L);  /* number of arguments */  int i;  luaL_Buffer b;  luaL_buffinit(L, &b);  for (i=1; i<=n; i++) {    int c = luaL_checkint(L, i);    luaL_argcheck(L, uchar(c) == c, i, "invalid value");    luaL_addchar(&b, uchar(c));  }  luaL_pushresult(&b);  return 1;}static int writer (lua_State *L, const void* b, size_t size, void* B) {  (void)L;  luaL_addlstring((luaL_Buffer*) B, (const char *)b, size);  return 0;}static int str_dump (lua_State *L) {  luaL_Buffer b;  luaL_checktype(L, 1, LUA_TFUNCTION);  lua_settop(L, 1);  luaL_buffinit(L,&b);  if (lua_dump(L, writer, &b) != 0)    luaL_error(L, "unable to dump given function");  luaL_pushresult(&b);  return 1;}/*** {======================================================** PATTERN MATCHING** =======================================================*/#define CAP_UNFINISHED	(-1)#define CAP_POSITION	(-2)typedef struct MatchState {  const char *src_init;  /* init of source string */  const char *src_end;  /* end (`\0') of source string */  lua_State *L;  int level;  /* total number of captures (finished or unfinished) */  struct {    const char *init;    ptrdiff_t len;  } capture[LUA_MAXCAPTURES];} MatchState;#define L_ESC		'%'#define SPECIALS	"^$*+?.([%-"static int check_capture (MatchState *ms, int l) {  l -= '1';  if (l < 0 || l >= ms->level || ms->capture[l].len == CAP_UNFINISHED)    return luaL_error(ms->L, "invalid capture index");  return l;}static int capture_to_close (MatchState *ms) {  int level = ms->level;  for (level--; level>=0; level--)    if (ms->capture[level].len == CAP_UNFINISHED) return level;  return luaL_error(ms->L, "invalid pattern capture");}static const char *classend (MatchState *ms, const char *p) {  switch (*p++) {    case L_ESC: {      if (*p == '\0')        luaL_error(ms->L, "malformed pattern (ends with " LUA_QL("%%") ")");      return p+1;    }    case '[': {      if (*p == '^') p++;      do {  /* look for a `]' */        if (*p == '\0')          luaL_error(ms->L, "malformed pattern (missing " LUA_QL("]") ")");        if (*(p++) == L_ESC && *p != '\0')          p++;  /* skip escapes (e.g. `%]') */      } while (*p != ']');      return p+1;    }    default: {      return p;    }  }}static int match_class (int c, int cl) {  int res;  switch (tolower(cl)) {    case 'a' : res = isalpha(c); break;    case 'c' : res = iscntrl(c); break;    case 'd' : res = isdigit(c); break;    case 'l' : res = islower(c); break;    case 'p' : res = ispunct(c); break;    case 's' : res = isspace(c); break;    case 'u' : res = isupper(c); break;    case 'w' : res = isalnum(c); break;    case 'x' : res = isxdigit(c); break;    case 'z' : res = (c == 0); break;    default: return (cl == c);  }  return (islower(cl) ? res : !res);}static int matchbracketclass (int c, const char *p, const char *ec) {  int sig = 1;  if (*(p+1) == '^') {    sig = 0;    p++;  /* skip the `^' */  }  while (++p < ec) {    if (*p == L_ESC) {      p++;      if (match_class(c, uchar(*p)))        return sig;    }    else if ((*(p+1) == '-') && (p+2 < ec)) {      p+=2;      if (uchar(*(p-2)) <= c && c <= uchar(*p))        return sig;    }    else if (uchar(*p) == c) return sig;  }  return !sig;}static int singlematch (int c, const char *p, const char *ep) {  switch (*p) {    case '.': return 1;  /* matches any char */    case L_ESC: return match_class(c, uchar(*(p+1)));    case '[': return matchbracketclass(c, p, ep-1);    default:  return (uchar(*p) == c);  }}static const char *match (MatchState *ms, const char *s, const char *p);static const char *matchbalance (MatchState *ms, const char *s,                                   const char *p) {  if (*p == 0 || *(p+1) == 0)    luaL_error(ms->L, "unbalanced pattern");  if (*s != *p) return NULL;  else {    int b = *p;    int e = *(p+1);    int cont = 1;    while (++s < ms->src_end) {      if (*s == e) {        if (--cont == 0) return s+1;      }      else if (*s == b) cont++;    }  }  return NULL;  /* string ends out of balance */}static const char *max_expand (MatchState *ms, const char *s,                                 const char *p, const char *ep) {  ptrdiff_t i = 0;  /* counts maximum expand for item */  while ((s+i)<ms->src_end && singlematch(uchar(*(s+i)), p, ep))    i++;  /* keeps trying to match with the maximum repetitions */  while (i>=0) {    const char *res = match(ms, (s+i), ep+1);    if (res) return res;    i--;  /* else didn't match; reduce 1 repetition to try again */  }  return NULL;}static const char *min_expand (MatchState *ms, const char *s,                                 const char *p, const char *ep) {  for (;;) {    const char *res = match(ms, s, ep+1);    if (res != NULL)      return res;    else if (s<ms->src_end && singlematch(uchar(*s), p, ep))      s++;  /* try with one more repetition */    else return NULL;  }}static const char *start_capture (MatchState *ms, const char *s,                                    const char *p, int what) {  const char *res;  int level = ms->level;  if (level >= LUA_MAXCAPTURES) luaL_error(ms->L, "too many captures");  ms->capture[level].init = s;  ms->capture[level].len = what;  ms->level = level+1;  if ((res=match(ms, s, p)) == NULL)  /* match failed? */    ms->level--;  /* undo capture */  return res;}static const char *end_capture (MatchState *ms, const char *s,                                  const char *p) {  int l = capture_to_close(ms);  const char *res;  ms->capture[l].len = s - ms->capture[l].init;  /* close capture */  if ((res = match(ms, s, p)) == NULL)  /* match failed? */    ms->capture[l].len = CAP_UNFINISHED;  /* undo capture */  return res;}static const char *match_capture (MatchState *ms, const char *s, int l) {  size_t len;  l = check_capture(ms, l);  len = ms->capture[l].len;  if ((size_t)(ms->src_end-s) >= len &&      memcmp(ms->capture[l].init, s, len) == 0)    return s+len;  else return NULL;}static const char *match (MatchState *ms, const char *s, const char *p) {  init: /* using goto's to optimize tail recursion */  switch (*p) {    case '(': {  /* start capture */      if (*(p+1) == ')')  /* position capture? */        return start_capture(ms, s, p+2, CAP_POSITION);      else        return start_capture(ms, s, p+1, CAP_UNFINISHED);    }    case ')': {  /* end capture */      return end_capture(ms, s, p+1);    }    case L_ESC: {      switch (*(p+1)) {        case 'b': {  /* balanced string? */          s = matchbalance(ms, s, p+2);          if (s == NULL) return NULL;          p+=4; goto init;  /* else return match(ms, s, p+4); */        }        case 'f': {  /* frontier? */          const char *ep; char previous;          p += 2;          if (*p != '[')            luaL_error(ms->L, "missing " LUA_QL("[") " after "                               LUA_QL("%%f") " in pattern");          ep = classend(ms, p);  /* points to what is next */          previous = (s == ms->src_init) ? '\0' : *(s-1);          if (matchbracketclass(uchar(previous), p, ep-1) ||             !matchbracketclass(uchar(*s), p, ep-1)) return NULL;          p=ep; goto init;  /* else return match(ms, s, ep); */        }        default: {          if (isdigit(uchar(*(p+1)))) {  /* capture results (%0-%9)? */            s = match_capture(ms, s, uchar(*(p+1)));            if (s == NULL) return NULL;            p+=2; goto init;  /* else return match(ms, s, p+2) */          }          goto dflt;  /* case default */        }      }    }    case '\0': {  /* end of pattern */      return s;  /* match succeeded */    }    case '$': {      if (*(p+1) == '\0')  /* is the `$' the last char in pattern? */        return (s == ms->src_end) ? s : NULL;  /* check end of string */      else goto dflt;    }    default: dflt: {  /* it is a pattern item */      const char *ep = classend(ms, p);  /* points to what is next */      int m = s<ms->src_end && singlematch(uchar(*s), p, ep);      switch (*ep) {        case '?': {  /* optional */          const char *res;          if (m && ((res=match(ms, s+1, ep+1)) != NULL))            return res;          p=ep+1; goto init;  /* else return match(ms, s, ep+1); */        }        case '*': {  /* 0 or more repetitions */          return max_expand(ms, s, p, ep);        }        case '+': {  /* 1 or more repetitions */          return (m ? max_expand(ms, s+1, p, ep) : NULL);        }        case '-': {  /* 0 or more repetitions (minimum) */          return min_expand(ms, s, p, ep);        }        default: {          if (!m) return NULL;          s++; p=ep; goto init;  /* else return match(ms, s+1, ep); */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久人人超碰精品| 亚洲色图在线播放| 另类小说一区二区三区| 精品福利在线导航| 波多野结衣的一区二区三区| 国产精品日产欧美久久久久| 91蝌蚪porny九色| 天堂午夜影视日韩欧美一区二区| 久久综合网色—综合色88| 一本久久精品一区二区| 精品在线观看视频| 亚洲综合一二三区| 日韩视频在线你懂得| 99国产一区二区三精品乱码| 男男视频亚洲欧美| 亚洲日本在线看| 中文字幕成人av| 91精品婷婷国产综合久久竹菊| 懂色av噜噜一区二区三区av| 久久99国产精品久久99果冻传媒| 亚洲国产精品麻豆| 亚洲人成精品久久久久| 国产网红主播福利一区二区| 欧美精品一区二区三区视频| 欧美日韩视频在线一区二区 | 91精品欧美一区二区三区综合在| 99久久99久久久精品齐齐| 国产美女久久久久| 一区二区欧美精品| 亚洲另类中文字| 性感美女极品91精品| 亚洲精品第1页| 亚洲一区在线观看网站| 五月天丁香久久| 玖玖九九国产精品| 国产高清在线精品| 99久久久精品免费观看国产蜜| k8久久久一区二区三区| bt7086福利一区国产| 91久久精品午夜一区二区| 777奇米四色成人影色区| 欧美精品一区二区三区在线播放 | 国内外成人在线视频| 国产91精品一区二区麻豆网站| 高清不卡在线观看| 欧美群妇大交群中文字幕| 精品第一国产综合精品aⅴ| 日本一区二区久久| 婷婷中文字幕综合| 夫妻av一区二区| 717成人午夜免费福利电影| 精品日本一线二线三线不卡| 欧美国产日韩亚洲一区| 日韩不卡在线观看日韩不卡视频| 国产一区二区三区精品欧美日韩一区二区三区| 国产成人精品影视| 欧美肥胖老妇做爰| 亚洲男人电影天堂| 国产精品影视网| 欧美日韩成人高清| 亚洲精品视频观看| 972aa.com艺术欧美| 欧美国产激情一区二区三区蜜月| 亚瑟在线精品视频| 在线观看日韩毛片| 亚洲免费资源在线播放| 91免费看`日韩一区二区| 久久久久久久久久久久久久久99| 亚洲第一成年网| 7777精品伊人久久久大香线蕉 | 久久电影国产免费久久电影| 欧美日韩在线不卡| 一区二区三区四区在线播放| 99国产精品99久久久久久| 久久蜜臀中文字幕| 成人免费看片app下载| 久久久久99精品国产片| 国产白丝网站精品污在线入口| 久久久久久久久久看片| 成人午夜私人影院| 亚洲免费av观看| 欧美日韩一区高清| 韩国精品主播一区二区在线观看| 精品盗摄一区二区三区| eeuss鲁一区二区三区| 中文字幕五月欧美| 91成人免费电影| 国内外精品视频| 一区二区三区在线视频免费观看| 8x福利精品第一导航| 成人高清免费在线播放| 亚洲va欧美va天堂v国产综合| 欧美va亚洲va国产综合| 成人精品国产一区二区4080 | 亚洲国产精品一区二区久久恐怖片| 欧美一卡二卡三卡四卡| 91在线看国产| 国产激情一区二区三区| 天堂va蜜桃一区二区三区| 国产精品久久久久久久裸模| 制服视频三区第一页精品| 91丝袜美腿高跟国产极品老师| 免费日韩伦理电影| 午夜亚洲国产au精品一区二区| 国产网站一区二区三区| xfplay精品久久| 欧美成人国产一区二区| 91黄视频在线| 91美女精品福利| 白白色 亚洲乱淫| 国产麻豆精品久久一二三| 六月婷婷色综合| 韩国女主播成人在线观看| 久久国产剧场电影| 精品亚洲porn| 波多野结衣一区二区三区 | 亚洲综合在线五月| 亚洲成a人v欧美综合天堂下载| 欧美mv和日韩mv的网站| 26uuu国产电影一区二区| 久久女同互慰一区二区三区| 中文字幕av一区 二区| 自拍av一区二区三区| 亚洲最大色网站| 精东粉嫩av免费一区二区三区| 国产精品资源在线看| 欧美日韩国产另类不卡| 日韩亚洲欧美一区二区三区| 亚洲视频你懂的| 日本欧美肥老太交大片| 成人网页在线观看| 3atv在线一区二区三区| 国产精品无码永久免费888| 亚洲综合激情小说| 九色porny丨国产精品| 91丨porny丨国产入口| 日韩欧美久久一区| 亚洲综合色区另类av| 石原莉奈在线亚洲二区| 国产精品18久久久久久久久| 欧美三区免费完整视频在线观看| 国产午夜精品久久久久久免费视| 亚洲一区二区黄色| 99久久精品免费看国产免费软件| 日韩久久久久久| 美国三级日本三级久久99| 欧美视频在线观看一区| 亚洲天堂网中文字| 成人av动漫网站| 国产精品久久久久久亚洲毛片 | 波多野结衣一区二区三区| 久久精品欧美一区二区三区不卡| 青青草原综合久久大伊人精品 | 制服丝袜av成人在线看| 午夜精品一区二区三区电影天堂| 91一区在线观看| 亚洲三级免费观看| 99国产欧美久久久精品| 亚洲福中文字幕伊人影院| 在线观看亚洲精品| 日韩电影一区二区三区| 精品理论电影在线| 国产一区二区三区精品欧美日韩一区二区三区| 欧美人xxxx| 国产一区免费电影| 国产精品电影一区二区三区| 色94色欧美sute亚洲线路一ni | 琪琪久久久久日韩精品| 欧美精彩视频一区二区三区| 99在线视频精品| 亚洲午夜影视影院在线观看| 日韩视频免费观看高清完整版 | av中文字幕一区| 午夜视频在线观看一区二区 | 欧美激情一区二区三区不卡 | 日韩欧美国产综合一区| 丁香婷婷综合色啪| 五月天丁香久久| 国产精品美女久久久久久久久 | 欧美激情一区二区三区不卡 | 日本一区二区动态图| 欧美一级在线观看| 91啪在线观看| 国产伦精一区二区三区| 亚洲黄色小说网站| 国产欧美精品一区aⅴ影院| 欧美高清精品3d| 欧美日韩在线三区| 97se亚洲国产综合自在线| 精品一二线国产| 日韩高清一级片| 亚洲一区在线观看视频| 亚洲三级在线免费观看| 国产精品日韩成人| 国产人成一区二区三区影院| 欧美xxxxx牲另类人与| 欧美精选午夜久久久乱码6080| 99re这里只有精品6| 色婷婷精品久久二区二区蜜臂av | 国产精品久久精品日日|