⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 test_loadext.c

📁 最新的sqlite3.6.2源代码
💻 C
字号:
/*** 2006 June 14**** 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.***************************************************************************** Test extension for testing the sqlite3_load_extension() function.**** $Id: test_loadext.c,v 1.3 2008/08/02 03:50:39 drh Exp $*/#include <string.h>#include "sqlite3ext.h"SQLITE_EXTENSION_INIT1/*** The half() SQL function returns half of its input value.*/static void halfFunc(  sqlite3_context *context,  int argc,  sqlite3_value **argv){  sqlite3_result_double(context, 0.5*sqlite3_value_double(argv[0]));}/*** SQL functions to call the sqlite3_status function and return results.*/static void statusFunc(  sqlite3_context *context,  int argc,  sqlite3_value **argv){  int op, mx, cur, resetFlag, rc;  if( sqlite3_value_type(argv[0])==SQLITE_INTEGER ){    op = sqlite3_value_int(argv[0]);  }else if( sqlite3_value_type(argv[0])==SQLITE_TEXT ){    int i;    const char *zName;    static const struct {      const char *zName;      int op;    } aOp[] = {      { "MEMORY_USED",         SQLITE_STATUS_MEMORY_USED         },      { "PAGECACHE_USED",      SQLITE_STATUS_PAGECACHE_USED      },      { "PAGECACHE_OVERFLOW",  SQLITE_STATUS_PAGECACHE_OVERFLOW  },      { "SCRATCH_USED",        SQLITE_STATUS_SCRATCH_USED        },      { "SCRATCH_OVERFLOW",    SQLITE_STATUS_SCRATCH_OVERFLOW    },      { "MALLOC_SIZE",         SQLITE_STATUS_MALLOC_SIZE         },    };    int nOp = sizeof(aOp)/sizeof(aOp[0]);    zName = (const char*)sqlite3_value_text(argv[0]);    for(i=0; i<nOp; i++){      if( strcmp(aOp[i].zName, zName)==0 ){        op = aOp[i].op;        break;      }    }    if( i>=nOp ){      char *zMsg = sqlite3_mprintf("unknown status property: %s", zName);      sqlite3_result_error(context, zMsg, -1);      sqlite3_free(zMsg);      return;    }  }else{    sqlite3_result_error(context, "unknown status type", -1);    return;  }  if( argc==2 ){    resetFlag = sqlite3_value_int(argv[1]);  }else{    resetFlag = 0;  }  rc = sqlite3_status(op, &cur, &mx, resetFlag);  if( rc!=SQLITE_OK ){    char *zMsg = sqlite3_mprintf("sqlite3_status(%d,...) returns %d", op, rc);    sqlite3_result_error(context, zMsg, -1);    sqlite3_free(zMsg);    return;  }   if( argc==2 ){    sqlite3_result_int(context, mx);  }else{    sqlite3_result_int(context, cur);  }}/*** Extension load function.*/int testloadext_init(  sqlite3 *db,   char **pzErrMsg,   const sqlite3_api_routines *pApi){  int nErr = 0;  SQLITE_EXTENSION_INIT2(pApi);  nErr |= sqlite3_create_function(db, "half", 1, SQLITE_ANY, 0, halfFunc, 0, 0);  nErr |= sqlite3_create_function(db, "sqlite3_status", 1, SQLITE_ANY, 0,                          statusFunc, 0, 0);  nErr |= sqlite3_create_function(db, "sqlite3_status", 2, SQLITE_ANY, 0,                          statusFunc, 0, 0);  return nErr ? SQLITE_ERROR : SQLITE_OK;}/*** Another extension entry point. This one always fails.*/int testbrokenext_init(  sqlite3 *db,   char **pzErrMsg,   const sqlite3_api_routines *pApi){  char *zErr;  SQLITE_EXTENSION_INIT2(pApi);  zErr = sqlite3_mprintf("broken!");  *pzErrMsg = zErr;  return 1;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -