xref: /sqlite-3.40.0/src/test_loadext.c (revision 8ccdef6b)
169e777f3Sdanielk1977 /*
269e777f3Sdanielk1977 ** 2006 June 14
369e777f3Sdanielk1977 **
469e777f3Sdanielk1977 ** The author disclaims copyright to this source code.  In place of
569e777f3Sdanielk1977 ** a legal notice, here is a blessing:
669e777f3Sdanielk1977 **
769e777f3Sdanielk1977 **    May you do good and not evil.
869e777f3Sdanielk1977 **    May you find forgiveness for yourself and forgive others.
969e777f3Sdanielk1977 **    May you share freely, never taking more than you give.
1069e777f3Sdanielk1977 **
1169e777f3Sdanielk1977 *************************************************************************
1269e777f3Sdanielk1977 ** Test extension for testing the sqlite3_load_extension() function.
1369e777f3Sdanielk1977 */
14d72a8414Sdrh #include <string.h>
1569e777f3Sdanielk1977 #include "sqlite3ext.h"
1669e777f3Sdanielk1977 SQLITE_EXTENSION_INIT1
1769e777f3Sdanielk1977 
1869e777f3Sdanielk1977 /*
1969e777f3Sdanielk1977 ** The half() SQL function returns half of its input value.
2069e777f3Sdanielk1977 */
halfFunc(sqlite3_context * context,int argc,sqlite3_value ** argv)2169e777f3Sdanielk1977 static void halfFunc(
2269e777f3Sdanielk1977   sqlite3_context *context,
2369e777f3Sdanielk1977   int argc,
2469e777f3Sdanielk1977   sqlite3_value **argv
2569e777f3Sdanielk1977 ){
2669e777f3Sdanielk1977   sqlite3_result_double(context, 0.5*sqlite3_value_double(argv[0]));
2769e777f3Sdanielk1977 }
2869e777f3Sdanielk1977 
2969e777f3Sdanielk1977 /*
30d72a8414Sdrh ** SQL functions to call the sqlite3_status function and return results.
31d72a8414Sdrh */
statusFunc(sqlite3_context * context,int argc,sqlite3_value ** argv)32d72a8414Sdrh static void statusFunc(
33d72a8414Sdrh   sqlite3_context *context,
34d72a8414Sdrh   int argc,
35d72a8414Sdrh   sqlite3_value **argv
36d72a8414Sdrh ){
37*8ccdef6bSmistachkin   int op = 0, mx, cur, resetFlag, rc;
38d72a8414Sdrh   if( sqlite3_value_type(argv[0])==SQLITE_INTEGER ){
39d72a8414Sdrh     op = sqlite3_value_int(argv[0]);
40d72a8414Sdrh   }else if( sqlite3_value_type(argv[0])==SQLITE_TEXT ){
41d72a8414Sdrh     int i;
42d72a8414Sdrh     const char *zName;
43d72a8414Sdrh     static const struct {
44d72a8414Sdrh       const char *zName;
45d72a8414Sdrh       int op;
46d72a8414Sdrh     } aOp[] = {
47d72a8414Sdrh       { "MEMORY_USED",         SQLITE_STATUS_MEMORY_USED         },
48d72a8414Sdrh       { "PAGECACHE_USED",      SQLITE_STATUS_PAGECACHE_USED      },
49d72a8414Sdrh       { "PAGECACHE_OVERFLOW",  SQLITE_STATUS_PAGECACHE_OVERFLOW  },
50d72a8414Sdrh       { "SCRATCH_USED",        SQLITE_STATUS_SCRATCH_USED        },
51d72a8414Sdrh       { "SCRATCH_OVERFLOW",    SQLITE_STATUS_SCRATCH_OVERFLOW    },
52d72a8414Sdrh       { "MALLOC_SIZE",         SQLITE_STATUS_MALLOC_SIZE         },
53d72a8414Sdrh     };
54d72a8414Sdrh     int nOp = sizeof(aOp)/sizeof(aOp[0]);
55d72a8414Sdrh     zName = (const char*)sqlite3_value_text(argv[0]);
56d72a8414Sdrh     for(i=0; i<nOp; i++){
57d72a8414Sdrh       if( strcmp(aOp[i].zName, zName)==0 ){
58d72a8414Sdrh         op = aOp[i].op;
59d72a8414Sdrh         break;
60d72a8414Sdrh       }
61d72a8414Sdrh     }
62d72a8414Sdrh     if( i>=nOp ){
63d72a8414Sdrh       char *zMsg = sqlite3_mprintf("unknown status property: %s", zName);
64d72a8414Sdrh       sqlite3_result_error(context, zMsg, -1);
65d72a8414Sdrh       sqlite3_free(zMsg);
66d72a8414Sdrh       return;
67d72a8414Sdrh     }
68d72a8414Sdrh   }else{
69d72a8414Sdrh     sqlite3_result_error(context, "unknown status type", -1);
70d72a8414Sdrh     return;
71d72a8414Sdrh   }
72d72a8414Sdrh   if( argc==2 ){
73d72a8414Sdrh     resetFlag = sqlite3_value_int(argv[1]);
74d72a8414Sdrh   }else{
75d72a8414Sdrh     resetFlag = 0;
76d72a8414Sdrh   }
77d72a8414Sdrh   rc = sqlite3_status(op, &cur, &mx, resetFlag);
78d72a8414Sdrh   if( rc!=SQLITE_OK ){
79d72a8414Sdrh     char *zMsg = sqlite3_mprintf("sqlite3_status(%d,...) returns %d", op, rc);
80d72a8414Sdrh     sqlite3_result_error(context, zMsg, -1);
81d72a8414Sdrh     sqlite3_free(zMsg);
82d72a8414Sdrh     return;
83d72a8414Sdrh   }
84d72a8414Sdrh   if( argc==2 ){
85d72a8414Sdrh     sqlite3_result_int(context, mx);
86d72a8414Sdrh   }else{
87d72a8414Sdrh     sqlite3_result_int(context, cur);
88d72a8414Sdrh   }
89d72a8414Sdrh }
90d72a8414Sdrh 
91d72a8414Sdrh /*
9269e777f3Sdanielk1977 ** Extension load function.
9369e777f3Sdanielk1977 */
941925a2e6Smistachkin #ifdef _WIN32
951925a2e6Smistachkin __declspec(dllexport)
961925a2e6Smistachkin #endif
testloadext_init(sqlite3 * db,char ** pzErrMsg,const sqlite3_api_routines * pApi)9769e777f3Sdanielk1977 int testloadext_init(
9869e777f3Sdanielk1977   sqlite3 *db,
9969e777f3Sdanielk1977   char **pzErrMsg,
10069e777f3Sdanielk1977   const sqlite3_api_routines *pApi
10169e777f3Sdanielk1977 ){
102701bb3b4Sdrh   int nErr = 0;
10369e777f3Sdanielk1977   SQLITE_EXTENSION_INIT2(pApi);
104701bb3b4Sdrh   nErr |= sqlite3_create_function(db, "half", 1, SQLITE_ANY, 0, halfFunc, 0, 0);
105701bb3b4Sdrh   nErr |= sqlite3_create_function(db, "sqlite3_status", 1, SQLITE_ANY, 0,
106d72a8414Sdrh                           statusFunc, 0, 0);
107701bb3b4Sdrh   nErr |= sqlite3_create_function(db, "sqlite3_status", 2, SQLITE_ANY, 0,
108d72a8414Sdrh                           statusFunc, 0, 0);
109701bb3b4Sdrh   return nErr ? SQLITE_ERROR : SQLITE_OK;
11069e777f3Sdanielk1977 }
11169e777f3Sdanielk1977 
11269e777f3Sdanielk1977 /*
11369e777f3Sdanielk1977 ** Another extension entry point. This one always fails.
11469e777f3Sdanielk1977 */
1151925a2e6Smistachkin #ifdef _WIN32
1161925a2e6Smistachkin __declspec(dllexport)
1171925a2e6Smistachkin #endif
testbrokenext_init(sqlite3 * db,char ** pzErrMsg,const sqlite3_api_routines * pApi)11869e777f3Sdanielk1977 int testbrokenext_init(
11969e777f3Sdanielk1977   sqlite3 *db,
12069e777f3Sdanielk1977   char **pzErrMsg,
12169e777f3Sdanielk1977   const sqlite3_api_routines *pApi
12269e777f3Sdanielk1977 ){
12369e777f3Sdanielk1977   char *zErr;
12469e777f3Sdanielk1977   SQLITE_EXTENSION_INIT2(pApi);
12569e777f3Sdanielk1977   zErr = sqlite3_mprintf("broken!");
12669e777f3Sdanielk1977   *pzErrMsg = zErr;
12769e777f3Sdanielk1977   return 1;
12869e777f3Sdanielk1977 }
129