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

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

?? func.c

?? sqlite 3.3.8 支持加密的版本
?? C
?? 第 1 頁 / 共 3 頁
字號:
        u8 const *zTemp = &zPattern[1];
        sqliteNextChar(zTemp);
        c = *zTemp;
      }
      if( c==0 ) return 1;
      if( c==matchSet ){
        assert( esc==0 );   /* This is GLOB, not LIKE */
        while( *zString && patternCompare(&zPattern[1],zString,pInfo,esc)==0 ){
          sqliteNextChar(zString);
        }
        return *zString!=0;
      }else{
        while( (c2 = *zString)!=0 ){
          if( noCase ){
            c2 = sqlite3UpperToLower[c2];
            c = sqlite3UpperToLower[c];
            while( c2 != 0 && c2 != c ){ c2 = sqlite3UpperToLower[*++zString]; }
          }else{
            while( c2 != 0 && c2 != c ){ c2 = *++zString; }
          }
          if( c2==0 ) return 0;
          if( patternCompare(&zPattern[1],zString,pInfo,esc) ) return 1;
          sqliteNextChar(zString);
        }
        return 0;
      }
    }else if( !prevEscape && c==matchOne ){
      if( *zString==0 ) return 0;
      sqliteNextChar(zString);
      zPattern++;
    }else if( c==matchSet ){
      int prior_c = 0;
      assert( esc==0 );    /* This only occurs for GLOB, not LIKE */
      seen = 0;
      invert = 0;
      c = sqliteCharVal(zString);
      if( c==0 ) return 0;
      c2 = *++zPattern;
      if( c2=='^' ){ invert = 1; c2 = *++zPattern; }
      if( c2==']' ){
        if( c==']' ) seen = 1;
        c2 = *++zPattern;
      }
      while( (c2 = sqliteCharVal(zPattern))!=0 && c2!=']' ){
        if( c2=='-' && zPattern[1]!=']' && zPattern[1]!=0 && prior_c>0 ){
          zPattern++;
          c2 = sqliteCharVal(zPattern);
          if( c>=prior_c && c<=c2 ) seen = 1;
          prior_c = 0;
        }else if( c==c2 ){
          seen = 1;
          prior_c = c2;
        }else{
          prior_c = c2;
        }
        sqliteNextChar(zPattern);
      }
      if( c2==0 || (seen ^ invert)==0 ) return 0;
      sqliteNextChar(zString);
      zPattern++;
    }else if( esc && !prevEscape && sqlite3ReadUtf8(zPattern)==esc){
      prevEscape = 1;
      sqliteNextChar(zPattern);
    }else{
      if( noCase ){
        if( sqlite3UpperToLower[c] != sqlite3UpperToLower[*zString] ) return 0;
      }else{
        if( c != *zString ) return 0;
      }
      zPattern++;
      zString++;
      prevEscape = 0;
    }
  }
  return *zString==0;
}

/*
** Count the number of times that the LIKE operator (or GLOB which is
** just a variation of LIKE) gets called.  This is used for testing
** only.
*/
#ifdef SQLITE_TEST
int sqlite3_like_count = 0;
#endif


/*
** Implementation of the like() SQL function.  This function implements
** the build-in LIKE operator.  The first argument to the function is the
** pattern and the second argument is the string.  So, the SQL statements:
**
**       A LIKE B
**
** is implemented as like(B,A).
**
** This same function (with a different compareInfo structure) computes
** the GLOB operator.
*/
static void likeFunc(
  sqlite3_context *context, 
  int argc, 
  sqlite3_value **argv
){
  const unsigned char *zA = sqlite3_value_text(argv[0]);
  const unsigned char *zB = sqlite3_value_text(argv[1]);
  int escape = 0;
  if( argc==3 ){
    /* The escape character string must consist of a single UTF-8 character.
    ** Otherwise, return an error.
    */
    const unsigned char *zEsc = sqlite3_value_text(argv[2]);
    if( sqlite3utf8CharLen((char*)zEsc, -1)!=1 ){
      sqlite3_result_error(context, 
          "ESCAPE expression must be a single character", -1);
      return;
    }
    escape = sqlite3ReadUtf8(zEsc);
  }
  if( zA && zB ){
    struct compareInfo *pInfo = sqlite3_user_data(context);
#ifdef SQLITE_TEST
    sqlite3_like_count++;
#endif
    sqlite3_result_int(context, patternCompare(zA, zB, pInfo, escape));
  }
}

