blob: 6aee6b673d2ffe79deab83288e17f6c35889659c [file] [log] [blame]
drh4f26d6c2004-05-26 23:25:30 +00001/*
2** 2004 May 26
3**
4** The author disclaims copyright to this source code. In place of
5** a legal notice, here is a blessing:
6**
7** May you do good and not evil.
8** May you find forgiveness for yourself and forgive others.
9** May you share freely, never taking more than you give.
10**
11*************************************************************************
12**
13** This file contains code use to implement APIs that are part of the
14** VDBE.
15*/
16#include "sqliteInt.h"
17#include "vdbeInt.h"
18
19/**************************** sqlite3_value_ *******************************
20** The following routines extract information from a Mem or sqlite3_value
21** structure.
22*/
23const void *sqlite3_value_blob(sqlite3_value *pVal){
24 Mem *p = (Mem*)pVal;
25 if( p->flags & (MEM_Blob|MEM_Str) ){
26 return p->z;
27 }else{
28 return sqlite3_value_text(pVal);
29 }
30}
31int sqlite3_value_bytes(sqlite3_value *pVal){
32 Mem *p = (Mem*)pVal;
33 if( (p->flags & MEM_Blob)!=0 || sqlite3_value_text(pVal) ){
34 return p->n;
35 }
36 return 0;
37}
38int sqlite3_value_bytes16(sqlite3_value *pVal){
39 Mem *p = (Mem*)pVal;
40 if( (p->flags & MEM_Blob)!=0 || sqlite3_value_text16(pVal) ){
41 return ((Mem *)pVal)->n;
42 }
43 return 0;
44}
45double sqlite3_value_double(sqlite3_value *pVal){
46 Mem *pMem = (Mem *)pVal;
drhf4479502004-05-27 03:12:53 +000047 sqlite3VdbeMemRealify(pMem);
drh4f26d6c2004-05-26 23:25:30 +000048 return pMem->r;
49}
50int sqlite3_value_int(sqlite3_value *pVal){
51 Mem *pMem = (Mem *)pVal;
drhf4479502004-05-27 03:12:53 +000052 sqlite3VdbeMemIntegerify(pMem);
drh4f26d6c2004-05-26 23:25:30 +000053 return (int)pVal->i;
54}
55long long int sqlite3_value_int64(sqlite3_value *pVal){
56 Mem *pMem = (Mem *)pVal;
drhf4479502004-05-27 03:12:53 +000057 sqlite3VdbeMemIntegerify(pMem);
drh4f26d6c2004-05-26 23:25:30 +000058 return pVal->i;
59}
60const unsigned char *sqlite3_value_text(sqlite3_value *pVal){
danielk1977dc8453f2004-06-12 00:42:34 +000061 return (const char *)sqlite3ValueText(pVal, SQLITE_UTF8);
drh4f26d6c2004-05-26 23:25:30 +000062}
63const void *sqlite3_value_text16(sqlite3_value* pVal){
danielk1977dc8453f2004-06-12 00:42:34 +000064 return sqlite3ValueText(pVal, SQLITE_UTF16NATIVE);
drh4f26d6c2004-05-26 23:25:30 +000065}
danielk1977d8123362004-06-12 09:25:12 +000066const void *sqlite3_value_text16be(sqlite3_value *pVal){
67 return sqlite3ValueText(pVal, SQLITE_UTF16BE);
68}
69const void *sqlite3_value_text16le(sqlite3_value *pVal){
70 return sqlite3ValueText(pVal, SQLITE_UTF16LE);
71}
drh4f26d6c2004-05-26 23:25:30 +000072int sqlite3_value_type(sqlite3_value* pVal){
drhf4479502004-05-27 03:12:53 +000073 return pVal->type;
drh4f26d6c2004-05-26 23:25:30 +000074}
75
76/**************************** sqlite3_result_ *******************************
77** The following routines are used by user-defined functions to specify
78** the function result.
79*/
80void sqlite3_result_blob(
81 sqlite3_context *pCtx,
82 const void *z,
83 int n,
danielk1977d8123362004-06-12 09:25:12 +000084 void (*xDel)(void *)
drh4f26d6c2004-05-26 23:25:30 +000085){
86 assert( n>0 );
danielk1977d8123362004-06-12 09:25:12 +000087 sqlite3VdbeMemSetStr(&pCtx->s, z, n, 0, xDel);
drh4f26d6c2004-05-26 23:25:30 +000088}
89void sqlite3_result_double(sqlite3_context *pCtx, double rVal){
90 sqlite3VdbeMemSetDouble(&pCtx->s, rVal);
91}
92void sqlite3_result_error(sqlite3_context *pCtx, const char *z, int n){
93 pCtx->isError = 1;
danielk1977d8123362004-06-12 09:25:12 +000094 sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF8, SQLITE_TRANSIENT);
drh4f26d6c2004-05-26 23:25:30 +000095}
96void sqlite3_result_error16(sqlite3_context *pCtx, const void *z, int n){
97 pCtx->isError = 1;
danielk1977d8123362004-06-12 09:25:12 +000098 sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16NATIVE, SQLITE_TRANSIENT);
drh4f26d6c2004-05-26 23:25:30 +000099}
drhf4479502004-05-27 03:12:53 +0000100void sqlite3_result_int(sqlite3_context *pCtx, int iVal){
drh4f26d6c2004-05-26 23:25:30 +0000101 sqlite3VdbeMemSetInt64(&pCtx->s, (i64)iVal);
102}
103void sqlite3_result_int64(sqlite3_context *pCtx, i64 iVal){
104 sqlite3VdbeMemSetInt64(&pCtx->s, iVal);
105}
106void sqlite3_result_null(sqlite3_context *pCtx){
drhf4479502004-05-27 03:12:53 +0000107 sqlite3VdbeMemSetNull(&pCtx->s);
drh4f26d6c2004-05-26 23:25:30 +0000108}
109void sqlite3_result_text(
110 sqlite3_context *pCtx,
111 const char *z,
112 int n,
danielk1977d8123362004-06-12 09:25:12 +0000113 void (*xDel)(void *)
drh4f26d6c2004-05-26 23:25:30 +0000114){
danielk1977d8123362004-06-12 09:25:12 +0000115 sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF8, xDel);
drh4f26d6c2004-05-26 23:25:30 +0000116}
117void sqlite3_result_text16(
118 sqlite3_context *pCtx,
119 const void *z,
120 int n,
danielk1977d8123362004-06-12 09:25:12 +0000121 void (*xDel)(void *)
drh4f26d6c2004-05-26 23:25:30 +0000122){
danielk1977d8123362004-06-12 09:25:12 +0000123 sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16NATIVE, xDel);
124}
125void sqlite3_result_text16be(
126 sqlite3_context *pCtx,
127 const void *z,
128 int n,
129 void (*xDel)(void *)
130){
131 sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16BE, xDel);
132}
133void sqlite3_result_text16le(
134 sqlite3_context *pCtx,
135 const void *z,
136 int n,
137 void (*xDel)(void *)
138){
139 sqlite3VdbeMemSetStr(&pCtx->s, z, n, SQLITE_UTF16LE, xDel);
drh4f26d6c2004-05-26 23:25:30 +0000140}
141void sqlite3_result_value(sqlite3_context *pCtx, sqlite3_value *pValue){
142 sqlite3VdbeMemCopy(&pCtx->s, pValue);
143}
144
145
146/*
147** Execute the statement pStmt, either until a row of data is ready, the
148** statement is completely executed or an error occurs.
149*/
150int sqlite3_step(sqlite3_stmt *pStmt){
151 Vdbe *p = (Vdbe*)pStmt;
152 sqlite *db;
153 int rc;
154
155 if( p->magic!=VDBE_MAGIC_RUN ){
156 return SQLITE_MISUSE;
157 }
158 db = p->db;
159 if( sqlite3SafetyOn(db) ){
160 p->rc = SQLITE_MISUSE;
161 return SQLITE_MISUSE;
162 }
danielk19771d850a72004-05-31 08:26:49 +0000163 if( p->pc<0 ){
164 db->activeVdbeCnt++;
165 p->pc = 0;
166 }
drh4f26d6c2004-05-26 23:25:30 +0000167 if( p->explain ){
168 rc = sqlite3VdbeList(p);
169 }else{
170 rc = sqlite3VdbeExec(p);
171 }
172
173 if( sqlite3SafetyOff(db) ){
174 rc = SQLITE_MISUSE;
175 }
176
177 sqlite3Error(p->db, rc, p->zErrMsg);
178 return rc;
179}
180
181/*
drheb2e1762004-05-27 01:53:56 +0000182** Extract the user data from a sqlite3_context structure and return a
183** pointer to it.
184*/
185void *sqlite3_user_data(sqlite3_context *p){
186 assert( p && p->pFunc );
187 return p->pFunc->pUserData;
188}
189
190/*
191** Allocate or return the aggregate context for a user function. A new
192** context is allocated on the first call. Subsequent calls return the
193** same context that was returned on prior calls.
194**
195** This routine is defined here in vdbe.c because it depends on knowing
196** the internals of the sqlite3_context structure which is only defined in
197** this source file.
198*/
199void *sqlite3_aggregate_context(sqlite3_context *p, int nByte){
200 assert( p && p->pFunc && p->pFunc->xStep );
201 if( p->pAgg==0 ){
202 if( nByte<=NBFS ){
203 p->pAgg = (void*)p->s.z;
204 memset(p->pAgg, 0, nByte);
205 }else{
206 p->pAgg = sqliteMalloc( nByte );
207 }
208 }
209 return p->pAgg;
210}
211
212/*
danielk1977682f68b2004-06-05 10:22:17 +0000213** Return the auxilary data pointer, if any, for the iArg'th argument to
214** the user-function defined by pCtx.
215*/
216void *sqlite3_get_auxdata(sqlite3_context *pCtx, int iArg){
217 VdbeFunc *pVdbeFunc = pCtx->pVdbeFunc;
218 if( !pVdbeFunc || iArg>=pVdbeFunc->nAux || iArg<0 ){
219 return 0;
220 }
221 return pCtx->pVdbeFunc->apAux[iArg].pAux;
222}
223
224/*
225** Set the auxilary data pointer and delete function, for the iArg'th
226** argument to the user-function defined by pCtx. Any previous value is
227** deleted by calling the delete function specified when it was set.
228*/
229void sqlite3_set_auxdata(
230 sqlite3_context *pCtx,
231 int iArg,
232 void *pAux,
233 void (*xDelete)(void*)
234){
235 struct AuxData *pAuxData;
236 if( iArg<0 ) return;
237
238 if( !pCtx->pVdbeFunc || pCtx->pVdbeFunc->nAux<=iArg ){
drh998da3a2004-06-19 15:22:56 +0000239 VdbeFunc *pVdbeFunc;
240 int nMalloc = sizeof(VdbeFunc)+sizeof(struct AuxData)*iArg;
241 pCtx->pVdbeFunc = pVdbeFunc = sqliteRealloc(pCtx->pVdbeFunc, nMalloc);
242 if( !pVdbeFunc ) return;
243 pVdbeFunc->nAux = iArg+1;
244 pVdbeFunc->pFunc = pCtx->pFunc;
danielk1977682f68b2004-06-05 10:22:17 +0000245 }
246
247 pAuxData = &pCtx->pVdbeFunc->apAux[iArg];
248 if( pAuxData->pAux && pAuxData->xDelete ){
249 pAuxData->xDelete(pAuxData->pAux);
250 }
251 pAuxData->pAux = pAux;
252 pAuxData->xDelete = xDelete;
253}
254
255/*
drheb2e1762004-05-27 01:53:56 +0000256** Return the number of times the Step function of a aggregate has been
257** called.
258**
259** This routine is defined here in vdbe.c because it depends on knowing
260** the internals of the sqlite3_context structure which is only defined in
261** this source file.
262*/
263int sqlite3_aggregate_count(sqlite3_context *p){
264 assert( p && p->pFunc && p->pFunc->xStep );
265 return p->cnt;
266}
267
268/*
drh4f26d6c2004-05-26 23:25:30 +0000269** Return the number of columns in the result set for the statement pStmt.
270*/
271int sqlite3_column_count(sqlite3_stmt *pStmt){
272 Vdbe *pVm = (Vdbe *)pStmt;
273 return pVm->nResColumn;
274}
275
276/*
277** Return the number of values available from the current row of the
278** currently executing statement pStmt.
279*/
280int sqlite3_data_count(sqlite3_stmt *pStmt){
281 Vdbe *pVm = (Vdbe *)pStmt;
282 if( !pVm->resOnStack ) return 0;
283 return pVm->nResColumn;
284}
285
286
287/*
288** Check to see if column iCol of the given statement is valid. If
289** it is, return a pointer to the Mem for the value of that column.
290** If iCol is not valid, return a pointer to a Mem which has a value
291** of NULL.
292*/
293static Mem *columnMem(sqlite3_stmt *pStmt, int i){
294 Vdbe *pVm = (Vdbe *)pStmt;
295 int vals = sqlite3_data_count(pStmt);
296 if( i>=vals || i<0 ){
297 static Mem nullMem;
298 if( nullMem.flags==0 ){ nullMem.flags = MEM_Null; }
299 sqlite3Error(pVm->db, SQLITE_RANGE, 0);
300 return &nullMem;
301 }
302 return &pVm->pTos[(1-vals)+i];
303}
304
305/**************************** sqlite3_column_ *******************************
306** The following routines are used to access elements of the current row
307** in the result set.
308*/
danielk1977c572ef72004-05-27 09:28:41 +0000309const void *sqlite3_column_blob(sqlite3_stmt *pStmt, int i){
310 return sqlite3_value_blob( columnMem(pStmt,i) );
311}
drh4f26d6c2004-05-26 23:25:30 +0000312int sqlite3_column_bytes(sqlite3_stmt *pStmt, int i){
313 return sqlite3_value_bytes( columnMem(pStmt,i) );
314}
315int sqlite3_column_bytes16(sqlite3_stmt *pStmt, int i){
316 return sqlite3_value_bytes16( columnMem(pStmt,i) );
317}
318double sqlite3_column_double(sqlite3_stmt *pStmt, int i){
319 return sqlite3_value_double( columnMem(pStmt,i) );
320}
321int sqlite3_column_int(sqlite3_stmt *pStmt, int i){
322 return sqlite3_value_int( columnMem(pStmt,i) );
323}
324long long int sqlite3_column_int64(sqlite3_stmt *pStmt, int i){
325 return sqlite3_value_int64( columnMem(pStmt,i) );
326}
327const unsigned char *sqlite3_column_text(sqlite3_stmt *pStmt, int i){
328 return sqlite3_value_text( columnMem(pStmt,i) );
329}
330const void *sqlite3_column_text16(sqlite3_stmt *pStmt, int i){
331 return sqlite3_value_text16( columnMem(pStmt,i) );
332}
333int sqlite3_column_type(sqlite3_stmt *pStmt, int i){
334 return sqlite3_value_type( columnMem(pStmt,i) );
335}
336
337
338/*
339** Return the name of the Nth column of the result set returned by SQL
340** statement pStmt.
341*/
342const char *sqlite3_column_name(sqlite3_stmt *pStmt, int N){
343 Vdbe *p = (Vdbe *)pStmt;
344 Mem *pColName;
345
346 if( N>=sqlite3_column_count(pStmt) || N<0 ){
347 sqlite3Error(p->db, SQLITE_RANGE, 0);
348 return 0;
349 }
350
351 pColName = &(p->aColName[N]);
352 return sqlite3_value_text(pColName);
353}
354
355/*
356** Return the name of the 'i'th column of the result set of SQL statement
357** pStmt, encoded as UTF-16.
358*/
359const void *sqlite3_column_name16(sqlite3_stmt *pStmt, int N){
360 Vdbe *p = (Vdbe *)pStmt;
361 Mem *pColName;
362
363 if( N>=sqlite3_column_count(pStmt) || N<0 ){
364 sqlite3Error(p->db, SQLITE_RANGE, 0);
365 return 0;
366 }
367
368 pColName = &(p->aColName[N]);
369 return sqlite3_value_text16(pColName);
370}
371
drh4f26d6c2004-05-26 23:25:30 +0000372/*
373** Return the column declaration type (if applicable) of the 'i'th column
374** of the result set of SQL statement pStmt, encoded as UTF-8.
375*/
danielk197776d505b2004-05-28 13:13:02 +0000376const char *sqlite3_column_decltype(sqlite3_stmt *pStmt, int N){
drh4f26d6c2004-05-26 23:25:30 +0000377 Vdbe *p = (Vdbe *)pStmt;
danielk197776d505b2004-05-28 13:13:02 +0000378 Mem *pColName;
drh4f26d6c2004-05-26 23:25:30 +0000379
danielk197776d505b2004-05-28 13:13:02 +0000380 if( N>=sqlite3_column_count(pStmt) || N<0 ){
drh4f26d6c2004-05-26 23:25:30 +0000381 sqlite3Error(p->db, SQLITE_RANGE, 0);
382 return 0;
383 }
384
danielk197776d505b2004-05-28 13:13:02 +0000385 pColName = &(p->aColName[N+sqlite3_column_count(pStmt)]);
386 return sqlite3_value_text(pColName);
drh4f26d6c2004-05-26 23:25:30 +0000387}
388
389/*
390** Return the column declaration type (if applicable) of the 'i'th column
391** of the result set of SQL statement pStmt, encoded as UTF-16.
392*/
danielk197776d505b2004-05-28 13:13:02 +0000393const void *sqlite3_column_decltype16(sqlite3_stmt *pStmt, int N){
394 Vdbe *p = (Vdbe *)pStmt;
395 Mem *pColName;
396
397 if( N>=sqlite3_column_count(pStmt) || N<0 ){
398 sqlite3Error(p->db, SQLITE_RANGE, 0);
399 return 0;
400 }
401
402 pColName = &(p->aColName[N+sqlite3_column_count(pStmt)]);
403 return sqlite3_value_text16(pColName);
drh4f26d6c2004-05-26 23:25:30 +0000404}
405
406/******************************* sqlite3_bind_ ***************************
407**
408** Routines used to attach values to wildcards in a compiled SQL statement.
409*/
410/*
411** Unbind the value bound to variable i in virtual machine p. This is the
412** the same as binding a NULL value to the column. If the "i" parameter is
413** out of range, then SQLITE_RANGE is returned. Othewise SQLITE_OK.
414**
415** The error code stored in database p->db is overwritten with the return
416** value in any case.
417*/
418static int vdbeUnbind(Vdbe *p, int i){
419 Mem *pVar;
danielk19771d850a72004-05-31 08:26:49 +0000420 if( p->magic!=VDBE_MAGIC_RUN || p->pc>=0 ){
drh4f26d6c2004-05-26 23:25:30 +0000421 sqlite3Error(p->db, SQLITE_MISUSE, 0);
422 return SQLITE_MISUSE;
423 }
424 if( i<1 || i>p->nVar ){
425 sqlite3Error(p->db, SQLITE_RANGE, 0);
426 return SQLITE_RANGE;
427 }
428 i--;
429 pVar = &p->apVar[i];
danielk1977d8123362004-06-12 09:25:12 +0000430 sqlite3VdbeMemRelease(pVar);
drh4f26d6c2004-05-26 23:25:30 +0000431 pVar->flags = MEM_Null;
432 sqlite3Error(p->db, SQLITE_OK, 0);
433 return SQLITE_OK;
434}
435
436/*
437** Bind a blob value to an SQL statement variable.
438*/
439int sqlite3_bind_blob(
drhf4479502004-05-27 03:12:53 +0000440 sqlite3_stmt *pStmt,
drh4f26d6c2004-05-26 23:25:30 +0000441 int i,
442 const void *zData,
443 int nData,
danielk1977d8123362004-06-12 09:25:12 +0000444 void (*xDel)(void*)
drh4f26d6c2004-05-26 23:25:30 +0000445){
446 Vdbe *p = (Vdbe *)pStmt;
447 Mem *pVar;
448 int rc;
449
450 rc = vdbeUnbind(p, i);
451 if( rc ){
452 return rc;
453 }
454 pVar = &p->apVar[i-1];
danielk1977d8123362004-06-12 09:25:12 +0000455 rc = sqlite3VdbeMemSetStr(pVar, zData, nData, 0, xDel);
drh4f26d6c2004-05-26 23:25:30 +0000456 return rc;
457}
458int sqlite3_bind_double(sqlite3_stmt *pStmt, int i, double rValue){
459 int rc;
460 Vdbe *p = (Vdbe *)pStmt;
drh4f26d6c2004-05-26 23:25:30 +0000461 rc = vdbeUnbind(p, i);
462 if( rc==SQLITE_OK ){
drhf4479502004-05-27 03:12:53 +0000463 sqlite3VdbeMemSetDouble(&p->apVar[i-1], rValue);
drh4f26d6c2004-05-26 23:25:30 +0000464 }
465 return SQLITE_OK;
466}
467int sqlite3_bind_int(sqlite3_stmt *p, int i, int iValue){
468 return sqlite3_bind_int64(p, i, (long long int)iValue);
469}
470int sqlite3_bind_int64(sqlite3_stmt *pStmt, int i, long long int iValue){
471 int rc;
472 Vdbe *p = (Vdbe *)pStmt;
473 rc = vdbeUnbind(p, i);
474 if( rc==SQLITE_OK ){
drhf4479502004-05-27 03:12:53 +0000475 sqlite3VdbeMemSetInt64(&p->apVar[i-1], iValue);
drh4f26d6c2004-05-26 23:25:30 +0000476 }
477 return rc;
478}
479int sqlite3_bind_null(sqlite3_stmt* p, int i){
480 return vdbeUnbind((Vdbe *)p, i);
481}
482int sqlite3_bind_text(
483 sqlite3_stmt *pStmt,
484 int i,
485 const char *zData,
486 int nData,
danielk1977d8123362004-06-12 09:25:12 +0000487 void (*xDel)(void*)
drh4f26d6c2004-05-26 23:25:30 +0000488){
489 Vdbe *p = (Vdbe *)pStmt;
490 Mem *pVar;
491 int rc;
492
493 rc = vdbeUnbind(p, i);
494 if( rc ){
495 return rc;
496 }
497 pVar = &p->apVar[i-1];
danielk1977d8123362004-06-12 09:25:12 +0000498 rc = sqlite3VdbeMemSetStr(pVar, zData, nData, SQLITE_UTF8, xDel);
drh4f26d6c2004-05-26 23:25:30 +0000499 if( rc ){
500 return rc;
501 }
drhf4479502004-05-27 03:12:53 +0000502 rc = sqlite3VdbeChangeEncoding(pVar, p->db->enc);
drh4f26d6c2004-05-26 23:25:30 +0000503 return rc;
504}
505int sqlite3_bind_text16(
506 sqlite3_stmt *pStmt,
507 int i,
508 const void *zData,
509 int nData,
danielk1977d8123362004-06-12 09:25:12 +0000510 void (*xDel)(void*)
drh4f26d6c2004-05-26 23:25:30 +0000511){
512 Vdbe *p = (Vdbe *)pStmt;
513 Mem *pVar;
danielk19775314c4d2004-06-18 06:02:35 +0000514 int rc;
drh4f26d6c2004-05-26 23:25:30 +0000515
516 rc = vdbeUnbind(p, i);
517 if( rc ){
518 return rc;
519 }
drhf4479502004-05-27 03:12:53 +0000520 pVar = &p->apVar[i-1];
drh4f26d6c2004-05-26 23:25:30 +0000521
danielk1977bfd6cce2004-06-18 04:24:54 +0000522 rc = sqlite3VdbeMemSetStr(pVar, zData, nData, SQLITE_UTF16NATIVE, xDel);
drh4f26d6c2004-05-26 23:25:30 +0000523 if( rc ){
524 return rc;
525 }
drhf4479502004-05-27 03:12:53 +0000526 rc = sqlite3VdbeChangeEncoding(pVar, p->db->enc);
drh4f26d6c2004-05-26 23:25:30 +0000527 return rc;
528}