First public contribution.
4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
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.
11 *************************************************************************
12 ** This file contains the C functions that implement various SQL
13 ** functions of SQLite.
15 ** There is only one exported symbol in this file - the function
16 ** sqliteRegisterBuildinFunctions() found at the bottom of the file.
17 ** All other code has file scope.
19 ** $Id: func.c,v 1.196 2008/07/28 19:34:53 drh Exp $
21 #include "sqliteInt.h"
29 ** Return the collating function associated with a function.
31 static CollSeq *sqlite3GetFuncCollSeq(sqlite3_context *context){
32 return context->pColl;
36 ** Implementation of the non-aggregate min() and max() functions
38 static void minmaxFunc(
39 sqlite3_context *context,
44 int mask; /* 0 for min() or 0xffffffff for max() */
49 mask = sqlite3_user_data(context)==0 ? 0 : -1;
50 pColl = sqlite3GetFuncCollSeq(context);
52 assert( mask==-1 || mask==0 );
54 if( sqlite3_value_type(argv[0])==SQLITE_NULL ) return;
55 for(i=1; i<argc; i++){
56 if( sqlite3_value_type(argv[i])==SQLITE_NULL ) return;
57 if( (sqlite3MemCompare(argv[iBest], argv[i], pColl)^mask)>=0 ){
61 sqlite3_result_value(context, argv[iBest]);
65 ** Return the type of the argument.
67 static void typeofFunc(
68 sqlite3_context *context,
73 switch( sqlite3_value_type(argv[0]) ){
74 case SQLITE_NULL: z = "null"; break;
75 case SQLITE_INTEGER: z = "integer"; break;
76 case SQLITE_TEXT: z = "text"; break;
77 case SQLITE_FLOAT: z = "real"; break;
78 case SQLITE_BLOB: z = "blob"; break;
80 sqlite3_result_text(context, z, -1, SQLITE_STATIC);
85 ** Implementation of the length() function
87 static void lengthFunc(
88 sqlite3_context *context,
95 switch( sqlite3_value_type(argv[0]) ){
99 sqlite3_result_int(context, sqlite3_value_bytes(argv[0]));
103 const unsigned char *z = sqlite3_value_text(argv[0]);
110 sqlite3_result_int(context, len);
114 sqlite3_result_null(context);
121 ** Implementation of the abs() function
123 static void absFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
125 switch( sqlite3_value_type(argv[0]) ){
126 case SQLITE_INTEGER: {
127 i64 iVal = sqlite3_value_int64(argv[0]);
130 sqlite3_result_error(context, "integer overflow", -1);
135 sqlite3_result_int64(context, iVal);
139 sqlite3_result_null(context);
143 double rVal = sqlite3_value_double(argv[0]);
144 if( rVal<0 ) rVal = -rVal;
145 sqlite3_result_double(context, rVal);
152 ** Implementation of the substr() function.
154 ** substr(x,p1,p2) returns p2 characters of x[] beginning with p1.
155 ** p1 is 1-indexed. So substr(x,1,1) returns the first character
156 ** of x. If x is text, then we actually count UTF-8 characters.
157 ** If x is a blob, then we count bytes.
159 ** If p1 is negative, then we begin abs(p1) from the end of x[].
161 static void substrFunc(
162 sqlite3_context *context,
166 const unsigned char *z;
167 const unsigned char *z2;
172 assert( argc==3 || argc==2 );
173 p0type = sqlite3_value_type(argv[0]);
174 if( p0type==SQLITE_BLOB ){
175 len = sqlite3_value_bytes(argv[0]);
176 z = sqlite3_value_blob(argv[0]);
178 assert( len==sqlite3_value_bytes(argv[0]) );
180 z = sqlite3_value_text(argv[0]);
183 for(z2=z; *z2; len++){
184 SQLITE_SKIP_UTF8(z2);
187 p1 = sqlite3_value_int(argv[1]);
189 p2 = sqlite3_value_int(argv[2]);
191 p2 = sqlite3_context_db_handle(context)->aLimit[SQLITE_LIMIT_LENGTH];
205 if( p0type!=SQLITE_BLOB ){
210 for(z2=z; *z2 && p2; p2--){
211 SQLITE_SKIP_UTF8(z2);
213 sqlite3_result_text(context, (char*)z, z2-z, SQLITE_TRANSIENT);
216 sqlite3_result_blob(context, (char*)&z[p1], p2, SQLITE_TRANSIENT);
221 ** Implementation of the round() function
223 static void roundFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
226 char zBuf[500]; /* larger than the %f representation of the largest double */
227 assert( argc==1 || argc==2 );
229 if( SQLITE_NULL==sqlite3_value_type(argv[1]) ) return;
230 n = sqlite3_value_int(argv[1]);
234 if( sqlite3_value_type(argv[0])==SQLITE_NULL ) return;
235 r = sqlite3_value_double(argv[0]);
236 sqlite3_snprintf(sizeof(zBuf),zBuf,"%.*f",n,r);
237 sqlite3AtoF(zBuf, &r);
238 sqlite3_result_double(context, r);
242 ** Allocate nByte bytes of space using sqlite3_malloc(). If the
243 ** allocation fails, call sqlite3_result_error_nomem() to notify
244 ** the database handle that malloc() has failed.
246 static void *contextMalloc(sqlite3_context *context, i64 nByte){
248 if( nByte>sqlite3_context_db_handle(context)->aLimit[SQLITE_LIMIT_LENGTH] ){
249 sqlite3_result_error_toobig(context);
252 z = sqlite3Malloc(nByte);
254 sqlite3_result_error_nomem(context);
261 ** Implementation of the upper() and lower() SQL functions.
263 static void upperFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
267 if( argc<1 || SQLITE_NULL==sqlite3_value_type(argv[0]) ) return;
268 z2 = (char*)sqlite3_value_text(argv[0]);
269 n = sqlite3_value_bytes(argv[0]);
270 /* Verify that the call to _bytes() does not invalidate the _text() pointer */
271 assert( z2==(char*)sqlite3_value_text(argv[0]) );
273 z1 = contextMalloc(context, ((i64)n)+1);
276 for(i=0; z1[i]; i++){
277 z1[i] = toupper(z1[i]);
279 sqlite3_result_text(context, z1, -1, sqlite3_free);
283 static void lowerFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
287 if( argc<1 || SQLITE_NULL==sqlite3_value_type(argv[0]) ) return;
288 z2 = (char*)sqlite3_value_text(argv[0]);
289 n = sqlite3_value_bytes(argv[0]);
290 /* Verify that the call to _bytes() does not invalidate the _text() pointer */
291 assert( z2==(char*)sqlite3_value_text(argv[0]) );
293 z1 = contextMalloc(context, ((i64)n)+1);
296 for(i=0; z1[i]; i++){
297 z1[i] = tolower(z1[i]);
299 sqlite3_result_text(context, z1, -1, sqlite3_free);
305 ** Implementation of the IFNULL(), NVL(), and COALESCE() functions.
306 ** All three do the same thing. They return the first non-NULL
309 static void ifnullFunc(
310 sqlite3_context *context,
315 for(i=0; i<argc; i++){
316 if( SQLITE_NULL!=sqlite3_value_type(argv[i]) ){
317 sqlite3_result_value(context, argv[i]);
324 ** Implementation of random(). Return a random integer.
326 static void randomFunc(
327 sqlite3_context *context,
332 sqlite3_randomness(sizeof(r), &r);
333 if( (r<<1)==0 ) r = 0; /* Prevent 0x8000.... as the result so that we */
334 /* can always do abs() of the result */
335 sqlite3_result_int64(context, r);
339 ** Implementation of randomblob(N). Return a random blob
340 ** that is N bytes long.
342 static void randomBlob(
343 sqlite3_context *context,
350 n = sqlite3_value_int(argv[0]);
354 p = contextMalloc(context, n);
356 sqlite3_randomness(n, p);
357 sqlite3_result_blob(context, (char*)p, n, sqlite3_free);
362 ** Implementation of the last_insert_rowid() SQL function. The return
363 ** value is the same as the sqlite3_last_insert_rowid() API function.
365 static void last_insert_rowid(
366 sqlite3_context *context,
370 sqlite3 *db = sqlite3_context_db_handle(context);
371 sqlite3_result_int64(context, sqlite3_last_insert_rowid(db));
375 ** Implementation of the changes() SQL function. The return value is the
376 ** same as the sqlite3_changes() API function.
379 sqlite3_context *context,
383 sqlite3 *db = sqlite3_context_db_handle(context);
384 sqlite3_result_int(context, sqlite3_changes(db));
388 ** Implementation of the total_changes() SQL function. The return value is
389 ** the same as the sqlite3_total_changes() API function.
391 static void total_changes(
392 sqlite3_context *context,
396 sqlite3 *db = sqlite3_context_db_handle(context);
397 sqlite3_result_int(context, sqlite3_total_changes(db));
401 ** A structure defining how to do GLOB-style comparisons.
411 ** For LIKE and GLOB matching on EBCDIC machines, assume that every
412 ** character is exactly one byte in size. Also, all characters are
413 ** able to participate in upper-case-to-lower-case mappings in EBCDIC
414 ** whereas only characters less than 0x80 do in ASCII.
416 #if defined(SQLITE_EBCDIC)
417 # define sqlite3Utf8Read(A,B,C) (*(A++))
418 # define GlogUpperToLower(A) A = sqlite3UpperToLower[A]
420 # define GlogUpperToLower(A) if( A<0x80 ){ A = sqlite3UpperToLower[A]; }
423 static const struct compareInfo globInfo = { '*', '?', '[', 0 };
424 /* The correct SQL-92 behavior is for the LIKE operator to ignore
425 ** case. Thus 'a' LIKE 'A' would be true. */
426 static const struct compareInfo likeInfoNorm = { '%', '_', 0, 1 };
427 /* If SQLITE_CASE_SENSITIVE_LIKE is defined, then the LIKE operator
428 ** is case sensitive causing 'a' LIKE 'A' to be false */
429 static const struct compareInfo likeInfoAlt = { '%', '_', 0, 0 };
432 ** Compare two UTF-8 strings for equality where the first string can
433 ** potentially be a "glob" expression. Return true (1) if they
434 ** are the same and false (0) if they are different.
438 ** '*' Matches any sequence of zero or more characters.
440 ** '?' Matches exactly one character.
442 ** [...] Matches one character from the enclosed list of
445 ** [^...] Matches one character not in the enclosed list.
447 ** With the [...] and [^...] matching, a ']' character can be included
448 ** in the list by making it the first character after '[' or '^'. A
449 ** range of characters can be specified using '-'. Example:
450 ** "[a-z]" matches any single lower-case letter. To match a '-', make
451 ** it the last character in the list.
453 ** This routine is usually quick, but can be N**2 in the worst case.
455 ** Hints: to match '*' or '?', put them in "[]". Like this:
457 ** abc[*]xyz Matches "abc*xyz" only
459 static int patternCompare(
460 const u8 *zPattern, /* The glob pattern */
461 const u8 *zString, /* The string to compare against the glob */
462 const struct compareInfo *pInfo, /* Information about how to do the compare */
463 const int esc /* The escape character */
468 u8 matchOne = pInfo->matchOne;
469 u8 matchAll = pInfo->matchAll;
470 u8 matchSet = pInfo->matchSet;
471 u8 noCase = pInfo->noCase;
472 int prevEscape = 0; /* True if the previous character was 'escape' */
474 while( (c = sqlite3Utf8Read(zPattern,0,&zPattern))!=0 ){
475 if( !prevEscape && c==matchAll ){
476 while( (c=sqlite3Utf8Read(zPattern,0,&zPattern)) == matchAll
478 if( c==matchOne && sqlite3Utf8Read(zString, 0, &zString)==0 ){
485 c = sqlite3Utf8Read(zPattern, 0, &zPattern);
489 }else if( c==matchSet ){
490 assert( esc==0 ); /* This is GLOB, not LIKE */
491 assert( matchSet<0x80 ); /* '[' is a single-byte character */
492 while( *zString && patternCompare(&zPattern[-1],zString,pInfo,esc)==0 ){
493 SQLITE_SKIP_UTF8(zString);
497 while( (c2 = sqlite3Utf8Read(zString,0,&zString))!=0 ){
499 GlogUpperToLower(c2);
501 while( c2 != 0 && c2 != c ){
502 c2 = sqlite3Utf8Read(zString, 0, &zString);
503 GlogUpperToLower(c2);
506 while( c2 != 0 && c2 != c ){
507 c2 = sqlite3Utf8Read(zString, 0, &zString);
510 if( c2==0 ) return 0;
511 if( patternCompare(zPattern,zString,pInfo,esc) ) return 1;
514 }else if( !prevEscape && c==matchOne ){
515 if( sqlite3Utf8Read(zString, 0, &zString)==0 ){
518 }else if( c==matchSet ){
520 assert( esc==0 ); /* This only occurs for GLOB, not LIKE */
523 c = sqlite3Utf8Read(zString, 0, &zString);
525 c2 = sqlite3Utf8Read(zPattern, 0, &zPattern);
528 c2 = sqlite3Utf8Read(zPattern, 0, &zPattern);
531 if( c==']' ) seen = 1;
532 c2 = sqlite3Utf8Read(zPattern, 0, &zPattern);
534 while( c2 && c2!=']' ){
535 if( c2=='-' && zPattern[0]!=']' && zPattern[0]!=0 && prior_c>0 ){
536 c2 = sqlite3Utf8Read(zPattern, 0, &zPattern);
537 if( c>=prior_c && c<=c2 ) seen = 1;
545 c2 = sqlite3Utf8Read(zPattern, 0, &zPattern);
547 if( c2==0 || (seen ^ invert)==0 ){
550 }else if( esc==c && !prevEscape ){
553 c2 = sqlite3Utf8Read(zString, 0, &zString);
556 GlogUpperToLower(c2);
568 ** Count the number of times that the LIKE operator (or GLOB which is
569 ** just a variation of LIKE) gets called. This is used for testing
573 int sqlite3_like_count = 0;
578 ** Implementation of the like() SQL function. This function implements
579 ** the build-in LIKE operator. The first argument to the function is the
580 ** pattern and the second argument is the string. So, the SQL statements:
584 ** is implemented as like(B,A).
586 ** This same function (with a different compareInfo structure) computes
587 ** the GLOB operator.
589 static void likeFunc(
590 sqlite3_context *context,
594 const unsigned char *zA, *zB;
596 sqlite3 *db = sqlite3_context_db_handle(context);
598 zB = sqlite3_value_text(argv[0]);
599 zA = sqlite3_value_text(argv[1]);
601 /* Limit the length of the LIKE or GLOB pattern to avoid problems
602 ** of deep recursion and N*N behavior in patternCompare().
604 if( sqlite3_value_bytes(argv[0]) >
605 db->aLimit[SQLITE_LIMIT_LIKE_PATTERN_LENGTH] ){
606 sqlite3_result_error(context, "LIKE or GLOB pattern too complex", -1);
609 assert( zB==sqlite3_value_text(argv[0]) ); /* Encoding did not change */
612 /* The escape character string must consist of a single UTF-8 character.
613 ** Otherwise, return an error.
615 const unsigned char *zEsc = sqlite3_value_text(argv[2]);
616 if( zEsc==0 ) return;
617 if( sqlite3Utf8CharLen((char*)zEsc, -1)!=1 ){
618 sqlite3_result_error(context,
619 "ESCAPE expression must be a single character", -1);
622 escape = sqlite3Utf8Read(zEsc, 0, &zEsc);
625 struct compareInfo *pInfo = sqlite3_user_data(context);
627 sqlite3_like_count++;
630 sqlite3_result_int(context, patternCompare(zB, zA, pInfo, escape));
635 ** Implementation of the NULLIF(x,y) function. The result is the first
636 ** argument if the arguments are different. The result is NULL if the
637 ** arguments are equal to each other.
639 static void nullifFunc(
640 sqlite3_context *context,
644 CollSeq *pColl = sqlite3GetFuncCollSeq(context);
645 if( sqlite3MemCompare(argv[0], argv[1], pColl)!=0 ){
646 sqlite3_result_value(context, argv[0]);
651 ** Implementation of the VERSION(*) function. The result is the version
652 ** of the SQLite library that is running.
654 static void versionFunc(
655 sqlite3_context *context,
659 sqlite3_result_text(context, sqlite3_version, -1, SQLITE_STATIC);
662 /* Array for converting from half-bytes (nybbles) into ASCII hex
664 static const char hexdigits[] = {
665 '0', '1', '2', '3', '4', '5', '6', '7',
666 '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'
670 ** EXPERIMENTAL - This is not an official function. The interface may
671 ** change. This function may disappear. Do not write code that depends
674 ** Implementation of the QUOTE() function. This function takes a single
675 ** argument. If the argument is numeric, the return value is the same as
676 ** the argument. If the argument is NULL, the return value is the string
677 ** "NULL". Otherwise, the argument is enclosed in single quotes with
678 ** single-quote escapes.
680 static void quoteFunc(sqlite3_context *context, int argc, sqlite3_value **argv){
682 switch( sqlite3_value_type(argv[0]) ){
684 sqlite3_result_text(context, "NULL", 4, SQLITE_STATIC);
689 sqlite3_result_value(context, argv[0]);
694 char const *zBlob = sqlite3_value_blob(argv[0]);
695 int nBlob = sqlite3_value_bytes(argv[0]);
696 assert( zBlob==sqlite3_value_blob(argv[0]) ); /* No encoding change */
697 zText = (char *)contextMalloc(context, (2*(i64)nBlob)+4);
700 for(i=0; i<nBlob; i++){
701 zText[(i*2)+2] = hexdigits[(zBlob[i]>>4)&0x0F];
702 zText[(i*2)+3] = hexdigits[(zBlob[i])&0x0F];
704 zText[(nBlob*2)+2] = '\'';
705 zText[(nBlob*2)+3] = '\0';
708 sqlite3_result_text(context, zText, -1, SQLITE_TRANSIENT);
716 const unsigned char *zArg = sqlite3_value_text(argv[0]);
719 if( zArg==0 ) return;
720 for(i=0, n=0; zArg[i]; i++){ if( zArg[i]=='\'' ) n++; }
721 z = contextMalloc(context, ((i64)i)+((i64)n)+3);
724 for(i=0, j=1; zArg[i]; i++){
732 sqlite3_result_text(context, z, j, sqlite3_free);
739 ** The hex() function. Interpret the argument as a blob. Return
740 ** a hexadecimal rendering as text.
743 sqlite3_context *context,
748 const unsigned char *pBlob;
751 pBlob = sqlite3_value_blob(argv[0]);
752 n = sqlite3_value_bytes(argv[0]);
753 assert( pBlob==sqlite3_value_blob(argv[0]) ); /* No encoding change */
754 z = zHex = contextMalloc(context, ((i64)n)*2 + 1);
756 for(i=0; i<n; i++, pBlob++){
757 unsigned char c = *pBlob;
758 *(z++) = hexdigits[(c>>4)&0xf];
759 *(z++) = hexdigits[c&0xf];
762 sqlite3_result_text(context, zHex, n*2, sqlite3_free);
767 ** The zeroblob(N) function returns a zero-filled blob of size N bytes.
769 static void zeroblobFunc(
770 sqlite3_context *context,
776 n = sqlite3_value_int64(argv[0]);
777 if( n>SQLITE_MAX_LENGTH ){
778 sqlite3_result_error_toobig(context);
780 sqlite3_result_zeroblob(context, n);
785 ** The replace() function. Three arguments are all strings: call
786 ** them A, B, and C. The result is also a string which is derived
787 ** from A by replacing every occurance of B with C. The match
788 ** must be exact. Collating sequences are not used.
790 static void replaceFunc(
791 sqlite3_context *context,
795 const unsigned char *zStr; /* The input string A */
796 const unsigned char *zPattern; /* The pattern string B */
797 const unsigned char *zRep; /* The replacement string C */
798 unsigned char *zOut; /* The output */
799 int nStr; /* Size of zStr */
800 int nPattern; /* Size of zPattern */
801 int nRep; /* Size of zRep */
802 i64 nOut; /* Maximum size of zOut */
803 int loopLimit; /* Last zStr[] that might match zPattern[] */
804 int i, j; /* Loop counters */
807 zStr = sqlite3_value_text(argv[0]);
808 if( zStr==0 ) return;
809 nStr = sqlite3_value_bytes(argv[0]);
810 assert( zStr==sqlite3_value_text(argv[0]) ); /* No encoding change */
811 zPattern = sqlite3_value_text(argv[1]);
812 if( zPattern==0 || zPattern[0]==0 ) return;
813 nPattern = sqlite3_value_bytes(argv[1]);
814 assert( zPattern==sqlite3_value_text(argv[1]) ); /* No encoding change */
815 zRep = sqlite3_value_text(argv[2]);
816 if( zRep==0 ) return;
817 nRep = sqlite3_value_bytes(argv[2]);
818 assert( zRep==sqlite3_value_text(argv[2]) );
820 assert( nOut<SQLITE_MAX_LENGTH );
821 zOut = contextMalloc(context, (i64)nOut);
825 loopLimit = nStr - nPattern;
826 for(i=j=0; i<=loopLimit; i++){
827 if( zStr[i]!=zPattern[0] || memcmp(&zStr[i], zPattern, nPattern) ){
831 sqlite3 *db = sqlite3_context_db_handle(context);
832 nOut += nRep - nPattern;
833 if( nOut>=db->aLimit[SQLITE_LIMIT_LENGTH] ){
834 sqlite3_result_error_toobig(context);
835 sqlite3DbFree(db, zOut);
839 zOut = sqlite3_realloc(zOut, (int)nOut);
841 sqlite3_result_error_nomem(context);
842 sqlite3DbFree(db, zOld);
845 memcpy(&zOut[j], zRep, nRep);
850 assert( j+nStr-i+1==nOut );
851 memcpy(&zOut[j], &zStr[i], nStr-i);
855 sqlite3_result_text(context, (char*)zOut, j, sqlite3_free);
859 ** Implementation of the TRIM(), LTRIM(), and RTRIM() functions.
860 ** The userdata is 0x1 for left trim, 0x2 for right trim, 0x3 for both.
862 static void trimFunc(
863 sqlite3_context *context,
867 const unsigned char *zIn; /* Input string */
868 const unsigned char *zCharSet; /* Set of characters to trim */
869 int nIn; /* Number of bytes in input */
870 int flags; /* 1: trimleft 2: trimright 3: trim */
871 int i; /* Loop counter */
872 unsigned char *aLen; /* Length of each character in zCharSet */
873 unsigned char **azChar; /* Individual characters in zCharSet */
874 int nChar; /* Number of characters in zCharSet */
876 if( sqlite3_value_type(argv[0])==SQLITE_NULL ){
879 zIn = sqlite3_value_text(argv[0]);
881 nIn = sqlite3_value_bytes(argv[0]);
882 assert( zIn==sqlite3_value_text(argv[0]) );
884 static const unsigned char lenOne[] = { 1 };
885 static const unsigned char *azOne[] = { (u8*)" " };
888 azChar = (unsigned char **)azOne;
890 }else if( (zCharSet = sqlite3_value_text(argv[1]))==0 ){
893 const unsigned char *z;
894 for(z=zCharSet, nChar=0; *z; nChar++){
898 azChar = contextMalloc(context, ((i64)nChar)*(sizeof(char*)+1));
902 aLen = (unsigned char*)&azChar[nChar];
903 for(z=zCharSet, nChar=0; *z; nChar++){
904 azChar[nChar] = (unsigned char *)z;
906 aLen[nChar] = z - azChar[nChar];
911 flags = SQLITE_PTR_TO_INT(sqlite3_user_data(context));
914 int len = 0; /* Initialized to placate warning. */
915 for(i=0; i<nChar; i++){
917 if( memcmp(zIn, azChar[i], len)==0 ) break;
919 if( i>=nChar ) break;
926 int len = 0; /* Initialized to placate warning. */
927 for(i=0; i<nChar; i++){
929 if( len<=nIn && memcmp(&zIn[nIn-len],azChar[i],len)==0 ) break;
931 if( i>=nChar ) break;
936 sqlite3_free(azChar);
939 sqlite3_result_text(context, (char*)zIn, nIn, SQLITE_TRANSIENT);
942 #ifdef SQLITE_SOUNDEX
944 ** Compute the soundex encoding of a word.
946 static void soundexFunc(
947 sqlite3_context *context,
954 static const unsigned char iCode[] = {
955 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
956 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
957 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
958 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
959 0, 0, 1, 2, 3, 0, 1, 2, 0, 0, 2, 2, 4, 5, 5, 0,
960 1, 2, 6, 2, 3, 0, 1, 0, 2, 0, 2, 0, 0, 0, 0, 0,
961 0, 0, 1, 2, 3, 0, 1, 2, 0, 0, 2, 2, 4, 5, 5, 0,
962 1, 2, 6, 2, 3, 0, 1, 0, 2, 0, 2, 0, 0, 0, 0, 0,
965 zIn = (u8*)sqlite3_value_text(argv[0]);
966 if( zIn==0 ) zIn = (u8*)"";
967 for(i=0; zIn[i] && !isalpha(zIn[i]); i++){}
969 u8 prevcode = iCode[zIn[i]&0x7f];
970 zResult[0] = toupper(zIn[i]);
971 for(j=1; j<4 && zIn[i]; i++){
972 int code = iCode[zIn[i]&0x7f];
974 if( code!=prevcode ){
976 zResult[j++] = code + '0';
986 sqlite3_result_text(context, zResult, 4, SQLITE_TRANSIENT);
988 sqlite3_result_text(context, "?000", 4, SQLITE_STATIC);
993 #ifndef SQLITE_OMIT_LOAD_EXTENSION
995 ** A function that loads a shared-library extension then returns NULL.
997 static void loadExt(sqlite3_context *context, int argc, sqlite3_value **argv){
998 const char *zFile = (const char *)sqlite3_value_text(argv[0]);
1000 sqlite3 *db = sqlite3_context_db_handle(context);
1004 zProc = (const char *)sqlite3_value_text(argv[1]);
1008 if( zFile && sqlite3_load_extension(db, zFile, zProc, &zErrMsg) ){
1009 sqlite3_result_error(context, zErrMsg, -1);
1010 sqlite3_free(zErrMsg);
1017 ** An instance of the following structure holds the context of a
1018 ** sum() or avg() aggregate computation.
1020 typedef struct SumCtx SumCtx;
1022 double rSum; /* Floating point sum */
1023 i64 iSum; /* Integer sum */
1024 i64 cnt; /* Number of elements summed */
1025 u8 overflow; /* True if integer overflow seen */
1026 u8 approx; /* True if non-integer value was input to the sum */
1030 ** Routines used to compute the sum, average, and total.
1032 ** The SUM() function follows the (broken) SQL standard which means
1033 ** that it returns NULL if it sums over no inputs. TOTAL returns
1034 ** 0.0 in that case. In addition, TOTAL always returns a float where
1035 ** SUM might return an integer if it never encounters a floating point
1036 ** value. TOTAL never fails, but SUM might through an exception if
1037 ** it overflows an integer.
1039 static void sumStep(sqlite3_context *context, int argc, sqlite3_value **argv){
1043 p = sqlite3_aggregate_context(context, sizeof(*p));
1044 type = sqlite3_value_numeric_type(argv[0]);
1045 if( p && type!=SQLITE_NULL ){
1047 if( type==SQLITE_INTEGER ){
1048 i64 v = sqlite3_value_int64(argv[0]);
1050 if( (p->approx|p->overflow)==0 ){
1051 i64 iNewSum = p->iSum + v;
1052 int s1 = p->iSum >> (sizeof(i64)*8-1);
1053 int s2 = v >> (sizeof(i64)*8-1);
1054 int s3 = iNewSum >> (sizeof(i64)*8-1);
1055 p->overflow = (s1&s2&~s3) | (~s1&~s2&s3);
1059 p->rSum += sqlite3_value_double(argv[0]);
1064 static void sumFinalize(sqlite3_context *context){
1066 p = sqlite3_aggregate_context(context, 0);
1067 if( p && p->cnt>0 ){
1069 sqlite3_result_error(context,"integer overflow",-1);
1070 }else if( p->approx ){
1071 sqlite3_result_double(context, p->rSum);
1073 sqlite3_result_int64(context, p->iSum);
1077 static void avgFinalize(sqlite3_context *context){
1079 p = sqlite3_aggregate_context(context, 0);
1080 if( p && p->cnt>0 ){
1081 sqlite3_result_double(context, p->rSum/(double)p->cnt);
1084 static void totalFinalize(sqlite3_context *context){
1086 p = sqlite3_aggregate_context(context, 0);
1087 sqlite3_result_double(context, p ? p->rSum : 0.0);
1091 ** The following structure keeps track of state information for the
1092 ** count() aggregate function.
1094 typedef struct CountCtx CountCtx;
1100 ** Routines to implement the count() aggregate function.
1102 static void countStep(sqlite3_context *context, int argc, sqlite3_value **argv){
1104 p = sqlite3_aggregate_context(context, sizeof(*p));
1105 if( (argc==0 || SQLITE_NULL!=sqlite3_value_type(argv[0])) && p ){
1109 static void countFinalize(sqlite3_context *context){
1111 p = sqlite3_aggregate_context(context, 0);
1112 sqlite3_result_int64(context, p ? p->n : 0);
1116 ** Routines to implement min() and max() aggregate functions.
1118 static void minmaxStep(sqlite3_context *context, int argc, sqlite3_value **argv){
1119 Mem *pArg = (Mem *)argv[0];
1122 if( sqlite3_value_type(argv[0])==SQLITE_NULL ) return;
1123 pBest = (Mem *)sqlite3_aggregate_context(context, sizeof(*pBest));
1124 if( !pBest ) return;
1129 CollSeq *pColl = sqlite3GetFuncCollSeq(context);
1130 /* This step function is used for both the min() and max() aggregates,
1131 ** the only difference between the two being that the sense of the
1132 ** comparison is inverted. For the max() aggregate, the
1133 ** sqlite3_user_data() function returns (void *)-1. For min() it
1134 ** returns (void *)db, where db is the sqlite3* database pointer.
1135 ** Therefore the next statement sets variable 'max' to 1 for the max()
1136 ** aggregate, or 0 for min().
1138 max = sqlite3_user_data(context)!=0;
1139 cmp = sqlite3MemCompare(pBest, pArg, pColl);
1140 if( (max && cmp<0) || (!max && cmp>0) ){
1141 sqlite3VdbeMemCopy(pBest, pArg);
1144 sqlite3VdbeMemCopy(pBest, pArg);
1147 static void minMaxFinalize(sqlite3_context *context){
1148 sqlite3_value *pRes;
1149 pRes = (sqlite3_value *)sqlite3_aggregate_context(context, 0);
1152 sqlite3_result_value(context, pRes);
1154 sqlite3VdbeMemRelease(pRes);
1159 ** group_concat(EXPR, ?SEPARATOR?)
1161 static void groupConcatStep(
1162 sqlite3_context *context,
1164 sqlite3_value **argv
1170 if( argc==0 || sqlite3_value_type(argv[0])==SQLITE_NULL ) return;
1171 pAccum = (StrAccum*)sqlite3_aggregate_context(context, sizeof(*pAccum));
1174 sqlite3 *db = sqlite3_context_db_handle(context);
1175 pAccum->useMalloc = 1;
1176 pAccum->mxAlloc = db->aLimit[SQLITE_LIMIT_LENGTH];
1177 if( pAccum->nChar ){
1179 zSep = (char*)sqlite3_value_text(argv[argc-1]);
1180 nSep = sqlite3_value_bytes(argv[argc-1]);
1185 sqlite3StrAccumAppend(pAccum, zSep, nSep);
1189 zVal = (char*)sqlite3_value_text(argv[i]);
1190 nVal = sqlite3_value_bytes(argv[i]);
1191 sqlite3StrAccumAppend(pAccum, zVal, nVal);
1196 static void groupConcatFinalize(sqlite3_context *context){
1198 pAccum = sqlite3_aggregate_context(context, 0);
1200 if( pAccum->tooBig ){
1201 sqlite3_result_error_toobig(context);
1202 }else if( pAccum->mallocFailed ){
1203 sqlite3_result_error_nomem(context);
1205 sqlite3_result_text(context, sqlite3StrAccumFinish(pAccum), -1,
1212 ** This function registered all of the above C functions as SQL
1213 ** functions. This should be the only routine in this file with
1214 ** external linkage.
1216 void sqlite3RegisterBuiltinFunctions(sqlite3 *db){
1217 static const struct {
1220 u8 argType; /* 1: 0, 2: 1, 3: 2,... N: N-1. */
1221 u8 eTextRep; /* 1: UTF-16. 0: UTF-8 */
1223 void (*xFunc)(sqlite3_context*,int,sqlite3_value **);
1225 { "min", -1, 0, SQLITE_UTF8, 1, minmaxFunc },
1226 { "min", 0, 0, SQLITE_UTF8, 1, 0 },
1227 { "max", -1, 1, SQLITE_UTF8, 1, minmaxFunc },
1228 { "max", 0, 1, SQLITE_UTF8, 1, 0 },
1229 { "typeof", 1, 0, SQLITE_UTF8, 0, typeofFunc },
1230 { "length", 1, 0, SQLITE_UTF8, 0, lengthFunc },
1231 { "substr", 2, 0, SQLITE_UTF8, 0, substrFunc },
1232 { "substr", 3, 0, SQLITE_UTF8, 0, substrFunc },
1233 { "abs", 1, 0, SQLITE_UTF8, 0, absFunc },
1234 { "round", 1, 0, SQLITE_UTF8, 0, roundFunc },
1235 { "round", 2, 0, SQLITE_UTF8, 0, roundFunc },
1236 { "upper", 1, 0, SQLITE_UTF8, 0, upperFunc },
1237 { "lower", 1, 0, SQLITE_UTF8, 0, lowerFunc },
1238 { "coalesce", -1, 0, SQLITE_UTF8, 0, ifnullFunc },
1239 { "coalesce", 0, 0, SQLITE_UTF8, 0, 0 },
1240 { "coalesce", 1, 0, SQLITE_UTF8, 0, 0 },
1241 { "hex", 1, 0, SQLITE_UTF8, 0, hexFunc },
1242 { "ifnull", 2, 0, SQLITE_UTF8, 1, ifnullFunc },
1243 { "random", -1, 0, SQLITE_UTF8, 0, randomFunc },
1244 { "randomblob", 1, 0, SQLITE_UTF8, 0, randomBlob },
1245 { "nullif", 2, 0, SQLITE_UTF8, 1, nullifFunc },
1246 { "sqlite_version", 0, 0, SQLITE_UTF8, 0, versionFunc},
1247 { "quote", 1, 0, SQLITE_UTF8, 0, quoteFunc },
1248 { "last_insert_rowid", 0, 0, SQLITE_UTF8, 0, last_insert_rowid },
1249 { "changes", 0, 0, SQLITE_UTF8, 0, changes },
1250 { "total_changes", 0, 0, SQLITE_UTF8, 0, total_changes },
1251 { "replace", 3, 0, SQLITE_UTF8, 0, replaceFunc },
1252 { "ltrim", 1, 1, SQLITE_UTF8, 0, trimFunc },
1253 { "ltrim", 2, 1, SQLITE_UTF8, 0, trimFunc },
1254 { "rtrim", 1, 2, SQLITE_UTF8, 0, trimFunc },
1255 { "rtrim", 2, 2, SQLITE_UTF8, 0, trimFunc },
1256 { "trim", 1, 3, SQLITE_UTF8, 0, trimFunc },
1257 { "trim", 2, 3, SQLITE_UTF8, 0, trimFunc },
1258 { "zeroblob", 1, 0, SQLITE_UTF8, 0, zeroblobFunc },
1259 #ifdef SQLITE_SOUNDEX
1260 { "soundex", 1, 0, SQLITE_UTF8, 0, soundexFunc},
1262 #ifndef SQLITE_OMIT_LOAD_EXTENSION
1263 { "load_extension", 1, 0, SQLITE_UTF8, 0, loadExt },
1264 { "load_extension", 2, 0, SQLITE_UTF8, 0, loadExt },
1267 static const struct {
1272 void (*xStep)(sqlite3_context*,int,sqlite3_value**);
1273 void (*xFinalize)(sqlite3_context*);
1275 { "min", 1, 0, 1, minmaxStep, minMaxFinalize },
1276 { "max", 1, 1, 1, minmaxStep, minMaxFinalize },
1277 { "sum", 1, 0, 0, sumStep, sumFinalize },
1278 { "total", 1, 0, 0, sumStep, totalFinalize },
1279 { "avg", 1, 0, 0, sumStep, avgFinalize },
1280 { "count", 0, 0, 0, countStep, countFinalize },
1281 { "count", 1, 0, 0, countStep, countFinalize },
1282 { "group_concat", -1, 0, 0, groupConcatStep, groupConcatFinalize },
1286 for(i=0; i<sizeof(aFuncs)/sizeof(aFuncs[0]); i++){
1288 u8 argType = aFuncs[i].argType;
1289 pArg = SQLITE_INT_TO_PTR(argType);
1290 sqlite3CreateFunc(db, aFuncs[i].zName, aFuncs[i].nArg,
1291 aFuncs[i].eTextRep, pArg, aFuncs[i].xFunc, 0, 0);
1292 if( aFuncs[i].needCollSeq ){
1293 FuncDef *pFunc = sqlite3FindFunction(db, aFuncs[i].zName,
1294 strlen(aFuncs[i].zName), aFuncs[i].nArg, aFuncs[i].eTextRep, 0);
1295 if( pFunc && aFuncs[i].needCollSeq ){
1296 pFunc->needCollSeq = 1;
1300 #ifndef SQLITE_OMIT_ALTERTABLE
1301 sqlite3AlterFunctions(db);
1303 #ifndef SQLITE_OMIT_PARSER
1304 sqlite3AttachFunctions(db);
1306 for(i=0; i<sizeof(aAggs)/sizeof(aAggs[0]); i++){
1307 void *pArg = SQLITE_INT_TO_PTR(aAggs[i].argType);
1308 sqlite3CreateFunc(db, aAggs[i].zName, aAggs[i].nArg, SQLITE_UTF8,
1309 pArg, 0, aAggs[i].xStep, aAggs[i].xFinalize);
1310 if( aAggs[i].needCollSeq ){
1311 FuncDef *pFunc = sqlite3FindFunction( db, aAggs[i].zName,
1312 strlen(aAggs[i].zName), aAggs[i].nArg, SQLITE_UTF8, 0);
1313 if( pFunc && aAggs[i].needCollSeq ){
1314 pFunc->needCollSeq = 1;
1318 sqlite3RegisterDateTimeFunctions(db);
1319 if( !db->mallocFailed ){
1320 int rc = sqlite3_overload_function(db, "MATCH", 2);
1321 assert( rc==SQLITE_NOMEM || rc==SQLITE_OK );
1322 if( rc==SQLITE_NOMEM ){
1323 db->mallocFailed = 1;
1327 (void)sqlite3SseFunctions(db);
1329 #ifdef SQLITE_CASE_SENSITIVE_LIKE
1330 sqlite3RegisterLikeFunctions(db, 1);
1332 sqlite3RegisterLikeFunctions(db, 0);
1337 ** Set the LIKEOPT flag on the 2-argument function with the given name.
1339 static void setLikeOptFlag(sqlite3 *db, const char *zName, int flagVal){
1341 pDef = sqlite3FindFunction(db, zName, strlen(zName), 2, SQLITE_UTF8, 0);
1343 pDef->flags = flagVal;
1348 ** Register the built-in LIKE and GLOB functions. The caseSensitive
1349 ** parameter determines whether or not the LIKE operator is case
1350 ** sensitive. GLOB is always case sensitive.
1352 void sqlite3RegisterLikeFunctions(sqlite3 *db, int caseSensitive){
1353 struct compareInfo *pInfo;
1354 if( caseSensitive ){
1355 pInfo = (struct compareInfo*)&likeInfoAlt;
1357 pInfo = (struct compareInfo*)&likeInfoNorm;
1359 sqlite3CreateFunc(db, "like", 2, SQLITE_UTF8, pInfo, likeFunc, 0, 0);
1360 sqlite3CreateFunc(db, "like", 3, SQLITE_UTF8, pInfo, likeFunc, 0, 0);
1361 sqlite3CreateFunc(db, "glob", 2, SQLITE_UTF8,
1362 (struct compareInfo*)&globInfo, likeFunc, 0,0);
1363 setLikeOptFlag(db, "glob", SQLITE_FUNC_LIKE | SQLITE_FUNC_CASE);
1364 setLikeOptFlag(db, "like",
1365 caseSensitive ? (SQLITE_FUNC_LIKE | SQLITE_FUNC_CASE) : SQLITE_FUNC_LIKE);
1369 ** pExpr points to an expression which implements a function. If
1370 ** it is appropriate to apply the LIKE optimization to that function
1371 ** then set aWc[0] through aWc[2] to the wildcard characters and
1372 ** return TRUE. If the function is not a LIKE-style function then
1375 int sqlite3IsLikeFunction(sqlite3 *db, Expr *pExpr, int *pIsNocase, char *aWc){
1377 if( pExpr->op!=TK_FUNCTION || !pExpr->pList ){
1380 if( pExpr->pList->nExpr!=2 ){
1383 pDef = sqlite3FindFunction(db, (char*)pExpr->token.z, pExpr->token.n, 2,
1385 if( pDef==0 || (pDef->flags & SQLITE_FUNC_LIKE)==0 ){
1389 /* The memcpy() statement assumes that the wildcard characters are
1390 ** the first three statements in the compareInfo structure. The
1391 ** asserts() that follow verify that assumption
1393 memcpy(aWc, pDef->pUserData, 3);
1394 assert( (char*)&likeInfoAlt == (char*)&likeInfoAlt.matchAll );
1395 assert( &((char*)&likeInfoAlt)[1] == (char*)&likeInfoAlt.matchOne );
1396 assert( &((char*)&likeInfoAlt)[2] == (char*)&likeInfoAlt.matchSet );
1397 *pIsNocase = (pDef->flags & SQLITE_FUNC_CASE)==0;