/*
** Implementation of the NULLIF(x,y) function.  The result is the first
** argument if the arguments are different.  The result is NULL if the
** arguments are equal to each other.
*/
static void nullifFunc(
  sqlite3_context *context,
  int argc,
  sqlite3_value **argv
){
  CollSeq *pColl = sqlite3GetFuncCollSeq(context);
  if( sqlite3MemCompare(argv[0], argv[1], pColl)!=0 ){
    sqlite3_result_value(context, argv[0]);
  }
}

/*
** Implementation of the VERSION(*) function.  The result is the version
** of the SQLite library that is running.
*/
static void versionFunc(
  sqlite3_context *context,
  int argc,
  sqlite3_value **argv
){
  sqlite3_result_text(context, sqlite3_version, -1, SQLITE_STATIC);
}


/*
** EXPERIMENTAL - This is not an official function.  The interface may
** change.  This function may disappear.  Do not write code that depends
** on this function.
**
** Implementation of the QUOTE() function.  This function takes a single
** argument.  If the argument is numeric, the return value is the same as
** the argument.  If the argument is NULL, the return value is the string
** "NULL".  Otherwise, the argument is enclosed in single quotes with
** single-quote escapes.
*/
static void quoteFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
  if( argc<1 ) return;
  switch( sqlite3_value_type(argv[0]) ){
    case SQLITE_NULL: {
      sqlite3_result_text(context, "NULL", 4, SQLITE_STATIC);
      break;
    }
    case SQLITE_INTEGER:
    case SQLITE_FLOAT: {
      sqlite3_result_value(context, argv[0]);
      break;
    }
    case SQLITE_BLOB: {
      static const char hexdigits[] = { 
        '0', '1', '2', '3', '4', '5', '6', '7',
        '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' 
      };
      char *zText = 0;
      int nBlob = sqlite3_value_bytes(argv[0]);
      char const *zBlob = sqlite3_value_blob(argv[0]);

      zText = (char *)sqliteMalloc((2*nBlob)+4); 
      if( !zText ){
        sqlite3_result_error(context, "out of memory", -1);
      }else{
        int i;
        for(i=0; i<nBlob; i++){
          zText[(i*2)+2] = hexdigits[(zBlob[i]>>4)&0x0F];
          zText[(i*2)+3] = hexdigits[(zBlob[i])&0x0F];
        }
        zText[(nBlob*2)+2] = '\'';
        zText[(nBlob*2)+3] = '\0';
        zText[0] = 'X';
        zText[1] = '\'';
        sqlite3_result_text(context, zText, -1, SQLITE_TRANSIENT);
        sqliteFree(zText);
      }
      break;
    }
    case SQLITE_TEXT: {
      int i,j,n;
      const unsigned char *zArg = sqlite3_value_text(argv[0]);
      char *z;

      for(i=n=0; zArg[i]; i++){ if( zArg[i]=='\'' ) n++; }
      z = sqliteMalloc( i+n+3 );
      if( z==0 ) return;
      z[0] = '\'';
      for(i=0, j=1; zArg[i]; i++){
        z[j++] = zArg[i];
        if( zArg[i]=='\'' ){
          z[j++] = '\'';
        }
      }
      z[j++] = '\'';
      z[j] = 0;
      sqlite3_result_text(context, z, j, SQLITE_TRANSIENT);
      sqliteFree(z);
    }
  }
}

#ifdef SQLITE_SOUNDEX
/*
** Compute the soundex encoding of a word.
*/
static void soundexFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
  char zResult[8];
  const u8 *zIn;
  int i, j;
  static const unsigned char iCode[] = {
    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
    0, 0, 1, 2, 3, 0, 1, 2, 0, 0, 2, 2, 4, 5, 5, 0,
    1, 2, 6, 2, 3, 0, 1, 0, 2, 0, 2, 0, 0, 0, 0, 0,
    0, 0, 1, 2, 3, 0, 1, 2, 0, 0, 2, 2, 4, 5, 5, 0,
    1, 2, 6, 2, 3, 0, 1, 0, 2, 0, 2, 0, 0, 0, 0, 0,
  };
  assert( argc==1 );
  zIn = (u8*)sqlite3_value_text(argv[0]);
  if( zIn==0 ) zIn = (u8*)"";
  for(i=0; zIn[i] && !isalpha(zIn[i]); i++){}
  if( zIn[i] ){
    u8 prevcode = iCode[zIn[i]&0x7f];
    zResult[0] = toupper(zIn[i]);
    for(j=1; j<4 && zIn[i]; i++){
      int code = iCode[zIn[i]&0x7f];
      if( code>0 ){
        if( code!=prevcode ){
          prevcode = code;
          zResult[j++] = code + '0';
        }
      }else{
        prevcode = 0;
      }
    }
    while( j<4 ){
      zResult[j++] = '0';
    }
    zResult[j] = 0;
    sqlite3_result_text(context, zResult, 4, SQLITE_TRANSIENT);
  }else{
    sqlite3_result_text(context, "?000", 4, SQLITE_STATIC);
  }
}
#endif

#ifndef SQLITE_OMIT_LOAD_EXTENSION
/*
** A function that loads a shared-library extension then returns NULL.
*/
static void loadExt(sqlite3_context *context, int argc, sqlite3_value **argv){
  const char *zFile = (const char *)sqlite3_value_text(argv[0]);
  const char *zProc = 0;
  sqlite3 *db = sqlite3_user_data(context);
  char *zErrMsg = 0;

  if( argc==2 ){
    zProc = (const char *)sqlite3_value_text(argv[1]);
  }
  if( sqlite3_load_extension(db, zFile, zProc, &zErrMsg) ){
    sqlite3_result_error(context, zErrMsg, -1);
    sqlite3_free(zErrMsg);
  }
}
#endif

#ifdef SQLITE_TEST
/*
** This function generates a string of random characters.  Used for
** generating test data.
*/
static void randStr(sqlite3_context *context, int argc, sqlite3_value **argv){
  static const unsigned char zSrc[] = 
     "abcdefghijklmnopqrstuvwxyz"
     "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
     "0123456789"
     ".-!,:*^+=_|?/<> ";
  int iMin, iMax, n, r, i;
  unsigned char zBuf[1000];
  if( argc>=1 ){
    iMin = sqlite3_value_int(argv[0]);
    if( iMin<0 ) iMin = 0;
    if( iMin>=sizeof(zBuf) ) iMin = sizeof(zBuf)-1;
  }else{
    iMin = 1;
  }
  if( argc>=2 ){
    iMax = sqlite3_value_int(argv[1]);
    if( iMax<iMin ) iMax = iMin;
    if( iMax>=sizeof(zBuf) ) iMax = sizeof(zBuf)-1;
  }else{
    iMax = 50;
  }
  n = iMin;
  if( iMax>iMin ){
    sqlite3Randomness(sizeof(r), &r);
    r &= 0x7fffffff;
    n += r%(iMax + 1 - iMin);
  }
  assert( n<sizeof(zBuf) );
  sqlite3Randomness(n, zBuf);
  for(i=0; i<n; i++){
    zBuf[i] = zSrc[zBuf[i]%(sizeof(zSrc)-1)];
  }
  zBuf[n] = 0;
  sqlite3_result_text(context, (char*)zBuf, n, SQLITE_TRANSIENT);
}
#endif /* SQLITE_TEST */

