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

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

?? vdbeapi.c

?? 新版輕量級嵌入式數據庫
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*** 2004 May 26**** The author disclaims copyright to this source code.  In place of** a legal notice, here is a blessing:****    May you do good and not evil.**    May you find forgiveness for yourself and forgive others.**    May you share freely, never taking more than you give.******************************************************************************* This file contains code use to implement APIs that are part of the** VDBE.*/#include "sqliteInt.h"#include "vdbeInt.h"#include "os.h"/*** Return TRUE (non-zero) of the statement supplied as an argument needs** to be recompiled.  A statement needs to be recompiled whenever the** execution environment changes in a way that would alter the program** that sqlite3_prepare() generates.  For example, if new functions or** collating sequences are registered or if an authorizer function is** added or changed.*/int sqlite3_expired(sqlite3_stmt *pStmt){  Vdbe *p = (Vdbe*)pStmt;  return p==0 || p->expired;}/**************************** sqlite3_value_  ********************************* The following routines extract information from a Mem or sqlite3_value** structure.*/const void *sqlite3_value_blob(sqlite3_value *pVal){  Mem *p = (Mem*)pVal;  if( p->flags & (MEM_Blob|MEM_Str) ){    return p->z;  }else{    return sqlite3_value_text(pVal);  }}int sqlite3_value_bytes(sqlite3_value *pVal){  return sqlite3ValueBytes(pVal, SQLITE_UTF8);}int sqlite3_value_bytes16(sqlite3_value *pVal){  return sqlite3ValueBytes(pVal, SQLITE_UTF16NATIVE);}double sqlite3_value_double(sqlite3_value *pVal){  return sqlite3VdbeRealValue((Mem*)pVal);}int sqlite3_value_int(sqlite3_value *pVal){  return sqlite3VdbeIntValue((Mem*)pVal);}sqlite_int64 sqlite3_value_int64(sqlite3_value *pVal){  return sqlite3VdbeIntValue((Mem*)pVal);}const unsigned char *sqlite3_value_text(sqlite3_value *pVal){  return (const unsigned char *)sqlite3ValueText(pVal, SQLITE_UTF8);}#ifndef SQLITE_OMIT_UTF16const void *sqlite3_value_text16(sqlite3_value* pVal){  return sqlite3ValueText(pVal, SQLITE_UTF16NATIVE);}const void *sqlite3_value_text16be(sqlite3_value *pVal){  return sqlite3ValueText(pVal, SQLITE_UTF16BE);}const void *sqlite3_value_text16le(sqlite3_value *pVal){  return sqlite3ValueText(pVal, SQLITE_UTF16LE);}#endif /* SQLITE_OMIT_UTF16 */int sqlite3_value_type(sqlite3_value* pVal){  return pVal->type;}/* sqlite3_value_numeric_type() defined in vdbe.c *//**************************** sqlite3_result_  ********************************* The following routines are used by user-defined functions to specify** the function result.*/void sqlite3_result_blob(  sqlite3_context *pCtx,   const void *z,   int n,   void (*xDel)(void *)){  assert( n>=0 );  sqlite3VdbeMemSetStr(&pCtx->s, z, n, 0, xDel);}void sqlite3_result_double(sqlite3_context *pCtx, double rVal){  sqlite3VdbeMemSetDouble(&pCtx->s, rVal);}void sqlite3_result_error(sqlite3_context *pCtx, const char *z, int n){  pCtx->isError = 1;  sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF8, SQLITE_TRANSIENT);}#ifndef SQLITE_OMIT_UTF16void sqlite3_result_error16(sqlite3_context *pCtx, const void *z, int n){  pCtx->isError = 1;  sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16NATIVE, SQLITE_TRANSIENT);}#endifvoid sqlite3_result_int(sqlite3_context *pCtx, int iVal){  sqlite3VdbeMemSetInt64(&pCtx->s, (i64)iVal);}void sqlite3_result_int64(sqlite3_context *pCtx, i64 iVal){  sqlite3VdbeMemSetInt64(&pCtx->s, iVal);}void sqlite3_result_null(sqlite3_context *pCtx){  sqlite3VdbeMemSetNull(&pCtx->s);}void sqlite3_result_text(  sqlite3_context *pCtx,   const char *z,   int n,  void (*xDel)(void *)){  sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF8, xDel);}#ifndef SQLITE_OMIT_UTF16void sqlite3_result_text16(  sqlite3_context *pCtx,   const void *z,   int n,   void (*xDel)(void *)){  sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16NATIVE, xDel);}void sqlite3_result_text16be(  sqlite3_context *pCtx,   const void *z,   int n,   void (*xDel)(void *)){  sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16BE, xDel);}void sqlite3_result_text16le(  sqlite3_context *pCtx,   const void *z,   int n,   void (*xDel)(void *)){  sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16LE, xDel);}#endif /* SQLITE_OMIT_UTF16 */void sqlite3_result_value(sqlite3_context *pCtx, sqlite3_value *pValue){  sqlite3VdbeMemCopy(&pCtx->s, pValue);}/*** Execute the statement pStmt, either until a row of data is ready, the** statement is completely executed or an error occurs.*/int sqlite3_step(sqlite3_stmt *pStmt){  Vdbe *p = (Vdbe*)pStmt;  sqlite3 *db;  int rc;  /* Assert that malloc() has not failed */  assert( !sqlite3MallocFailed() );  if( p==0 || p->magic!=VDBE_MAGIC_RUN ){    return SQLITE_MISUSE;  }  if( p->aborted ){    return SQLITE_ABORT;  }  if( p->pc<=0 && p->expired ){    if( p->rc==SQLITE_OK ){      p->rc = SQLITE_SCHEMA;    }    return SQLITE_ERROR;  }  db = p->db;  if( sqlite3SafetyOn(db) ){    p->rc = SQLITE_MISUSE;    return SQLITE_MISUSE;  }  if( p->pc<0 ){#ifndef SQLITE_OMIT_TRACE    /* Invoke the trace callback if there is one    */    if( db->xTrace && !db->init.busy ){      assert( p->nOp>0 );      assert( p->aOp[p->nOp-1].opcode==OP_Noop );      assert( p->aOp[p->nOp-1].p3!=0 );      assert( p->aOp[p->nOp-1].p3type==P3_DYNAMIC );      sqlite3SafetyOff(db);      db->xTrace(db->pTraceArg, p->aOp[p->nOp-1].p3);      if( sqlite3SafetyOn(db) ){        p->rc = SQLITE_MISUSE;        return SQLITE_MISUSE;      }    }    if( db->xProfile && !db->init.busy ){      double rNow;      sqlite3OsCurrentTime(&rNow);      p->startTime = (rNow - (int)rNow)*3600.0*24.0*1000000000.0;    }#endif    /* Print a copy of SQL as it is executed if the SQL_TRACE pragma is turned    ** on in debugging mode.    */#ifdef SQLITE_DEBUG    if( (db->flags & SQLITE_SqlTrace)!=0 ){      sqlite3DebugPrintf("SQL-trace: %s\n", p->aOp[p->nOp-1].p3);    }#endif /* SQLITE_DEBUG */    db->activeVdbeCnt++;    p->pc = 0;  }#ifndef SQLITE_OMIT_EXPLAIN  if( p->explain ){    rc = sqlite3VdbeList(p);  }else#endif /* SQLITE_OMIT_EXPLAIN */  {    rc = sqlite3VdbeExec(p);  }  if( sqlite3SafetyOff(db) ){    rc = SQLITE_MISUSE;  }#ifndef SQLITE_OMIT_TRACE  /* Invoke the profile callback if there is one  */  if( rc!=SQLITE_ROW && db->xProfile && !db->init.busy ){    double rNow;    u64 elapseTime;    sqlite3OsCurrentTime(&rNow);    elapseTime = (rNow - (int)rNow)*3600.0*24.0*1000000000.0 - p->startTime;    assert( p->nOp>0 );    assert( p->aOp[p->nOp-1].opcode==OP_Noop );    assert( p->aOp[p->nOp-1].p3!=0 );    assert( p->aOp[p->nOp-1].p3type==P3_DYNAMIC );    db->xProfile(db->pProfileArg, p->aOp[p->nOp-1].p3, elapseTime);  }#endif  sqlite3Error(p->db, rc, 0);  p->rc = sqlite3ApiExit(p->db, p->rc);  return rc;}/*** Extract the user data from a sqlite3_context structure and return a** pointer to it.*/void *sqlite3_user_data(sqlite3_context *p){  assert( p && p->pFunc );  return p->pFunc->pUserData;}/*** Allocate or return the aggregate context for a user function.  A new** context is allocated on the first call.  Subsequent calls return the** same context that was returned on prior calls.*/void *sqlite3_aggregate_context(sqlite3_context *p, int nByte){  Mem *pMem = p->pMem;  assert( p && p->pFunc && p->pFunc->xStep );  if( (pMem->flags & MEM_Agg)==0 ){    if( nByte==0 ){      assert( pMem->flags==MEM_Null );      pMem->z = 0;    }else{      pMem->flags = MEM_Agg;      pMem->xDel = sqlite3FreeX;      *(FuncDef**)&pMem->i = p->pFunc;      if( nByte<=NBFS ){        pMem->z = pMem->zShort;        memset(pMem->z, 0, nByte);      }else{        pMem->z = sqliteMalloc( nByte );      }    }  }  return (void*)pMem->z;}/*** Return the auxilary data pointer, if any, for the iArg'th argument to** the user-function defined by pCtx.*/void *sqlite3_get_auxdata(sqlite3_context *pCtx, int iArg){  VdbeFunc *pVdbeFunc = pCtx->pVdbeFunc;  if( !pVdbeFunc || iArg>=pVdbeFunc->nAux || iArg<0 ){    return 0;  }  return pVdbeFunc->apAux[iArg].pAux;}/*** Set the auxilary data pointer and delete function, for the iArg'th** argument to the user-function defined by pCtx. Any previous value is** deleted by calling the delete function specified when it was set.*/void sqlite3_set_auxdata(  sqlite3_context *pCtx,   int iArg,   void *pAux,   void (*xDelete)(void*)){  struct AuxData *pAuxData;  VdbeFunc *pVdbeFunc;  if( iArg<0 ) return;  pVdbeFunc = pCtx->pVdbeFunc;  if( !pVdbeFunc || pVdbeFunc->nAux<=iArg ){    int nMalloc = sizeof(VdbeFunc) + sizeof(struct AuxData)*iArg;    pVdbeFunc = sqliteRealloc(pVdbeFunc, nMalloc);    if( !pVdbeFunc ) return;    pCtx->pVdbeFunc = pVdbeFunc;    memset(&pVdbeFunc->apAux[pVdbeFunc->nAux], 0,              sizeof(struct AuxData)*(iArg+1-pVdbeFunc->nAux));    pVdbeFunc->nAux = iArg+1;    pVdbeFunc->pFunc = pCtx->pFunc;  }  pAuxData = &pVdbeFunc->apAux[iArg];  if( pAuxData->pAux && pAuxData->xDelete ){    pAuxData->xDelete(pAuxData->pAux);  }  pAuxData->pAux = pAux;  pAuxData->xDelete = xDelete;}/*** Return the number of times the Step function of a aggregate has been ** called.**** This function is deprecated.  Do not use it for new code.  It is** provide only to avoid breaking legacy code.  New aggregate function** implementations should keep their own counts within their aggregate** context.*/int sqlite3_aggregate_count(sqlite3_context *p){  assert( p && p->pFunc && p->pFunc->xStep );  return p->pMem->n;}/*** Return the number of columns in the result set for the statement pStmt.*/int sqlite3_column_count(sqlite3_stmt *pStmt){  Vdbe *pVm = (Vdbe *)pStmt;  return pVm ? pVm->nResColumn : 0;}/*** Return the number of values available from the current row of the** currently executing statement pStmt.*/int sqlite3_data_count(sqlite3_stmt *pStmt){  Vdbe *pVm = (Vdbe *)pStmt;  if( pVm==0 || !pVm->resOnStack ) return 0;  return pVm->nResColumn;}/*** Check to see if column iCol of the given statement is valid.  If** it is, return a pointer to the Mem for the value of that column.** If iCol is not valid, return a pointer to a Mem which has a value** of NULL.*/static Mem *columnMem(sqlite3_stmt *pStmt, int i){  Vdbe *pVm = (Vdbe *)pStmt;  int vals = sqlite3_data_count(pStmt);  if( i>=vals || i<0 ){    static Mem nullMem;    if( nullMem.flags==0 ){ nullMem.flags = MEM_Null; }    sqlite3Error(pVm->db, SQLITE_RANGE, 0);    return &nullMem;  }  return &pVm->pTos[(1-vals)+i];}/*** This function is called after invoking an sqlite3_value_XXX function on a ** column value (i.e. a value returned by evaluating an SQL expression in the** select list of a SELECT statement) that may cause a malloc() failure. If ** malloc() has failed, the threads mallocFailed flag is cleared and the result** code of statement pStmt set to SQLITE_NOMEM.**** Specificly, this is called from within:****     sqlite3_column_int()**     sqlite3_column_int64()**     sqlite3_column_text()**     sqlite3_column_text16()**     sqlite3_column_real()**     sqlite3_column_bytes()**     sqlite3_column_bytes16()**** But not for sqlite3_column_blob(), which never calls malloc().*/static void columnMallocFailure(sqlite3_stmt *pStmt){  /* If malloc() failed during an encoding conversion within an  ** sqlite3_column_XXX API, then set the return code of the statement to

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
高清久久久久久| 亚洲国产精品v| 欧美视频精品在线观看| 欧亚洲嫩模精品一区三区| 色综合中文字幕国产| av一区二区三区在线| 99精品一区二区三区| av动漫一区二区| 91福利社在线观看| 欧美色图激情小说| 91精品国产黑色紧身裤美女| 欧美精品777| 精品女同一区二区| 国产拍揄自揄精品视频麻豆| 国产精品伦理在线| 一区二区国产视频| 美女国产一区二区三区| 美腿丝袜亚洲一区| 国产成人精品网址| 色婷婷亚洲一区二区三区| 欧美老人xxxx18| 精品久久国产字幕高潮| 国产日韩欧美在线一区| 日韩一区在线播放| 亚洲午夜日本在线观看| 蜜桃传媒麻豆第一区在线观看| 精品一区二区三区免费播放| 国产成人在线视频网址| 色综合视频在线观看| 欧美日韩国产精品成人| 精品国产网站在线观看| 国产日韩高清在线| 亚洲综合激情另类小说区| 视频一区在线播放| 国产精品综合久久| 色94色欧美sute亚洲线路二| 91精品婷婷国产综合久久竹菊| 久久影视一区二区| 亚洲激情图片qvod| 精品在线免费观看| 色综合天天综合在线视频| 日韩一级片网址| 亚洲欧洲在线观看av| 轻轻草成人在线| 成人午夜精品在线| 538prom精品视频线放| 久久久天堂av| 天堂成人免费av电影一区| 国产成人综合亚洲网站| 在线一区二区视频| 久久综合九色综合欧美98| 《视频一区视频二区| 免费av成人在线| 在线观看日韩毛片| 久久久久久久久蜜桃| 亚洲va在线va天堂| 成人免费毛片app| 精品日韩99亚洲| 亚洲一区中文日韩| 成人午夜视频在线| 欧美精品一区二区久久婷婷| 一二三四社区欧美黄| 国产成人自拍网| 91精品国产一区二区| 亚洲精品视频一区| 国产大片一区二区| 精品国内片67194| 日韩1区2区3区| 91免费在线视频观看| 久久久久青草大香线综合精品| 五月天视频一区| 色88888久久久久久影院野外| 久久久综合视频| 捆绑变态av一区二区三区| 欧美视频一区二区在线观看| 国产精品传媒入口麻豆| 国产精品资源在线看| 日韩欧美国产系列| 天堂影院一区二区| 精品视频资源站| 亚洲综合无码一区二区| 91首页免费视频| 国产精品理伦片| 丁香桃色午夜亚洲一区二区三区| 日韩欧美在线综合网| 日韩精品欧美精品| 欧美日韩精品一区二区三区四区 | 精品国产第一区二区三区观看体验| 亚洲永久免费av| 日本韩国精品一区二区在线观看| 国产欧美日韩在线| 国产一区二区三区在线看麻豆| 91麻豆精品国产91久久久久久久久 | 国产毛片精品一区| 久久午夜电影网| 狠狠色丁香婷婷综合| 精品日韩在线观看| 国产美女一区二区| 国产欧美一区二区精品忘忧草| 激情欧美一区二区| 国产午夜精品久久| 成人激情免费视频| 国产精品电影一区二区三区| av在线不卡免费看| 亚洲精选视频在线| 91麻豆swag| 亚洲一级在线观看| 91精品综合久久久久久| 日韩国产欧美在线观看| 日韩一级片在线观看| 狠狠色狠狠色合久久伊人| 2020国产成人综合网| 国产精品自拍在线| 中文字幕中文乱码欧美一区二区 | 欧美性生活大片视频| 亚洲123区在线观看| 欧美日韩国产一区| 蜜臀国产一区二区三区在线播放| 日韩欧美国产电影| 国产精华液一区二区三区| 欧美国产日本韩| 日本精品一区二区三区高清 | 国产精品99久久久久久有的能看 | 一区二区三区免费在线观看| 欧美日韩久久久| 免费在线观看一区| 国产偷国产偷亚洲高清人白洁| 成人高清免费在线播放| 亚洲欧美色综合| 在线播放欧美女士性生活| 国产在线精品免费av| 欧美国产禁国产网站cc| 欧美体内she精视频| 麻豆久久久久久| 中文av字幕一区| 欧美写真视频网站| 国产一区二区三区免费在线观看| 欧美国产欧美综合| 欧美日韩在线三级| 国产在线日韩欧美| 一区二区三区视频在线看| 91精品国产黑色紧身裤美女| 国产精品综合一区二区三区| 亚洲免费av网站| 欧美一级黄色大片| caoporm超碰国产精品| 日本91福利区| 亚洲天堂久久久久久久| 在线电影国产精品| 成人妖精视频yjsp地址| 日韩va欧美va亚洲va久久| 欧美激情一区二区三区| 6080亚洲精品一区二区| av在线综合网| 免费在线观看一区二区三区| 成人免费在线视频| 欧美本精品男人aⅴ天堂| 成人av网址在线| 免费日韩伦理电影| 最新国产成人在线观看| 精品国产乱码久久久久久闺蜜| 色婷婷久久久久swag精品| 精品一区二区三区免费播放| 1000部国产精品成人观看| 欧美精品一区二区蜜臀亚洲| 欧美亚洲一区二区在线观看| 从欧美一区二区三区| 日韩高清欧美激情| 一区二区三区.www| 国产欧美va欧美不卡在线| 91精品国产色综合久久ai换脸| av不卡在线观看| 国产自产2019最新不卡| 视频一区在线播放| 亚洲自拍欧美精品| 国产精品久久久久久久裸模| 日韩欧美国产高清| 欧美狂野另类xxxxoooo| 99国产精品国产精品毛片| 韩国av一区二区三区四区| 日韩国产精品大片| 亚洲五月六月丁香激情| 亚洲欧洲性图库| 久久久九九九九| 精品欧美乱码久久久久久1区2区| 欧美日韩不卡一区二区| 色天使色偷偷av一区二区| 国产福利一区二区三区| 久久99精品国产麻豆婷婷洗澡| 亚洲午夜久久久久久久久电影网| 国产精品毛片久久久久久久| 久久久高清一区二区三区| 欧美成人乱码一区二区三区| 欧美日韩亚洲另类| 色噜噜久久综合| 91在线观看高清| 色婷婷av一区二区三区gif| 99精品国产视频| 99这里只有久久精品视频| 懂色av一区二区三区免费观看|