/ Hex Artifact Content
Login

Artifact 3afab2291762b5d09ae20c18feb8e9fa935a60a6:


0000: 2f 2a 0a 2a 2a 20 32 30 30 37 20 4d 61 79 20 37  /*.** 2007 May 7
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a  ***************.
0170: 2a 2a 20 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65  ** .** This file
0180: 20 64 65 66 69 6e 65 73 20 76 61 72 69 6f 75 73   defines various
0190: 20 6c 69 6d 69 74 73 20 6f 66 20 77 68 61 74 20   limits of what 
01a0: 53 51 4c 69 74 65 20 63 61 6e 20 70 72 6f 63 65  SQLite can proce
01b0: 73 73 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 54 68  ss..*/../*.** Th
01c0: 65 20 6d 61 78 69 6d 75 6d 20 6c 65 6e 67 74 68  e maximum length
01d0: 20 6f 66 20 61 20 54 45 58 54 20 6f 72 20 42 4c   of a TEXT or BL
01e0: 4f 42 20 69 6e 20 62 79 74 65 73 2e 20 20 20 54  OB in bytes.   T
01f0: 68 69 73 20 61 6c 73 6f 0a 2a 2a 20 6c 69 6d 69  his also.** limi
0200: 74 73 20 74 68 65 20 73 69 7a 65 20 6f 66 20 61  ts the size of a
0210: 20 72 6f 77 20 69 6e 20 61 20 74 61 62 6c 65 20   row in a table 
0220: 6f 72 20 69 6e 64 65 78 2e 0a 2a 2a 0a 2a 2a 20  or index..**.** 
0230: 54 68 65 20 68 61 72 64 20 6c 69 6d 69 74 20 69  The hard limit i
0240: 73 20 74 68 65 20 61 62 69 6c 69 74 79 20 6f 66  s the ability of
0250: 20 61 20 33 32 2d 62 69 74 20 73 69 67 6e 65 64   a 32-bit signed
0260: 20 69 6e 74 65 67 65 72 0a 2a 2a 20 74 6f 20 63   integer.** to c
0270: 6f 75 6e 74 20 74 68 65 20 73 69 7a 65 3a 20 32  ount the size: 2
0280: 5e 33 31 2d 31 20 6f 72 20 32 31 34 37 34 38 33  ^31-1 or 2147483
0290: 36 34 37 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20  647..*/.#ifndef 
02a0: 53 51 4c 49 54 45 5f 4d 41 58 5f 4c 45 4e 47 54  SQLITE_MAX_LENGT
02b0: 48 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54  H.# define SQLIT
02c0: 45 5f 4d 41 58 5f 4c 45 4e 47 54 48 20 31 30 30  E_MAX_LENGTH 100
02d0: 30 30 30 30 30 30 30 0a 23 65 6e 64 69 66 0a 0a  0000000.#endif..
02e0: 2f 2a 0a 2a 2a 20 54 68 69 73 20 69 73 20 74 68  /*.** This is th
02f0: 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65 72  e maximum number
0300: 20 6f 66 0a 2a 2a 0a 2a 2a 20 20 20 20 2a 20 43   of.**.**    * C
0310: 6f 6c 75 6d 6e 73 20 69 6e 20 61 20 74 61 62 6c  olumns in a tabl
0320: 65 0a 2a 2a 20 20 20 20 2a 20 43 6f 6c 75 6d 6e  e.**    * Column
0330: 73 20 69 6e 20 61 6e 20 69 6e 64 65 78 0a 2a 2a  s in an index.**
0340: 20 20 20 20 2a 20 43 6f 6c 75 6d 6e 73 20 69 6e      * Columns in
0350: 20 61 20 76 69 65 77 0a 2a 2a 20 20 20 20 2a 20   a view.**    * 
0360: 54 65 72 6d 73 20 69 6e 20 74 68 65 20 53 45 54  Terms in the SET
0370: 20 63 6c 61 75 73 65 20 6f 66 20 61 6e 20 55 50   clause of an UP
0380: 44 41 54 45 20 73 74 61 74 65 6d 65 6e 74 0a 2a  DATE statement.*
0390: 2a 20 20 20 20 2a 20 54 65 72 6d 73 20 69 6e 20  *    * Terms in 
03a0: 74 68 65 20 72 65 73 75 6c 74 20 73 65 74 20 6f  the result set o
03b0: 66 20 61 20 53 45 4c 45 43 54 20 73 74 61 74 65  f a SELECT state
03c0: 6d 65 6e 74 0a 2a 2a 20 20 20 20 2a 20 54 65 72  ment.**    * Ter
03d0: 6d 73 20 69 6e 20 74 68 65 20 47 52 4f 55 50 20  ms in the GROUP 
03e0: 42 59 20 6f 72 20 4f 52 44 45 52 20 42 59 20 63  BY or ORDER BY c
03f0: 6c 61 75 73 65 73 20 6f 66 20 61 20 53 45 4c 45  lauses of a SELE
0400: 43 54 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2a  CT statement..**
0410: 20 20 20 20 2a 20 54 65 72 6d 73 20 69 6e 20 74      * Terms in t
0420: 68 65 20 56 41 4c 55 45 53 20 63 6c 61 75 73 65  he VALUES clause
0430: 20 6f 66 20 61 6e 20 49 4e 53 45 52 54 20 73 74   of an INSERT st
0440: 61 74 65 6d 65 6e 74 0a 2a 2a 0a 2a 2a 20 54 68  atement.**.** Th
0450: 65 20 68 61 72 64 20 75 70 70 65 72 20 6c 69 6d  e hard upper lim
0460: 69 74 20 68 65 72 65 20 69 73 20 33 32 36 37 36  it here is 32676
0470: 2e 20 20 4d 6f 73 74 20 64 61 74 61 62 61 73 65  .  Most database
0480: 20 70 65 6f 70 6c 65 20 77 69 6c 6c 0a 2a 2a 20   people will.** 
0490: 74 65 6c 6c 20 79 6f 75 20 74 68 61 74 20 69 6e  tell you that in
04a0: 20 61 20 77 65 6c 6c 2d 6e 6f 72 6d 61 6c 69 7a   a well-normaliz
04b0: 65 64 20 64 61 74 61 62 61 73 65 2c 20 79 6f 75  ed database, you
04c0: 20 75 73 75 61 6c 6c 79 20 73 68 6f 75 6c 64 0a   usually should.
04d0: 2a 2a 20 6e 6f 74 20 68 61 76 65 20 6d 6f 72 65  ** not have more
04e0: 20 74 68 61 6e 20 61 20 64 6f 7a 65 6e 20 6f 72   than a dozen or
04f0: 20 73 6f 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 61   so columns in a
0500: 6e 79 20 74 61 62 6c 65 2e 20 20 41 6e 64 20 69  ny table.  And i
0510: 66 0a 2a 2a 20 74 68 61 74 20 69 73 20 74 68 65  f.** that is the
0520: 20 63 61 73 65 2c 20 74 68 65 72 65 20 69 73 20   case, there is 
0530: 6e 6f 20 70 6f 69 6e 74 20 69 6e 20 68 61 76 69  no point in havi
0540: 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 61 20 66  ng more than a f
0550: 65 77 0a 2a 2a 20 64 6f 7a 65 6e 20 76 61 6c 75  ew.** dozen valu
0560: 65 73 20 69 6e 20 61 6e 79 20 6f 66 20 74 68 65  es in any of the
0570: 20 6f 74 68 65 72 20 73 69 74 75 61 74 69 6f 6e   other situation
0580: 73 20 64 65 73 63 72 69 62 65 64 20 61 62 6f 76  s described abov
0590: 65 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  e..*/.#ifndef SQ
05a0: 4c 49 54 45 5f 4d 41 58 5f 43 4f 4c 55 4d 4e 0a  LITE_MAX_COLUMN.
05b0: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
05c0: 4d 41 58 5f 43 4f 4c 55 4d 4e 20 32 30 30 30 0a  MAX_COLUMN 2000.
05d0: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68  #endif../*.** Th
05e0: 65 20 6d 61 78 69 6d 75 6d 20 6c 65 6e 67 74 68  e maximum length
05f0: 20 6f 66 20 61 20 73 69 6e 67 6c 65 20 53 51 4c   of a single SQL
0600: 20 73 74 61 74 65 6d 65 6e 74 20 69 6e 20 62 79   statement in by
0610: 74 65 73 2e 0a 2a 2a 0a 2a 2a 20 49 74 20 75 73  tes..**.** It us
0620: 65 64 20 74 6f 20 62 65 20 74 68 65 20 63 61 73  ed to be the cas
0630: 65 20 74 68 61 74 20 73 65 74 74 69 6e 67 20 74  e that setting t
0640: 68 69 73 20 76 61 6c 75 65 20 74 6f 20 7a 65 72  his value to zer
0650: 6f 20 77 6f 75 6c 64 0a 2a 2a 20 74 75 72 6e 20  o would.** turn 
0660: 74 68 65 20 6c 69 6d 69 74 20 6f 66 66 2e 20 20  the limit off.  
0670: 54 68 61 74 20 69 73 20 6e 6f 20 6c 6f 6e 67 65  That is no longe
0680: 72 20 74 72 75 65 2e 20 20 49 74 20 69 73 20 6e  r true.  It is n
0690: 6f 74 20 70 6f 73 73 69 62 6c 65 0a 2a 2a 20 74  ot possible.** t
06a0: 6f 20 74 75 72 6e 20 74 68 69 73 20 6c 69 6d 69  o turn this limi
06b0: 74 20 6f 66 66 2e 0a 2a 2f 0a 23 69 66 6e 64 65  t off..*/.#ifnde
06c0: 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 53 51 4c  f SQLITE_MAX_SQL
06d0: 5f 4c 45 4e 47 54 48 0a 23 20 64 65 66 69 6e 65  _LENGTH.# define
06e0: 20 53 51 4c 49 54 45 5f 4d 41 58 5f 53 51 4c 5f   SQLITE_MAX_SQL_
06f0: 4c 45 4e 47 54 48 20 31 30 30 30 30 30 30 30 30  LENGTH 100000000
0700: 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20  0.#endif../*.** 
0710: 54 68 65 20 6d 61 78 69 6d 75 6d 20 64 65 70 74  The maximum dept
0720: 68 20 6f 66 20 61 6e 20 65 78 70 72 65 73 73 69  h of an expressi
0730: 6f 6e 20 74 72 65 65 2e 20 54 68 69 73 20 69 73  on tree. This is
0740: 20 6c 69 6d 69 74 65 64 20 74 6f 20 0a 2a 2a 20   limited to .** 
0750: 73 6f 6d 65 20 65 78 74 65 6e 74 20 62 79 20 53  some extent by S
0760: 51 4c 49 54 45 5f 4d 41 58 5f 53 51 4c 5f 4c 45  QLITE_MAX_SQL_LE
0770: 4e 47 54 48 2e 20 42 75 74 20 73 6f 6d 65 74 69  NGTH. But someti
0780: 6d 65 20 79 6f 75 20 6d 69 67 68 74 20 0a 2a 2a  me you might .**
0790: 20 77 61 6e 74 20 74 6f 20 70 6c 61 63 65 20 6d   want to place m
07a0: 6f 72 65 20 73 65 76 65 72 65 20 6c 69 6d 69 74  ore severe limit
07b0: 73 20 6f 6e 20 74 68 65 20 63 6f 6d 70 6c 65 78  s on the complex
07c0: 69 74 79 20 6f 66 20 61 6e 20 0a 2a 2a 20 65 78  ity of an .** ex
07d0: 70 72 65 73 73 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20  pression..**.** 
07e0: 41 20 76 61 6c 75 65 20 6f 66 20 30 20 75 73 65  A value of 0 use
07f0: 64 20 74 6f 20 6d 65 61 6e 20 74 68 61 74 20 74  d to mean that t
0800: 68 65 20 6c 69 6d 69 74 20 77 61 73 20 6e 6f 74  he limit was not
0810: 20 65 6e 66 6f 72 63 65 64 2e 0a 2a 2a 20 42 75   enforced..** Bu
0820: 74 20 74 68 61 74 20 69 73 20 6e 6f 20 6c 6f 6e  t that is no lon
0830: 67 65 72 20 74 72 75 65 2e 20 20 54 68 65 20 6c  ger true.  The l
0840: 69 6d 69 74 20 69 73 20 6e 6f 77 20 73 74 72 69  imit is now stri
0850: 63 74 6c 79 20 65 6e 66 6f 72 63 65 64 0a 2a 2a  ctly enforced.**
0860: 20 61 74 20 61 6c 6c 20 74 69 6d 65 73 2e 0a 2a   at all times..*
0870: 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  /.#ifndef SQLITE
0880: 5f 4d 41 58 5f 45 58 50 52 5f 44 45 50 54 48 0a  _MAX_EXPR_DEPTH.
0890: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
08a0: 4d 41 58 5f 45 58 50 52 5f 44 45 50 54 48 20 31  MAX_EXPR_DEPTH 1
08b0: 30 30 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a  000.#endif../*.*
08c0: 2a 20 54 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75  * The maximum nu
08d0: 6d 62 65 72 20 6f 66 20 74 65 72 6d 73 20 69 6e  mber of terms in
08e0: 20 61 20 63 6f 6d 70 6f 75 6e 64 20 53 45 4c 45   a compound SELE
08f0: 43 54 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2a  CT statement..**
0900: 20 54 68 65 20 63 6f 64 65 20 67 65 6e 65 72 61   The code genera
0910: 74 6f 72 20 66 6f 72 20 63 6f 6d 70 6f 75 6e 64  tor for compound
0920: 20 53 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e   SELECT statemen
0930: 74 73 20 64 6f 65 73 20 6f 6e 65 0a 2a 2a 20 6c  ts does one.** l
0940: 65 76 65 6c 20 6f 66 20 72 65 63 75 72 73 69 6f  evel of recursio
0950: 6e 20 66 6f 72 20 65 61 63 68 20 74 65 72 6d 2e  n for each term.
0960: 20 20 41 20 73 74 61 63 6b 20 6f 76 65 72 66 6c    A stack overfl
0970: 6f 77 20 63 61 6e 20 72 65 73 75 6c 74 0a 2a 2a  ow can result.**
0980: 20 69 66 20 74 68 65 20 6e 75 6d 62 65 72 20 6f   if the number o
0990: 66 20 74 65 72 6d 73 20 69 73 20 74 6f 6f 20 6c  f terms is too l
09a0: 61 72 67 65 2e 20 20 49 6e 20 70 72 61 63 74 69  arge.  In practi
09b0: 63 65 2c 20 6d 6f 73 74 20 53 51 4c 0a 2a 2a 20  ce, most SQL.** 
09c0: 6e 65 76 65 72 20 68 61 73 20 6d 6f 72 65 20 74  never has more t
09d0: 68 61 6e 20 33 20 6f 72 20 34 20 74 65 72 6d 73  han 3 or 4 terms
09e0: 2e 20 20 55 73 65 20 61 20 76 61 6c 75 65 20 6f  .  Use a value o
09f0: 66 20 30 20 74 6f 20 64 69 73 61 62 6c 65 0a 2a  f 0 to disable.*
0a00: 2a 20 61 6e 79 20 6c 69 6d 69 74 20 6f 6e 20 74  * any limit on t
0a10: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 74 65 72  he number of ter
0a20: 6d 73 20 69 6e 20 61 20 63 6f 6d 70 6f 75 6e 74  ms in a compount
0a30: 20 53 45 4c 45 43 54 2e 0a 2a 2f 0a 23 69 66 6e   SELECT..*/.#ifn
0a40: 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 43  def SQLITE_MAX_C
0a50: 4f 4d 50 4f 55 4e 44 5f 53 45 4c 45 43 54 0a 23  OMPOUND_SELECT.#
0a60: 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d   define SQLITE_M
0a70: 41 58 5f 43 4f 4d 50 4f 55 4e 44 5f 53 45 4c 45  AX_COMPOUND_SELE
0a80: 43 54 20 35 30 30 0a 23 65 6e 64 69 66 0a 0a 2f  CT 500.#endif../
0a90: 2a 0a 2a 2a 20 54 68 65 20 6d 61 78 69 6d 75 6d  *.** The maximum
0aa0: 20 6e 75 6d 62 65 72 20 6f 66 20 6f 70 63 6f 64   number of opcod
0ab0: 65 73 20 69 6e 20 61 20 56 44 42 45 20 70 72 6f  es in a VDBE pro
0ac0: 67 72 61 6d 2e 0a 2a 2a 20 4e 6f 74 20 63 75 72  gram..** Not cur
0ad0: 72 65 6e 74 6c 79 20 65 6e 66 6f 72 63 65 64 2e  rently enforced.
0ae0: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  .*/.#ifndef SQLI
0af0: 54 45 5f 4d 41 58 5f 56 44 42 45 5f 4f 50 0a 23  TE_MAX_VDBE_OP.#
0b00: 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d   define SQLITE_M
0b10: 41 58 5f 56 44 42 45 5f 4f 50 20 32 35 30 30 30  AX_VDBE_OP 25000
0b20: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54  .#endif../*.** T
0b30: 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62 65  he maximum numbe
0b40: 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73 20 74  r of arguments t
0b50: 6f 20 61 6e 20 53 51 4c 20 66 75 6e 63 74 69 6f  o an SQL functio
0b60: 6e 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  n..*/.#ifndef SQ
0b70: 4c 49 54 45 5f 4d 41 58 5f 46 55 4e 43 54 49 4f  LITE_MAX_FUNCTIO
0b80: 4e 5f 41 52 47 0a 23 20 64 65 66 69 6e 65 20 53  N_ARG.# define S
0b90: 51 4c 49 54 45 5f 4d 41 58 5f 46 55 4e 43 54 49  QLITE_MAX_FUNCTI
0ba0: 4f 4e 5f 41 52 47 20 31 32 37 0a 23 65 6e 64 69  ON_ARG 127.#endi
0bb0: 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6d 61 78  f../*.** The max
0bc0: 69 6d 75 6d 20 6e 75 6d 62 65 72 20 6f 66 20 69  imum number of i
0bd0: 6e 2d 6d 65 6d 6f 72 79 20 70 61 67 65 73 20 74  n-memory pages t
0be0: 6f 20 75 73 65 20 66 6f 72 20 74 68 65 20 6d 61  o use for the ma
0bf0: 69 6e 20 64 61 74 61 62 61 73 65 0a 2a 2a 20 74  in database.** t
0c00: 61 62 6c 65 20 61 6e 64 20 66 6f 72 20 74 65 6d  able and for tem
0c10: 70 6f 72 61 72 79 20 74 61 62 6c 65 73 2e 20 20  porary tables.  
0c20: 54 68 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55  The SQLITE_DEFAU
0c30: 4c 54 5f 43 41 43 48 45 5f 53 49 5a 45 0a 2a 2f  LT_CACHE_SIZE.*/
0c40: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
0c50: 44 45 46 41 55 4c 54 5f 43 41 43 48 45 5f 53 49  DEFAULT_CACHE_SI
0c60: 5a 45 0a 23 20 64 65 66 69 6e 65 20 53 51 4c 49  ZE.# define SQLI
0c70: 54 45 5f 44 45 46 41 55 4c 54 5f 43 41 43 48 45  TE_DEFAULT_CACHE
0c80: 5f 53 49 5a 45 20 20 32 30 30 30 0a 23 65 6e 64  _SIZE  2000.#end
0c90: 69 66 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  if.#ifndef SQLIT
0ca0: 45 5f 44 45 46 41 55 4c 54 5f 54 45 4d 50 5f 43  E_DEFAULT_TEMP_C
0cb0: 41 43 48 45 5f 53 49 5a 45 0a 23 20 64 65 66 69  ACHE_SIZE.# defi
0cc0: 6e 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c  ne SQLITE_DEFAUL
0cd0: 54 5f 54 45 4d 50 5f 43 41 43 48 45 5f 53 49 5a  T_TEMP_CACHE_SIZ
0ce0: 45 20 20 35 30 30 0a 23 65 6e 64 69 66 0a 0a 2f  E  500.#endif../
0cf0: 2a 0a 2a 2a 20 54 68 65 20 6d 61 78 69 6d 75 6d  *.** The maximum
0d00: 20 6e 75 6d 62 65 72 20 6f 66 20 61 74 74 61 63   number of attac
0d10: 68 65 64 20 64 61 74 61 62 61 73 65 73 2e 20 20  hed databases.  
0d20: 54 68 69 73 20 6d 75 73 74 20 62 65 20 62 65 74  This must be bet
0d30: 77 65 65 6e 20 30 0a 2a 2a 20 61 6e 64 20 33 30  ween 0.** and 30
0d40: 2e 20 20 54 68 65 20 75 70 70 65 72 20 62 6f 75  .  The upper bou
0d50: 6e 64 20 6f 6e 20 33 30 20 69 73 20 62 65 63 61  nd on 30 is beca
0d60: 75 73 65 20 61 20 33 32 2d 62 69 74 20 69 6e 74  use a 32-bit int
0d70: 65 67 65 72 20 62 69 74 6d 61 70 0a 2a 2a 20 69  eger bitmap.** i
0d80: 73 20 75 73 65 64 20 69 6e 74 65 72 6e 61 6c 6c  s used internall
0d90: 79 20 74 6f 20 74 72 61 63 6b 20 61 74 74 61 63  y to track attac
0da0: 68 65 64 20 64 61 74 61 62 61 73 65 73 2e 0a 2a  hed databases..*
0db0: 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  /.#ifndef SQLITE
0dc0: 5f 4d 41 58 5f 41 54 54 41 43 48 45 44 0a 23 20  _MAX_ATTACHED.# 
0dd0: 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41  define SQLITE_MA
0de0: 58 5f 41 54 54 41 43 48 45 44 20 31 30 0a 23 65  X_ATTACHED 10.#e
0df0: 6e 64 69 66 0a 0a 0a 2f 2a 0a 2a 2a 20 54 68 65  ndif.../*.** The
0e00: 20 6d 61 78 69 6d 75 6d 20 76 61 6c 75 65 20 6f   maximum value o
0e10: 66 20 61 20 3f 6e 6e 6e 20 77 69 6c 64 63 61 72  f a ?nnn wildcar
0e20: 64 20 74 68 61 74 20 74 68 65 20 70 61 72 73 65  d that the parse
0e30: 72 20 77 69 6c 6c 20 61 63 63 65 70 74 2e 0a 2a  r will accept..*
0e40: 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  /.#ifndef SQLITE
0e50: 5f 4d 41 58 5f 56 41 52 49 41 42 4c 45 5f 4e 55  _MAX_VARIABLE_NU
0e60: 4d 42 45 52 0a 23 20 64 65 66 69 6e 65 20 53 51  MBER.# define SQ
0e70: 4c 49 54 45 5f 4d 41 58 5f 56 41 52 49 41 42 4c  LITE_MAX_VARIABL
0e80: 45 5f 4e 55 4d 42 45 52 20 39 39 39 0a 23 65 6e  E_NUMBER 999.#en
0e90: 64 69 66 0a 0a 2f 2a 20 4d 61 78 69 6d 75 6d 20  dif../* Maximum 
0ea0: 70 61 67 65 20 73 69 7a 65 2e 20 20 54 68 65 20  page size.  The 
0eb0: 75 70 70 65 72 20 62 6f 75 6e 64 20 6f 6e 20 74  upper bound on t
0ec0: 68 69 73 20 76 61 6c 75 65 20 69 73 20 33 32 37  his value is 327
0ed0: 36 38 2e 20 20 54 68 69 73 20 61 20 6c 69 6d 69  68.  This a limi
0ee0: 74 0a 2a 2a 20 69 6d 70 6f 73 65 64 20 62 79 20  t.** imposed by 
0ef0: 74 68 65 20 6e 65 63 65 73 73 69 74 79 20 6f 66  the necessity of
0f00: 20 73 74 6f 72 69 6e 67 20 74 68 65 20 76 61 6c   storing the val
0f10: 75 65 20 69 6e 20 61 20 32 2d 62 79 74 65 20 75  ue in a 2-byte u
0f20: 6e 73 69 67 6e 65 64 20 69 6e 74 65 67 65 72 0a  nsigned integer.
0f30: 2a 2a 20 61 6e 64 20 74 68 65 20 66 61 63 74 20  ** and the fact 
0f40: 74 68 61 74 20 74 68 65 20 70 61 67 65 20 73 69  that the page si
0f50: 7a 65 20 6d 75 73 74 20 62 65 20 61 20 70 6f 77  ze must be a pow
0f60: 65 72 20 6f 66 20 32 2e 0a 2a 2a 0a 2a 2a 20 49  er of 2..**.** I
0f70: 66 20 74 68 69 73 20 6c 69 6d 69 74 20 69 73 20  f this limit is 
0f80: 63 68 61 6e 67 65 64 2c 20 74 68 65 6e 20 74 68  changed, then th
0f90: 65 20 63 6f 6d 70 69 6c 65 64 20 6c 69 62 72 61  e compiled libra
0fa0: 72 79 20 69 73 20 74 65 63 68 6e 69 63 61 6c 6c  ry is technicall
0fb0: 79 0a 2a 2a 20 69 6e 63 6f 6d 70 61 74 69 62 6c  y.** incompatibl
0fc0: 65 20 77 69 74 68 20 61 6e 20 53 51 4c 69 74 65  e with an SQLite
0fd0: 20 6c 69 62 72 61 72 79 20 63 6f 6d 70 69 6c 65   library compile
0fe0: 64 20 77 69 74 68 20 61 20 64 69 66 66 65 72 65  d with a differe
0ff0: 6e 74 20 6c 69 6d 69 74 2e 20 49 66 0a 2a 2a 20  nt limit. If.** 
1000: 61 20 70 72 6f 63 65 73 73 20 6f 70 65 72 61 74  a process operat
1010: 69 6e 67 20 6f 6e 20 61 20 64 61 74 61 62 61 73  ing on a databas
1020: 65 20 77 69 74 68 20 61 20 70 61 67 65 2d 73 69  e with a page-si
1030: 7a 65 20 6f 66 20 36 35 35 33 36 20 62 79 74 65  ze of 65536 byte
1040: 73 20 0a 2a 2a 20 63 72 61 73 68 65 73 2c 20 74  s .** crashes, t
1050: 68 65 6e 20 61 6e 20 69 6e 73 74 61 6e 63 65 20  hen an instance 
1060: 6f 66 20 53 51 4c 69 74 65 20 63 6f 6d 70 69 6c  of SQLite compil
1070: 65 64 20 77 69 74 68 20 74 68 65 20 64 65 66 61  ed with the defa
1080: 75 6c 74 20 70 61 67 65 2d 73 69 7a 65 20 0a 2a  ult page-size .*
1090: 2a 20 6c 69 6d 69 74 20 77 69 6c 6c 20 6e 6f 74  * limit will not
10a0: 20 62 65 20 61 62 6c 65 20 74 6f 20 72 6f 6c 6c   be able to roll
10b0: 62 61 63 6b 20 74 68 65 20 61 62 6f 72 74 65 64  back the aborted
10c0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 2e 20 54 68   transaction. Th
10d0: 69 73 20 63 6f 75 6c 64 0a 2a 2a 20 6c 65 61 64  is could.** lead
10e0: 20 74 6f 20 64 61 74 61 62 61 73 65 20 63 6f 72   to database cor
10f0: 72 75 70 74 69 6f 6e 2e 0a 2a 2f 0a 23 69 66 6e  ruption..*/.#ifn
1100: 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 50  def SQLITE_MAX_P
1110: 41 47 45 5f 53 49 5a 45 0a 23 20 64 65 66 69 6e  AGE_SIZE.# defin
1120: 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41 47  e SQLITE_MAX_PAG
1130: 45 5f 53 49 5a 45 20 33 32 37 36 38 0a 23 65 6e  E_SIZE 32768.#en
1140: 64 69 66 0a 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20  dif.../*.** The 
1150: 64 65 66 61 75 6c 74 20 73 69 7a 65 20 6f 66 20  default size of 
1160: 61 20 64 61 74 61 62 61 73 65 20 70 61 67 65 2e  a database page.
1170: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  .*/.#ifndef SQLI
1180: 54 45 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f  TE_DEFAULT_PAGE_
1190: 53 49 5a 45 0a 23 20 64 65 66 69 6e 65 20 53 51  SIZE.# define SQ
11a0: 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f 50 41 47  LITE_DEFAULT_PAG
11b0: 45 5f 53 49 5a 45 20 31 30 32 34 0a 23 65 6e 64  E_SIZE 1024.#end
11c0: 69 66 0a 23 69 66 20 53 51 4c 49 54 45 5f 44 45  if.#if SQLITE_DE
11d0: 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45 3e  FAULT_PAGE_SIZE>
11e0: 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41 47 45 5f  SQLITE_MAX_PAGE_
11f0: 53 49 5a 45 0a 23 20 75 6e 64 65 66 20 53 51 4c  SIZE.# undef SQL
1200: 49 54 45 5f 44 45 46 41 55 4c 54 5f 50 41 47 45  ITE_DEFAULT_PAGE
1210: 5f 53 49 5a 45 0a 23 20 64 65 66 69 6e 65 20 53  _SIZE.# define S
1220: 51 4c 49 54 45 5f 44 45 46 41 55 4c 54 5f 50 41  QLITE_DEFAULT_PA
1230: 47 45 5f 53 49 5a 45 20 53 51 4c 49 54 45 5f 4d  GE_SIZE SQLITE_M
1240: 41 58 5f 50 41 47 45 5f 53 49 5a 45 0a 23 65 6e  AX_PAGE_SIZE.#en
1250: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 4f 72 64 69 6e  dif../*.** Ordin
1260: 61 72 69 6c 79 2c 20 69 66 20 6e 6f 20 76 61 6c  arily, if no val
1270: 75 65 20 69 73 20 65 78 70 6c 69 63 69 74 6c 79  ue is explicitly
1280: 20 70 72 6f 76 69 64 65 64 2c 20 53 51 4c 69 74   provided, SQLit
1290: 65 20 63 72 65 61 74 65 73 20 64 61 74 61 62 61  e creates databa
12a0: 73 65 73 0a 2a 2a 20 77 69 74 68 20 70 61 67 65  ses.** with page
12b0: 20 73 69 7a 65 20 53 51 4c 49 54 45 5f 44 45 46   size SQLITE_DEF
12c0: 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45 2e 20  AULT_PAGE_SIZE. 
12d0: 48 6f 77 65 76 65 72 2c 20 62 61 73 65 64 20 6f  However, based o
12e0: 6e 20 63 65 72 74 61 69 6e 0a 2a 2a 20 64 65 76  n certain.** dev
12f0: 69 63 65 20 63 68 61 72 61 63 74 65 72 69 73 74  ice characterist
1300: 69 63 73 20 28 73 65 63 74 6f 72 2d 73 69 7a 65  ics (sector-size
1310: 20 61 6e 64 20 61 74 6f 6d 69 63 20 77 72 69 74   and atomic writ
1320: 65 28 29 20 73 75 70 70 6f 72 74 29 2c 0a 2a 2a  e() support),.**
1330: 20 53 51 4c 69 74 65 20 6d 61 79 20 63 68 6f 6f   SQLite may choo
1340: 73 65 20 61 20 6c 61 72 67 65 72 20 76 61 6c 75  se a larger valu
1350: 65 2e 20 54 68 69 73 20 63 6f 6e 73 74 61 6e 74  e. This constant
1360: 20 69 73 20 74 68 65 20 6d 61 78 69 6d 75 6d 20   is the maximum 
1370: 76 61 6c 75 65 0a 2a 2a 20 53 51 4c 69 74 65 20  value.** SQLite 
1380: 77 69 6c 6c 20 63 68 6f 6f 73 65 20 6f 6e 20 69  will choose on i
1390: 74 73 20 6f 77 6e 2e 0a 2a 2f 0a 23 69 66 6e 64  ts own..*/.#ifnd
13a0: 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 44 45  ef SQLITE_MAX_DE
13b0: 46 41 55 4c 54 5f 50 41 47 45 5f 53 49 5a 45 0a  FAULT_PAGE_SIZE.
13c0: 23 20 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f  # define SQLITE_
13d0: 4d 41 58 5f 44 45 46 41 55 4c 54 5f 50 41 47 45  MAX_DEFAULT_PAGE
13e0: 5f 53 49 5a 45 20 38 31 39 32 0a 23 65 6e 64 69  _SIZE 8192.#endi
13f0: 66 0a 23 69 66 20 53 51 4c 49 54 45 5f 4d 41 58  f.#if SQLITE_MAX
1400: 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49  _DEFAULT_PAGE_SI
1410: 5a 45 3e 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41  ZE>SQLITE_MAX_PA
1420: 47 45 5f 53 49 5a 45 0a 23 20 75 6e 64 65 66 20  GE_SIZE.# undef 
1430: 53 51 4c 49 54 45 5f 4d 41 58 5f 44 45 46 41 55  SQLITE_MAX_DEFAU
1440: 4c 54 5f 50 41 47 45 5f 53 49 5a 45 0a 23 20 64  LT_PAGE_SIZE.# d
1450: 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58  efine SQLITE_MAX
1460: 5f 44 45 46 41 55 4c 54 5f 50 41 47 45 5f 53 49  _DEFAULT_PAGE_SI
1470: 5a 45 20 53 51 4c 49 54 45 5f 4d 41 58 5f 50 41  ZE SQLITE_MAX_PA
1480: 47 45 5f 53 49 5a 45 0a 23 65 6e 64 69 66 0a 0a  GE_SIZE.#endif..
1490: 0a 2f 2a 0a 2a 2a 20 4d 61 78 69 6d 75 6d 20 6e  ./*.** Maximum n
14a0: 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20 69  umber of pages i
14b0: 6e 20 6f 6e 65 20 64 61 74 61 62 61 73 65 20 66  n one database f
14c0: 69 6c 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  ile..**.** This 
14d0: 69 73 20 72 65 61 6c 6c 79 20 6a 75 73 74 20 74  is really just t
14e0: 68 65 20 64 65 66 61 75 6c 74 20 76 61 6c 75 65  he default value
14f0: 20 66 6f 72 20 74 68 65 20 6d 61 78 5f 70 61 67   for the max_pag
1500: 65 5f 63 6f 75 6e 74 20 70 72 61 67 6d 61 2e 0a  e_count pragma..
1510: 2a 2a 20 54 68 69 73 20 76 61 6c 75 65 20 63 61  ** This value ca
1520: 6e 20 62 65 20 6c 6f 77 65 72 65 64 20 28 6f 72  n be lowered (or
1530: 20 72 61 69 73 65 64 29 20 61 74 20 72 75 6e 2d   raised) at run-
1540: 74 69 6d 65 20 75 73 69 6e 67 20 74 68 61 74 20  time using that 
1550: 74 68 65 0a 2a 2a 20 6d 61 78 5f 70 61 67 65 5f  the.** max_page_
1560: 63 6f 75 6e 74 20 6d 61 63 72 6f 2e 0a 2a 2f 0a  count macro..*/.
1570: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d  #ifndef SQLITE_M
1580: 41 58 5f 50 41 47 45 5f 43 4f 55 4e 54 0a 23 20  AX_PAGE_COUNT.# 
1590: 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41  define SQLITE_MA
15a0: 58 5f 50 41 47 45 5f 43 4f 55 4e 54 20 31 30 37  X_PAGE_COUNT 107
15b0: 33 37 34 31 38 32 33 0a 23 65 6e 64 69 66 0a 0a  3741823.#endif..
15c0: 2f 2a 0a 2a 2a 20 4d 61 78 69 6d 75 6d 20 6c 65  /*.** Maximum le
15d0: 6e 67 74 68 20 28 69 6e 20 62 79 74 65 73 29 20  ngth (in bytes) 
15e0: 6f 66 20 74 68 65 20 70 61 74 74 65 72 6e 20 69  of the pattern i
15f0: 6e 20 61 20 4c 49 4b 45 20 6f 72 20 47 4c 4f 42  n a LIKE or GLOB
1600: 0a 2a 2a 20 6f 70 65 72 61 74 6f 72 2e 0a 2a 2f  .** operator..*/
1610: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
1620: 4d 41 58 5f 4c 49 4b 45 5f 50 41 54 54 45 52 4e  MAX_LIKE_PATTERN
1630: 5f 4c 45 4e 47 54 48 0a 23 20 64 65 66 69 6e 65  _LENGTH.# define
1640: 20 53 51 4c 49 54 45 5f 4d 41 58 5f 4c 49 4b 45   SQLITE_MAX_LIKE
1650: 5f 50 41 54 54 45 52 4e 5f 4c 45 4e 47 54 48 20  _PATTERN_LENGTH 
1660: 35 30 30 30 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a  50000.#endif../*
1670: 0a 2a 2a 20 4d 61 78 69 6d 75 6d 20 64 65 70 74  .** Maximum dept
1680: 68 20 6f 66 20 72 65 63 75 72 73 69 6f 6e 20 66  h of recursion f
1690: 6f 72 20 74 72 69 67 67 65 72 73 2e 0a 2a 2a 0a  or triggers..**.
16a0: 2a 2a 20 41 20 76 61 6c 75 65 20 6f 66 20 31 20  ** A value of 1 
16b0: 6d 65 61 6e 73 20 74 68 61 74 20 61 20 74 72 69  means that a tri
16c0: 67 67 65 72 20 70 72 6f 67 72 61 6d 20 77 69 6c  gger program wil
16d0: 6c 20 6e 6f 74 20 62 65 20 61 62 6c 65 20 74 6f  l not be able to
16e0: 20 69 74 73 65 6c 66 0a 2a 2a 20 66 69 72 65 20   itself.** fire 
16f0: 61 6e 79 20 74 72 69 67 67 65 72 73 2e 20 41 20  any triggers. A 
1700: 76 61 6c 75 65 20 6f 66 20 30 20 6d 65 61 6e 73  value of 0 means
1710: 20 74 68 61 74 20 6e 6f 20 74 72 69 67 67 65 72   that no trigger
1720: 20 70 72 6f 67 72 61 6d 73 20 61 74 20 61 6c 6c   programs at all
1730: 20 0a 2a 2a 20 6d 61 79 20 62 65 20 65 78 65 63   .** may be exec
1740: 75 74 65 64 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66  uted..*/.#ifndef
1750: 20 53 51 4c 49 54 45 5f 4d 41 58 5f 54 52 49 47   SQLITE_MAX_TRIG
1760: 47 45 52 5f 44 45 50 54 48 0a 23 20 64 65 66 69  GER_DEPTH.# defi
1770: 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f 54 52  ne SQLITE_MAX_TR
1780: 49 47 47 45 52 5f 44 45 50 54 48 20 31 30 30 30  IGGER_DEPTH 1000
1790: 0a 23 65 6e 64 69 66 0a                          .#endif.