#ifdef SQLITE_TEST
/*
** The following two SQL functions are used to test returning a text
** result with a destructor. Function 'test_destructor' takes one argument
** and returns the same argument interpreted as TEXT. A destructor is
** passed with the sqlite3_result_text() call.
**
** SQL function 'test_destructor_count' returns the number of outstanding 
** allocations made by 'test_destructor';
**
** WARNING: Not threadsafe.
*/
static int test_destructor_count_var = 0;
static void destructor(void *p){
  char *zVal = (char *)p;
  assert(zVal);
  zVal--;
  sqliteFree(zVal);
  test_destructor_count_var--;
}
static void test_destructor(
  sqlite3_context *pCtx, 
  int nArg,
  sqlite3_value **argv
){
  char *zVal;
  int len;
  sqlite3 *db = sqlite3_user_data(pCtx);
 
  test_destructor_count_var++;
  assert( nArg==1 );
  if( sqlite3_value_type(argv[0])==SQLITE_NULL ) return;
  len = sqlite3ValueBytes(argv[0], ENC(db)); 
  zVal = sqliteMalloc(len+3);
  zVal[len] = 0;
  zVal[len-1] = 0;
  assert( zVal );
  zVal++;
  memcpy(zVal, sqlite3ValueText(argv[0], ENC(db)), len);
  if( ENC(db)==SQLITE_UTF8 ){
    sqlite3_result_text(pCtx, zVal, -1, destructor);
#ifndef SQLITE_OMIT_UTF16
  }else if( ENC(db)==SQLITE_UTF16LE ){
    sqlite3_result_text16le(pCtx, zVal, -1, destructor);
  }else{
    sqlite3_result_text16be(pCtx, zVal, -1, destructor);
#endif /* SQLITE_OMIT_UTF16 */
  }
}
static void test_destructor_count(
  sqlite3_context *pCtx, 
  int nArg,
  sqlite3_value **argv
){

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕久久午夜不卡| 波多野结衣中文字幕一区二区三区| 蜜臀久久99精品久久久久久9| 成人黄色综合网站| 欧美一区二区成人| 亚洲午夜久久久| 一本到三区不卡视频| 精品区一区二区| 美女国产一区二区三区| 91精品久久久久久久99蜜桃| 亚洲一区免费在线观看| 成人福利在线看| 久久久夜色精品亚洲| 蜜臀va亚洲va欧美va天堂| 欧美日本免费一区二区三区| 亚洲国产精品久久人人爱| 国产98色在线|日韩| 精品国产电影一区二区| 美国十次了思思久久精品导航| 欧美一卡二卡在线观看| 美女视频黄免费的久久 | 亚洲女同ⅹxx女同tv| www.综合网.com| 亚洲视频电影在线| 欧美高清hd18日本| 国产伦精一区二区三区| 国产精品国产三级国产| 在线观看日韩一区| 久久99精品久久久| 日韩美女啊v在线免费观看| 欧美日韩国产欧美日美国产精品| 久久av中文字幕片| 日韩伦理电影网| 欧美精品久久久久久久多人混战 | 国产美女在线观看一区| 国产精品久99| 精品久久人人做人人爰| 色久综合一二码| 国产精品原创巨作av| 亚洲女厕所小便bbb| 欧美精品一区二区不卡| 欧美日韩精品高清| 99r国产精品| 国产精选一区二区三区| 亚洲国产视频在线| 国产日韩欧美不卡| 日韩欧美www| 欧洲av一区二区嗯嗯嗯啊| 激情偷乱视频一区二区三区| 亚洲美女视频在线观看| 欧美tickling网站挠脚心| 色av综合在线| 91网站最新地址| 成人免费高清视频在线观看| 美女一区二区视频| 亚洲大片精品永久免费| 依依成人精品视频| 成人欧美一区二区三区白人| 中文字幕巨乱亚洲| 国产精品美女久久久久av爽李琼 | 蜜桃视频在线观看一区| 日韩高清国产一区在线| 亚洲成人精品在线观看| 亚洲综合男人的天堂| 成人欧美一区二区三区白人 | 欧美日韩一区在线| 欧美精品在线观看播放| 日韩精品一区在线| 91国模大尺度私拍在线视频| 91福利区一区二区三区| 欧美亚洲一区二区在线观看| 欧美在线视频你懂得| 欧美日韩国产在线观看| 欧美三级在线看| 日韩亚洲欧美在线观看| 国产喂奶挤奶一区二区三区| 久久人人97超碰com| 一区二区在线观看av| 亚洲精品国产无天堂网2021| 男女男精品网站| 成人在线综合网| 欧美日韩午夜精品| 精品国产91久久久久久久妲己| 国产精品无遮挡| 日本视频中文字幕一区二区三区| 成人av在线网| 欧美三级电影网站| 日韩一区国产二区欧美三区| 亚洲欧洲精品天堂一级| 免费一区二区视频| 在线不卡的av| 一区二区久久久久| 国产乱国产乱300精品| 这里只有精品视频在线观看| 久久99久久久久久久久久久| 国产精品一二三在| 欧美一区二区三区性视频| 国产精品久久久久久福利一牛影视| 日韩电影免费在线观看网站| 色菇凉天天综合网| 亚洲人成人一区二区在线观看 | 精品一区中文字幕| 91.com视频| 精品一区二区在线观看| 日韩欧美的一区| 蜜臀va亚洲va欧美va天堂| 9191成人精品久久| 七七婷婷婷婷精品国产| 欧美一区二区三区不卡| 石原莉奈在线亚洲二区| 日韩一级高清毛片| 国产精品综合一区二区三区| 久久精品亚洲国产奇米99| 国内久久精品视频| 欧美国产精品专区| 91原创在线视频| 日韩国产在线观看一区| 欧美videofree性高清杂交| 国产乱码精品一品二品| 亚洲丝袜制服诱惑| 91精品国产综合久久福利| 国产露脸91国语对白| 国产精品女人毛片| 7878成人国产在线观看| 经典三级一区二区| 亚洲专区一二三| 欧美高清在线视频| 欧美久久久久免费| 国产.欧美.日韩| 久久精品免费观看| 一区二区不卡在线视频 午夜欧美不卡在| 欧美日韩综合在线免费观看| 成人国产视频在线观看| 亚洲欧美一区二区三区极速播放| 2021国产精品久久精品 | 日韩欧美在线1卡| 精品盗摄一区二区三区| ...av二区三区久久精品| 国产色一区二区| 亚洲精选免费视频| 亚洲成人午夜电影| 久久精品国产亚洲高清剧情介绍 | 国产精品美女久久久久久久| 一区在线观看免费| 亚洲美腿欧美偷拍| 欧美一区二区三区色| 欧美一区二区三区视频| 91麻豆精品国产无毒不卡在线观看 | 欧美丝袜自拍制服另类| 日本韩国欧美一区二区三区| av影院午夜一区| 色先锋aa成人| 91精品欧美福利在线观看| 欧美一三区三区四区免费在线看 | 国产成人综合亚洲91猫咪| 精品一区精品二区高清| 成人性生交大片免费看视频在线| 国产一区999| 色天天综合色天天久久| 欧美日本在线一区| 国产亚洲欧洲997久久综合| 亚洲视频综合在线| 亚洲成人资源网| 国产成人自拍网| 欧美日韩黄色影视| 国产亚洲一二三区| 亚洲一二三四在线观看| 精品一区二区国语对白| 91丨porny丨中文| 日韩亚洲欧美综合| 亚洲靠逼com| 黄色日韩网站视频| 欧美色网一区二区| 久久色视频免费观看| 免费观看30秒视频久久| 国产一区二区精品在线观看| 久久国内精品视频| 韩国一区二区在线观看| 狠狠色综合播放一区二区| 韩国视频一区二区| 国产在线不卡一区| 一本一道综合狠狠老| 欧美tk丨vk视频| 国产精品视频观看| 亚洲综合偷拍欧美一区色| 久久66热re国产| 4438成人网| 一区二区三区电影在线播| 亚洲嫩草精品久久| 久久精品国产免费| 99久久精品费精品国产一区二区| 欧美日韩一区二区在线视频| 国产亚洲女人久久久久毛片| 亚洲国产高清aⅴ视频| 天堂久久一区二区三区| 日韩av电影免费观看高清完整版在线观看| 爽好久久久欧美精品| 91国产视频在线观看| 亚洲精品一二三四区| av中文字幕在线不卡|