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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? vdbeint.h

?? sqlite 3.3.8 支持加密的版本
?? H
?? 第 1 頁 / 共 2 頁
字號:
/*** 2003 September 6**** 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 is the header file for information that is private to the** VDBE.  This information used to all be at the top of the single** source code file "vdbe.c".  When that file became too big (over** 6000 lines long) it was split up into several smaller files and** this header information was factored out.*//*** intToKey() and keyToInt() used to transform the rowid.  But with** the latest versions of the design they are no-ops.*/#define keyToInt(X)   (X)#define intToKey(X)   (X)/*** The makefile scans the vdbe.c source file and creates the following** array of string constants which are the names of all VDBE opcodes.  This** array is defined in a separate source code file named opcode.c which is** automatically generated by the makefile.*/extern char *sqlite3OpcodeNames[];/*** SQL is translated into a sequence of instructions to be** executed by a virtual machine.  Each instruction is an instance** of the following structure.*/typedef struct VdbeOp Op;/*** Boolean values*/typedef unsigned char Bool;/*** A cursor is a pointer into a single BTree within a database file.** The cursor can seek to a BTree entry with a particular key, or** loop over all entries of the Btree.  You can also insert new BTree** entries or retrieve the key or data from the entry that the cursor** is currently pointing to.** ** Every cursor that the virtual machine has open is represented by an** instance of the following structure.**** If the Cursor.isTriggerRow flag is set it means that this cursor is** really a single row that represents the NEW or OLD pseudo-table of** a row trigger.  The data for the row is stored in Cursor.pData and** the rowid is in Cursor.iKey.*/struct Cursor {  BtCursor *pCursor;    /* The cursor structure of the backend */  int iDb;              /* Index of cursor database in db->aDb[] (or -1) */  i64 lastRowid;        /* Last rowid from a Next or NextIdx operation */  i64 nextRowid;        /* Next rowid returned by OP_NewRowid */  Bool zeroed;          /* True if zeroed out and ready for reuse */  Bool rowidIsValid;    /* True if lastRowid is valid */  Bool atFirst;         /* True if pointing to first entry */  Bool useRandomRowid;  /* Generate new record numbers semi-randomly */  Bool nullRow;         /* True if pointing to a row with no data */  Bool nextRowidValid;  /* True if the nextRowid field is valid */  Bool pseudoTable;     /* This is a NEW or OLD pseudo-tables of a trigger */  Bool deferredMoveto;  /* A call to sqlite3BtreeMoveto() is needed */  Bool isTable;         /* True if a table requiring integer keys */  Bool isIndex;         /* True if an index containing keys only - no data */  u8 bogusIncrKey;      /* Something for pIncrKey to point to if pKeyInfo==0 */  i64 movetoTarget;     /* Argument to the deferred sqlite3BtreeMoveto() */  Btree *pBt;           /* Separate file holding temporary table */  int nData;            /* Number of bytes in pData */  char *pData;          /* Data for a NEW or OLD pseudo-table */  i64 iKey;             /* Key for the NEW or OLD pseudo-table row */  u8 *pIncrKey;         /* Pointer to pKeyInfo->incrKey */  KeyInfo *pKeyInfo;    /* Info about index keys needed by index cursors */  int nField;           /* Number of fields in the header */  i64 seqCount;         /* Sequence counter */  sqlite3_vtab_cursor *pVtabCursor;  /* The cursor for a virtual table */  const sqlite3_module *pModule;     /* Module for cursor pVtabCursor */  /* Cached information about the header for the data record that the  ** cursor is currently pointing to.  Only valid if cacheValid is true.  ** aRow might point to (ephemeral) data for the current row, or it might  ** be NULL.  */  int cacheStatus;      /* Cache is valid if this matches Vdbe.cacheCtr */  int payloadSize;      /* Total number of bytes in the record */  u32 *aType;           /* Type values for all entries in the record */  u32 *aOffset;         /* Cached offsets to the start of each columns data */  u8 *aRow;             /* Data for the current row, if all on one page */};typedef struct Cursor Cursor;/*** Number of bytes of string storage space available to each stack** layer without having to malloc.  NBFS is short for Number of Bytes** For Strings.*/#define NBFS 32/*** A value for Cursor.cacheValid that means the cache is always invalid.*/#define CACHE_STALE 0/*** Internally, the vdbe manipulates nearly all SQL values as Mem** structures. Each Mem struct may cache multiple representations (string,** integer etc.) of the same value.  A value (and therefore Mem structure)** has the following properties:**** Each value has a manifest type. The manifest type of the value stored** in a Mem struct is returned by the MemType(Mem*) macro. The type is** one of SQLITE_NULL, SQLITE_INTEGER, SQLITE_REAL, SQLITE_TEXT or** SQLITE_BLOB.*/struct Mem {  i64 i;              /* Integer value. Or FuncDef* when flags==MEM_Agg */  double r;           /* Real value */  char *z;            /* String or BLOB value */  int n;              /* Number of characters in string value, including '\0' */  u16 flags;          /* Some combination of MEM_Null, MEM_Str, MEM_Dyn, etc. */  u8  type;           /* One of MEM_Null, MEM_Str, etc. */  u8  enc;            /* TEXT_Utf8, TEXT_Utf16le, or TEXT_Utf16be */  void (*xDel)(void *);  /* If not null, call this function to delete Mem.z */  char zShort[NBFS];  /* Space for short strings */};typedef struct Mem Mem;/* One or more of the following flags are set to indicate the validOK** representations of the value stored in the Mem struct.**** If the MEM_Null flag is set, then the value is an SQL NULL value.** No other flags may be set in this case.**** If the MEM_Str flag is set then Mem.z points at a string representation.** Usually this is encoded in the same unicode encoding as the main** database (see below for exceptions). If the MEM_Term flag is also** set, then the string is nul terminated. The MEM_Int and MEM_Real ** flags may coexist with the MEM_Str flag.**** Multiple of these values can appear in Mem.flags.  But only one** at a time can appear in Mem.type.*/#define MEM_Null      0x0001   /* Value is NULL */#define MEM_Str       0x0002   /* Value is a string */#define MEM_Int       0x0004   /* Value is an integer */#define MEM_Real      0x0008   /* Value is a real number */#define MEM_Blob      0x0010   /* Value is a BLOB *//* Whenever Mem contains a valid string or blob representation, one of** the following flags must be set to determine the memory management** policy for Mem.z.  The MEM_Term flag tells us whether or not the** string is \000 or \u0000 terminated*/#define MEM_Term      0x0020   /* String rep is nul terminated */#define MEM_Dyn       0x0040   /* Need to call sqliteFree() on Mem.z */#define MEM_Static    0x0080   /* Mem.z points to a static string */#define MEM_Ephem     0x0100   /* Mem.z points to an ephemeral string */#define MEM_Short     0x0200   /* Mem.z points to Mem.zShort */#define MEM_Agg       0x0400   /* Mem.z points to an agg function context *//* A VdbeFunc is just a FuncDef (defined in sqliteInt.h) that contains** additional information about auxiliary information bound to arguments** of the function.  This is used to implement the sqlite3_get_auxdata()** and sqlite3_set_auxdata() APIs.  The "auxdata" is some auxiliary data** that can be associated with a constant argument to a function.  This** allows functions such as "regexp" to compile their constant regular** expression argument once and reused the compiled code for multiple** invocations.*/struct VdbeFunc {  FuncDef *pFunc;               /* The definition of the function */  int nAux;                     /* Number of entries allocated for apAux[] */  struct AuxData {    void *pAux;                   /* Aux data for the i-th argument */    void (*xDelete)(void *);      /* Destructor for the aux data */  } apAux[1];                   /* One slot for each function argument */};typedef struct VdbeFunc VdbeFunc;/*** The "context" argument for a installable function.  A pointer to an** instance of this structure is the first argument to the routines used** implement the SQL functions.**** There is a typedef for this structure in sqlite.h.  So all routines,** even the public interface to SQLite, can use a pointer to this structure.** But this file is the only place where the internal details of this** structure are known.**** This structure is defined inside of vdbeInt.h because it uses substructures** (Mem) which are only defined there.

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品亚洲专一区二区三区| 免费精品视频在线| 欧美一级黄色录像| 91在线你懂得| 激情欧美一区二区| 午夜精品久久久| 伊人性伊人情综合网| 欧美一级片在线| 欧美亚洲尤物久久| 99久久婷婷国产综合精品电影 | 91视频国产观看| 国产成人亚洲精品狼色在线 | k8久久久一区二区三区| 免费观看成人av| 日本女人一区二区三区| 亚洲国产视频网站| 一区二区三区日韩在线观看| 国产网红主播福利一区二区| 日韩欧美一区二区视频| 欧美日本一道本| 欧美精品在线一区二区三区| 欧美人xxxx| 欧美麻豆精品久久久久久| 在线看国产日韩| 欧美三区在线观看| 正在播放亚洲一区| 精品久久久久久最新网址| 91麻豆精品久久久久蜜臀| 在线91免费看| 99免费精品视频| 亚洲va在线va天堂| 国产日产欧美一区二区三区| 在线免费一区三区| 制服丝袜一区二区三区| 3d动漫精品啪啪一区二区竹菊| 欧美在线不卡视频| 91精品国产综合久久国产大片| 51精品久久久久久久蜜臀| 欧美第一区第二区| 欧美国产激情二区三区| 国产精品久久久久久妇女6080| 亚洲欧洲色图综合| 男人的j进女人的j一区| 国产一区91精品张津瑜| 99久久99久久综合| 欧美久久久久久久久久| 国产欧美日韩综合精品一区二区| 国产精品福利一区二区| 亚洲国产精品一区二区久久| 久久91精品国产91久久小草| 91麻豆swag| 26uuu国产在线精品一区二区| 中文字幕中文字幕中文字幕亚洲无线| 一区二区三区精品在线| 国产精品香蕉一区二区三区| 欧美日韩成人在线一区| 国产精品久久久久久久久久免费看| 午夜电影一区二区| 在线免费观看视频一区| 国产精品久久久久久久久免费桃花 | 国产精品无人区| 日本女优在线视频一区二区| 91日韩精品一区| 亚洲欧洲在线观看av| 国产激情一区二区三区| 日韩欧美高清一区| 日韩中文字幕1| 97超碰欧美中文字幕| 综合久久久久久久| 成人精品免费看| 欧美精彩视频一区二区三区| 久久爱www久久做| 日韩限制级电影在线观看| 三级久久三级久久久| 日韩欧美一区二区久久婷婷| 日日噜噜夜夜狠狠视频欧美人 | 激情综合色综合久久综合| 91精品国产综合久久福利| 一区二区三区中文在线观看| 91色视频在线| 日韩精品免费专区| 538在线一区二区精品国产| 日韩高清在线不卡| 精品成人一区二区三区| 成人短视频下载| 视频一区二区欧美| 欧美精品一区二区久久久| 国产精品一卡二卡| 中文一区二区完整视频在线观看| 成人深夜在线观看| 亚洲国产成人av好男人在线观看| 91精品综合久久久久久| 国产成人在线视频免费播放| 成人欧美一区二区三区视频网页| 色婷婷国产精品久久包臀| 丝袜脚交一区二区| 国产精品国产自产拍高清av| 欧美在线观看视频一区二区| 免费成人av资源网| 亚洲精品乱码久久久久久久久| 欧美日韩亚州综合| 国产精品77777| 三级一区在线视频先锋| 欧美激情一区二区三区在线| 在线观看成人小视频| 久久99日本精品| 午夜欧美在线一二页| 中文字幕一区二区三区四区| 69av一区二区三区| 在线免费不卡视频| 成人中文字幕合集| 国产精品99久久久久久久vr| 调教+趴+乳夹+国产+精品| 亚洲黄色性网站| 国产精品久久久久精k8| 欧美国产1区2区| 一区二区三区四区在线| 久久久噜噜噜久久人人看| 56国语精品自产拍在线观看| 在线视频你懂得一区| 成人18视频日本| 成人性生交大片| 国产精品亚洲а∨天堂免在线| 麻豆国产精品视频| 国产一区二区三区四区五区入口| 午夜精品一区二区三区电影天堂| 亚洲一二三区不卡| 一区二区三区日韩欧美| 亚洲影院在线观看| 亚洲成在线观看| 天天做天天摸天天爽国产一区| 午夜精品一区在线观看| 蜜臀va亚洲va欧美va天堂| 免费人成精品欧美精品| 精品一区二区在线播放| 国产剧情在线观看一区二区| 国产精品18久久久久久久久| va亚洲va日韩不卡在线观看| 99精品国产热久久91蜜凸| 欧美亚洲国产一区二区三区| 欧美日韩亚洲综合| 国产亚洲一区二区三区在线观看 | 高清不卡一区二区在线| 丁香五精品蜜臀久久久久99网站 | 亚洲国产精品久久久久婷婷884 | 午夜成人在线视频| 国产成人av电影在线| 欧美日韩精品一二三区| 久久综合给合久久狠狠狠97色69| 亚洲欧洲精品一区二区三区不卡 | 欧美成人a∨高清免费观看| 2024国产精品| 亚洲一级电影视频| 国产成人精品亚洲777人妖| 欧美日韩综合不卡| 国产精品免费看片| 免费人成精品欧美精品| 中文字幕av一区二区三区免费看| 亚洲综合视频网| 国产白丝网站精品污在线入口| 欧美三级三级三级爽爽爽| 精品剧情在线观看| 亚洲影视在线观看| 亚洲在线视频网站| 色视频一区二区| 亚洲国产电影在线观看| 久久91精品久久久久久秒播| 欧美日韩在线三区| 亚洲精品菠萝久久久久久久| 粉嫩av一区二区三区粉嫩| 欧美成人三级电影在线| 日韩国产精品久久久| 欧美三级蜜桃2在线观看| 日韩理论片一区二区| 99久久99久久精品免费看蜜桃 | 久久久精品黄色| 国产一区二区主播在线| 久久理论电影网| 国产一区二区三区| 国产日产精品1区| 不卡电影一区二区三区| 国产精品久久久久久久久久免费看 | 亚洲国产日韩综合久久精品| 色悠悠亚洲一区二区| 亚洲电影在线播放| 在线观看91av| 国产高清精品网站| 国产精品久久久久毛片软件| 成人激情av网| 亚洲电影一区二区三区| 欧美v国产在线一区二区三区| 美女视频一区二区三区| 久久精品在线免费观看| 99久久国产综合精品色伊| 午夜精品福利久久久| 欧美tk丨vk视频| 91久久精品一区二区| 亚洲一区在线观看视频| 欧美三级视频在线播放| 国产又黄又大久久|