/ Hex Artifact Content
Login

Artifact 669cc22781c6461a273416ec1a7414d25c081730:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you give..**.***
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 2a  ****************
0170: 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 43 6f 64 65 20 66  ******.** Code f
0180: 6f 72 20 74 65 73 74 69 6e 67 20 74 68 65 20 70  or testing the p
0190: 61 67 65 72 2e 63 20 6d 6f 64 75 6c 65 20 69 6e  ager.c module in
01a0: 20 53 51 4c 69 74 65 2e 20 20 54 68 69 73 20 63   SQLite.  This c
01b0: 6f 64 65 0a 2a 2a 20 69 73 20 6e 6f 74 20 69 6e  ode.** is not in
01c0: 63 6c 75 64 65 64 20 69 6e 20 74 68 65 20 53 51  cluded in the SQ
01d0: 4c 69 74 65 20 6c 69 62 72 61 72 79 2e 20 20 49  Lite library.  I
01e0: 74 20 69 73 20 75 73 65 64 20 66 6f 72 20 61 75  t is used for au
01f0: 74 6f 6d 61 74 65 64 0a 2a 2a 20 74 65 73 74 69  tomated.** testi
0200: 6e 67 20 6f 66 20 74 68 65 20 53 51 4c 69 74 65  ng of the SQLite
0210: 20 6c 69 62 72 61 72 79 2e 0a 2a 2a 0a 2a 2a 20   library..**.** 
0220: 24 49 64 3a 20 74 65 73 74 32 2e 63 2c 76 20 31  $Id: test2.c,v 1
0230: 2e 38 20 32 30 30 32 2f 30 35 2f 31 30 20 30 35  .8 2002/05/10 05
0240: 3a 34 34 3a 35 36 20 64 72 68 20 45 78 70 20 24  :44:56 drh Exp $
0250: 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 73 71  .*/.#include "sq
0260: 6c 69 74 65 49 6e 74 2e 68 22 0a 23 69 6e 63 6c  liteInt.h".#incl
0270: 75 64 65 20 22 70 61 67 65 72 2e 68 22 0a 23 69  ude "pager.h".#i
0280: 6e 63 6c 75 64 65 20 22 74 63 6c 2e 68 22 0a 23  nclude "tcl.h".#
0290: 69 6e 63 6c 75 64 65 20 3c 73 74 64 6c 69 62 2e  include <stdlib.
02a0: 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 72  h>.#include <str
02b0: 69 6e 67 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20 49 6e  ing.h>../*.** In
02c0: 74 65 72 70 72 65 74 20 61 6e 20 53 51 4c 69 74  terpret an SQLit
02d0: 65 20 65 72 72 6f 72 20 6e 75 6d 62 65 72 0a 2a  e error number.*
02e0: 2f 0a 73 74 61 74 69 63 20 63 68 61 72 20 2a 65  /.static char *e
02f0: 72 72 6f 72 4e 61 6d 65 28 69 6e 74 20 72 63 29  rrorName(int rc)
0300: 7b 0a 20 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b  {.  char *zName;
0310: 0a 20 20 73 77 69 74 63 68 28 20 72 63 20 29 7b  .  switch( rc ){
0320: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
0330: 5f 4f 4b 3a 20 20 20 20 20 20 20 20 20 7a 4e 61  _OK:         zNa
0340: 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f 4f 4b 22  me = "SQLITE_OK"
0350: 3b 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b  ;          break
0360: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
0370: 45 5f 45 52 52 4f 52 3a 20 20 20 20 20 20 7a 4e  E_ERROR:      zN
0380: 61 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f 45 52  ame = "SQLITE_ER
0390: 52 4f 52 22 3b 20 20 20 20 20 20 20 62 72 65 61  ROR";       brea
03a0: 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49  k;.    case SQLI
03b0: 54 45 5f 49 4e 54 45 52 4e 41 4c 3a 20 20 20 7a  TE_INTERNAL:   z
03c0: 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f 49  Name = "SQLITE_I
03d0: 4e 54 45 52 4e 41 4c 22 3b 20 20 20 20 62 72 65  NTERNAL";    bre
03e0: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c  ak;.    case SQL
03f0: 49 54 45 5f 50 45 52 4d 3a 20 20 20 20 20 20 20  ITE_PERM:       
0400: 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f  zName = "SQLITE_
0410: 50 45 52 4d 22 3b 20 20 20 20 20 20 20 20 62 72  PERM";        br
0420: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51  eak;.    case SQ
0430: 4c 49 54 45 5f 41 42 4f 52 54 3a 20 20 20 20 20  LITE_ABORT:     
0440: 20 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54 45   zName = "SQLITE
0450: 5f 41 42 4f 52 54 22 3b 20 20 20 20 20 20 20 62  _ABORT";       b
0460: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
0470: 51 4c 49 54 45 5f 42 55 53 59 3a 20 20 20 20 20  QLITE_BUSY:     
0480: 20 20 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54    zName = "SQLIT
0490: 45 5f 42 55 53 59 22 3b 20 20 20 20 20 20 20 20  E_BUSY";        
04a0: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
04b0: 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3a 20 20 20  SQLITE_NOMEM:   
04c0: 20 20 20 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49     zName = "SQLI
04d0: 54 45 5f 4e 4f 4d 45 4d 22 3b 20 20 20 20 20 20  TE_NOMEM";      
04e0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
04f0: 20 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c 59   SQLITE_READONLY
0500: 3a 20 20 20 7a 4e 61 6d 65 20 3d 20 22 53 51 4c  :   zName = "SQL
0510: 49 54 45 5f 52 45 41 44 4f 4e 4c 59 22 3b 20 20  ITE_READONLY";  
0520: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
0530: 65 20 53 51 4c 49 54 45 5f 49 4e 54 45 52 52 55  e SQLITE_INTERRU
0540: 50 54 3a 20 20 7a 4e 61 6d 65 20 3d 20 22 53 51  PT:  zName = "SQ
0550: 4c 49 54 45 5f 49 4e 54 45 52 52 55 50 54 22 3b  LITE_INTERRUPT";
0560: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
0570: 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 3a  se SQLITE_IOERR:
0580: 20 20 20 20 20 20 7a 4e 61 6d 65 20 3d 20 22 53        zName = "S
0590: 51 4c 49 54 45 5f 49 4f 45 52 52 22 3b 20 20 20  QLITE_IOERR";   
05a0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
05b0: 61 73 65 20 53 51 4c 49 54 45 5f 43 4f 52 52 55  ase SQLITE_CORRU
05c0: 50 54 3a 20 20 20 20 7a 4e 61 6d 65 20 3d 20 22  PT:    zName = "
05d0: 53 51 4c 49 54 45 5f 43 4f 52 52 55 50 54 22 3b  SQLITE_CORRUPT";
05e0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
05f0: 63 61 73 65 20 53 51 4c 49 54 45 5f 4e 4f 54 46  case SQLITE_NOTF
0600: 4f 55 4e 44 3a 20 20 20 7a 4e 61 6d 65 20 3d 20  OUND:   zName = 
0610: 22 53 51 4c 49 54 45 5f 4e 4f 54 46 4f 55 4e 44  "SQLITE_NOTFOUND
0620: 22 3b 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20  ";    break;.   
0630: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46 55 4c   case SQLITE_FUL
0640: 4c 3a 20 20 20 20 20 20 20 7a 4e 61 6d 65 20 3d  L:       zName =
0650: 20 22 53 51 4c 49 54 45 5f 46 55 4c 4c 22 3b 20   "SQLITE_FULL"; 
0660: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
0670: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 43 41    case SQLITE_CA
0680: 4e 54 4f 50 45 4e 3a 20 20 20 7a 4e 61 6d 65 20  NTOPEN:   zName 
0690: 3d 20 22 53 51 4c 49 54 45 5f 43 41 4e 54 4f 50  = "SQLITE_CANTOP
06a0: 45 4e 22 3b 20 20 20 20 62 72 65 61 6b 3b 0a 20  EN";    break;. 
06b0: 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 50     case SQLITE_P
06c0: 52 4f 54 4f 43 4f 4c 3a 20 20 20 7a 4e 61 6d 65  ROTOCOL:   zName
06d0: 20 3d 20 22 53 51 4c 49 54 45 5f 50 52 4f 54 4f   = "SQLITE_PROTO
06e0: 43 4f 4c 22 3b 20 20 20 20 62 72 65 61 6b 3b 0a  COL";    break;.
06f0: 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f      case SQLITE_
0700: 45 4d 50 54 59 3a 20 20 20 20 20 20 7a 4e 61 6d  EMPTY:      zNam
0710: 65 20 3d 20 22 53 51 4c 49 54 45 5f 45 4d 50 54  e = "SQLITE_EMPT
0720: 59 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b 3b  Y";       break;
0730: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
0740: 5f 53 43 48 45 4d 41 3a 20 20 20 20 20 7a 4e 61  _SCHEMA:     zNa
0750: 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f 53 43 48  me = "SQLITE_SCH
0760: 45 4d 41 22 3b 20 20 20 20 20 20 62 72 65 61 6b  EMA";      break
0770: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
0780: 45 5f 54 4f 4f 42 49 47 3a 20 20 20 20 20 7a 4e  E_TOOBIG:     zN
0790: 61 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f 54 4f  ame = "SQLITE_TO
07a0: 4f 42 49 47 22 3b 20 20 20 20 20 20 62 72 65 61  OBIG";      brea
07b0: 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49  k;.    case SQLI
07c0: 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54 3a 20 7a  TE_CONSTRAINT: z
07d0: 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f 43  Name = "SQLITE_C
07e0: 4f 4e 53 54 52 41 49 4e 54 22 3b 20 20 62 72 65  ONSTRAINT";  bre
07f0: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c  ak;.    case SQL
0800: 49 54 45 5f 4d 49 53 4d 41 54 43 48 3a 20 20 20  ITE_MISMATCH:   
0810: 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54 45 5f  zName = "SQLITE_
0820: 4d 49 53 4d 41 54 43 48 22 3b 20 20 20 20 62 72  MISMATCH";    br
0830: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51  eak;.    case SQ
0840: 4c 49 54 45 5f 4d 49 53 55 53 45 3a 20 20 20 20  LITE_MISUSE:    
0850: 20 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54 45   zName = "SQLITE
0860: 5f 4d 49 53 55 53 45 22 3b 20 20 20 20 20 20 62  _MISUSE";      b
0870: 72 65 61 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c  reak;.    defaul
0880: 74 3a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t:              
0890: 20 20 7a 4e 61 6d 65 20 3d 20 22 53 51 4c 49 54    zName = "SQLIT
08a0: 45 5f 55 6e 6b 6e 6f 77 6e 22 3b 20 20 20 20 20  E_Unknown";     
08b0: 62 72 65 61 6b 3b 0a 20 20 7d 0a 20 20 72 65 74  break;.  }.  ret
08c0: 75 72 6e 20 7a 4e 61 6d 65 3b 0a 7d 0a 0a 2f 2a  urn zName;.}../*
08d0: 0a 2a 2a 20 55 73 61 67 65 3a 20 20 20 70 61 67  .** Usage:   pag
08e0: 65 72 5f 6f 70 65 6e 20 46 49 4c 45 4e 41 4d 45  er_open FILENAME
08f0: 20 4e 2d 50 41 47 45 0a 2a 2a 0a 2a 2a 20 4f 70   N-PAGE.**.** Op
0900: 65 6e 20 61 20 6e 65 77 20 70 61 67 65 72 0a 2a  en a new pager.*
0910: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 70 61 67  /.static int pag
0920: 65 72 5f 6f 70 65 6e 28 0a 20 20 76 6f 69 64 20  er_open(.  void 
0930: 2a 4e 6f 74 55 73 65 64 2c 0a 20 20 54 63 6c 5f  *NotUsed,.  Tcl_
0940: 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20  Interp *interp, 
0950: 20 20 20 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e     /* The TCL in
0960: 74 65 72 70 72 65 74 65 72 20 74 68 61 74 20 69  terpreter that i
0970: 6e 76 6f 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d  nvoked this comm
0980: 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 61 72 67  and */.  int arg
0990: 63 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c,              
09a0: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67  /* Number of arg
09b0: 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 63 68 61 72  uments */.  char
09c0: 20 2a 2a 61 72 67 76 20 20 20 20 20 20 20 20 20   **argv         
09d0: 20 20 20 2f 2a 20 54 65 78 74 20 6f 66 20 65 61     /* Text of ea
09e0: 63 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f 0a 29  ch argument */.)
09f0: 7b 0a 20 20 50 61 67 65 72 20 2a 70 50 61 67 65  {.  Pager *pPage
0a00: 72 3b 0a 20 20 69 6e 74 20 6e 50 61 67 65 3b 0a  r;.  int nPage;.
0a10: 20 20 69 6e 74 20 72 63 3b 0a 20 20 63 68 61 72    int rc;.  char
0a20: 20 7a 42 75 66 5b 31 30 30 5d 3b 0a 20 20 69 66   zBuf[100];.  if
0a30: 28 20 61 72 67 63 21 3d 33 20 29 7b 0a 20 20 20  ( argc!=3 ){.   
0a40: 20 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c   Tcl_AppendResul
0a50: 74 28 69 6e 74 65 72 70 2c 20 22 77 72 6f 6e 67  t(interp, "wrong
0a60: 20 23 20 61 72 67 73 3a 20 73 68 6f 75 6c 64 20   # args: should 
0a70: 62 65 20 5c 22 22 2c 20 61 72 67 76 5b 30 5d 2c  be \"", argv[0],
0a80: 0a 20 20 20 20 20 20 20 22 20 46 49 4c 45 4e 41  .       " FILENA
0a90: 4d 45 20 4e 2d 50 41 47 45 5c 22 22 2c 20 30 29  ME N-PAGE\"", 0)
0aa0: 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c  ;.    return TCL
0ab0: 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 69 66  _ERROR;.  }.  if
0ac0: 28 20 54 63 6c 5f 47 65 74 49 6e 74 28 69 6e 74  ( Tcl_GetInt(int
0ad0: 65 72 70 2c 20 61 72 67 76 5b 32 5d 2c 20 26 6e  erp, argv[2], &n
0ae0: 50 61 67 65 29 20 29 20 72 65 74 75 72 6e 20 54  Page) ) return T
0af0: 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 72 63 20 3d  CL_ERROR;.  rc =
0b00: 20 73 71 6c 69 74 65 70 61 67 65 72 5f 6f 70 65   sqlitepager_ope
0b10: 6e 28 26 70 50 61 67 65 72 2c 20 61 72 67 76 5b  n(&pPager, argv[
0b20: 31 5d 2c 20 6e 50 61 67 65 2c 20 30 29 3b 0a 20  1], nPage, 0);. 
0b30: 20 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f   if( rc!=SQLITE_
0b40: 4f 4b 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70  OK ){.    Tcl_Ap
0b50: 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72  pendResult(inter
0b60: 70 2c 20 65 72 72 6f 72 4e 61 6d 65 28 72 63 29  p, errorName(rc)
0b70: 2c 20 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e  , 0);.    return
0b80: 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a   TCL_ERROR;.  }.
0b90: 20 20 73 70 72 69 6e 74 66 28 7a 42 75 66 2c 22    sprintf(zBuf,"
0ba0: 30 78 25 78 22 2c 28 69 6e 74 29 70 50 61 67 65  0x%x",(int)pPage
0bb0: 72 29 3b 0a 20 20 54 63 6c 5f 41 70 70 65 6e 64  r);.  Tcl_Append
0bc0: 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 7a  Result(interp, z
0bd0: 42 75 66 2c 20 30 29 3b 0a 20 20 72 65 74 75 72  Buf, 0);.  retur
0be0: 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a  n TCL_OK;.}../*.
0bf0: 2a 2a 20 55 73 61 67 65 3a 20 20 20 70 61 67 65  ** Usage:   page
0c00: 72 5f 63 6c 6f 73 65 20 49 44 0a 2a 2a 0a 2a 2a  r_close ID.**.**
0c10: 20 43 6c 6f 73 65 20 74 68 65 20 67 69 76 65 6e   Close the given
0c20: 20 70 61 67 65 72 2e 0a 2a 2f 0a 73 74 61 74 69   pager..*/.stati
0c30: 63 20 69 6e 74 20 70 61 67 65 72 5f 63 6c 6f 73  c int pager_clos
0c40: 65 28 0a 20 20 76 6f 69 64 20 2a 4e 6f 74 55 73  e(.  void *NotUs
0c50: 65 64 2c 0a 20 20 54 63 6c 5f 49 6e 74 65 72 70  ed,.  Tcl_Interp
0c60: 20 2a 69 6e 74 65 72 70 2c 20 20 20 20 2f 2a 20   *interp,    /* 
0c70: 54 68 65 20 54 43 4c 20 69 6e 74 65 72 70 72 65  The TCL interpre
0c80: 74 65 72 20 74 68 61 74 20 69 6e 76 6f 6b 65 64  ter that invoked
0c90: 20 74 68 69 73 20 63 6f 6d 6d 61 6e 64 20 2a 2f   this command */
0ca0: 0a 20 20 69 6e 74 20 61 72 67 63 2c 20 20 20 20  .  int argc,    
0cb0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d            /* Num
0cc0: 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73  ber of arguments
0cd0: 20 2a 2f 0a 20 20 63 68 61 72 20 2a 2a 61 72 67   */.  char **arg
0ce0: 76 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  v            /* 
0cf0: 54 65 78 74 20 6f 66 20 65 61 63 68 20 61 72 67  Text of each arg
0d00: 75 6d 65 6e 74 20 2a 2f 0a 29 7b 0a 20 20 50 61  ument */.){.  Pa
0d10: 67 65 72 20 2a 70 50 61 67 65 72 3b 0a 20 20 69  ger *pPager;.  i
0d20: 6e 74 20 72 63 3b 0a 20 20 69 66 28 20 61 72 67  nt rc;.  if( arg
0d30: 63 21 3d 32 20 29 7b 0a 20 20 20 20 54 63 6c 5f  c!=2 ){.    Tcl_
0d40: 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74  AppendResult(int
0d50: 65 72 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72  erp, "wrong # ar
0d60: 67 73 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22  gs: should be \"
0d70: 22 2c 20 61 72 67 76 5b 30 5d 2c 0a 20 20 20 20  ", argv[0],.    
0d80: 20 20 20 22 20 49 44 5c 22 22 2c 20 30 29 3b 0a     " ID\"", 0);.
0d90: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 45      return TCL_E
0da0: 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 69 66 28 20  RROR;.  }.  if( 
0db0: 54 63 6c 5f 47 65 74 49 6e 74 28 69 6e 74 65 72  Tcl_GetInt(inter
0dc0: 70 2c 20 61 72 67 76 5b 31 5d 2c 20 28 69 6e 74  p, argv[1], (int
0dd0: 2a 29 26 70 50 61 67 65 72 29 20 29 20 72 65 74  *)&pPager) ) ret
0de0: 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20  urn TCL_ERROR;. 
0df0: 20 72 63 20 3d 20 73 71 6c 69 74 65 70 61 67 65   rc = sqlitepage
0e00: 72 5f 63 6c 6f 73 65 28 70 50 61 67 65 72 29 3b  r_close(pPager);
0e10: 0a 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49 54  .  if( rc!=SQLIT
0e20: 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 54 63 6c 5f  E_OK ){.    Tcl_
0e30: 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74  AppendResult(int
0e40: 65 72 70 2c 20 65 72 72 6f 72 4e 61 6d 65 28 72  erp, errorName(r
0e50: 63 29 2c 20 30 29 3b 0a 20 20 20 20 72 65 74 75  c), 0);.    retu
0e60: 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20  rn TCL_ERROR;.  
0e70: 7d 0a 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f  }.  return TCL_O
0e80: 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55 73 61 67  K;.}../*.** Usag
0e90: 65 3a 20 20 20 70 61 67 65 72 5f 72 6f 6c 6c 62  e:   pager_rollb
0ea0: 61 63 6b 20 49 44 0a 2a 2a 0a 2a 2a 20 52 6f 6c  ack ID.**.** Rol
0eb0: 6c 62 61 63 6b 20 63 68 61 6e 67 65 73 0a 2a 2f  lback changes.*/
0ec0: 0a 73 74 61 74 69 63 20 69 6e 74 20 70 61 67 65  .static int page
0ed0: 72 5f 72 6f 6c 6c 62 61 63 6b 28 0a 20 20 76 6f  r_rollback(.  vo
0ee0: 69 64 20 2a 4e 6f 74 55 73 65 64 2c 0a 20 20 54  id *NotUsed,.  T
0ef0: 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72  cl_Interp *inter
0f00: 70 2c 20 20 20 20 2f 2a 20 54 68 65 20 54 43 4c  p,    /* The TCL
0f10: 20 69 6e 74 65 72 70 72 65 74 65 72 20 74 68 61   interpreter tha
0f20: 74 20 69 6e 76 6f 6b 65 64 20 74 68 69 73 20 63  t invoked this c
0f30: 6f 6d 6d 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20  ommand */.  int 
0f40: 61 72 67 63 2c 20 20 20 20 20 20 20 20 20 20 20  argc,           
0f50: 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20     /* Number of 
0f60: 61 72 67 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 63  arguments */.  c
0f70: 68 61 72 20 2a 2a 61 72 67 76 20 20 20 20 20 20  har **argv      
0f80: 20 20 20 20 20 20 2f 2a 20 54 65 78 74 20 6f 66        /* Text of
0f90: 20 65 61 63 68 20 61 72 67 75 6d 65 6e 74 20 2a   each argument *
0fa0: 2f 0a 29 7b 0a 20 20 50 61 67 65 72 20 2a 70 50  /.){.  Pager *pP
0fb0: 61 67 65 72 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  ager;.  int rc;.
0fc0: 20 20 69 66 28 20 61 72 67 63 21 3d 32 20 29 7b    if( argc!=2 ){
0fd0: 0a 20 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52  .    Tcl_AppendR
0fe0: 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 77  esult(interp, "w
0ff0: 72 6f 6e 67 20 23 20 61 72 67 73 3a 20 73 68 6f  rong # args: sho
1000: 75 6c 64 20 62 65 20 5c 22 22 2c 20 61 72 67 76  uld be \"", argv
1010: 5b 30 5d 2c 0a 20 20 20 20 20 20 20 22 20 49 44  [0],.       " ID
1020: 5c 22 22 2c 20 30 29 3b 0a 20 20 20 20 72 65 74  \"", 0);.    ret
1030: 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20  urn TCL_ERROR;. 
1040: 20 7d 0a 20 20 69 66 28 20 54 63 6c 5f 47 65 74   }.  if( Tcl_Get
1050: 49 6e 74 28 69 6e 74 65 72 70 2c 20 61 72 67 76  Int(interp, argv
1060: 5b 31 5d 2c 20 28 69 6e 74 2a 29 26 70 50 61 67  [1], (int*)&pPag
1070: 65 72 29 20 29 20 72 65 74 75 72 6e 20 54 43 4c  er) ) return TCL
1080: 5f 45 52 52 4f 52 3b 0a 20 20 72 63 20 3d 20 73  _ERROR;.  rc = s
1090: 71 6c 69 74 65 70 61 67 65 72 5f 72 6f 6c 6c 62  qlitepager_rollb
10a0: 61 63 6b 28 70 50 61 67 65 72 29 3b 0a 20 20 69  ack(pPager);.  i
10b0: 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc!=SQLITE_OK
10c0: 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70 65   ){.    Tcl_Appe
10d0: 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c  ndResult(interp,
10e0: 20 65 72 72 6f 72 4e 61 6d 65 28 72 63 29 2c 20   errorName(rc), 
10f0: 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54  0);.    return T
1100: 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20  CL_ERROR;.  }.  
1110: 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d  return TCL_OK;.}
1120: 0a 0a 2f 2a 0a 2a 2a 20 55 73 61 67 65 3a 20 20  ../*.** Usage:  
1130: 20 70 61 67 65 72 5f 63 6f 6d 6d 69 74 20 49 44   pager_commit ID
1140: 0a 2a 2a 0a 2a 2a 20 43 6f 6d 6d 69 74 20 61 6c  .**.** Commit al
1150: 6c 20 63 68 61 6e 67 65 73 0a 2a 2f 0a 73 74 61  l changes.*/.sta
1160: 74 69 63 20 69 6e 74 20 70 61 67 65 72 5f 63 6f  tic int pager_co
1170: 6d 6d 69 74 28 0a 20 20 76 6f 69 64 20 2a 4e 6f  mmit(.  void *No
1180: 74 55 73 65 64 2c 0a 20 20 54 63 6c 5f 49 6e 74  tUsed,.  Tcl_Int
1190: 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 20 20 20  erp *interp,    
11a0: 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e 74 65 72  /* The TCL inter
11b0: 70 72 65 74 65 72 20 74 68 61 74 20 69 6e 76 6f  preter that invo
11c0: 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d 61 6e 64  ked this command
11d0: 20 2a 2f 0a 20 20 69 6e 74 20 61 72 67 63 2c 20   */.  int argc, 
11e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
11f0: 4e 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d 65  Number of argume
1200: 6e 74 73 20 2a 2f 0a 20 20 63 68 61 72 20 2a 2a  nts */.  char **
1210: 61 72 67 76 20 20 20 20 20 20 20 20 20 20 20 20  argv            
1220: 2f 2a 20 54 65 78 74 20 6f 66 20 65 61 63 68 20  /* Text of each 
1230: 61 72 67 75 6d 65 6e 74 20 2a 2f 0a 29 7b 0a 20  argument */.){. 
1240: 20 50 61 67 65 72 20 2a 70 50 61 67 65 72 3b 0a   Pager *pPager;.
1250: 20 20 69 6e 74 20 72 63 3b 0a 20 20 69 66 28 20    int rc;.  if( 
1260: 61 72 67 63 21 3d 32 20 29 7b 0a 20 20 20 20 54  argc!=2 ){.    T
1270: 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c 74 28  cl_AppendResult(
1280: 69 6e 74 65 72 70 2c 20 22 77 72 6f 6e 67 20 23  interp, "wrong #
1290: 20 61 72 67 73 3a 20 73 68 6f 75 6c 64 20 62 65   args: should be
12a0: 20 5c 22 22 2c 20 61 72 67 76 5b 30 5d 2c 0a 20   \"", argv[0],. 
12b0: 20 20 20 20 20 20 22 20 49 44 5c 22 22 2c 20 30        " ID\"", 0
12c0: 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54 43  );.    return TC
12d0: 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 69  L_ERROR;.  }.  i
12e0: 66 28 20 54 63 6c 5f 47 65 74 49 6e 74 28 69 6e  f( Tcl_GetInt(in
12f0: 74 65 72 70 2c 20 61 72 67 76 5b 31 5d 2c 20 28  terp, argv[1], (
1300: 69 6e 74 2a 29 26 70 50 61 67 65 72 29 20 29 20  int*)&pPager) ) 
1310: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52  return TCL_ERROR
1320: 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 70  ;.  rc = sqlitep
1330: 61 67 65 72 5f 63 6f 6d 6d 69 74 28 70 50 61 67  ager_commit(pPag
1340: 65 72 29 3b 0a 20 20 69 66 28 20 72 63 21 3d 53  er);.  if( rc!=S
1350: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
1360: 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c 74  Tcl_AppendResult
1370: 28 69 6e 74 65 72 70 2c 20 65 72 72 6f 72 4e 61  (interp, errorNa
1380: 6d 65 28 72 63 29 2c 20 30 29 3b 0a 20 20 20 20  me(rc), 0);.    
1390: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52  return TCL_ERROR
13a0: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 54  ;.  }.  return T
13b0: 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  CL_OK;.}../*.** 
13c0: 55 73 61 67 65 3a 20 20 20 70 61 67 65 72 5f 63  Usage:   pager_c
13d0: 6b 70 74 5f 62 65 67 69 6e 20 49 44 0a 2a 2a 0a  kpt_begin ID.**.
13e0: 2a 2a 20 53 74 61 72 74 20 61 20 6e 65 77 20 63  ** Start a new c
13f0: 68 65 63 6b 70 6f 69 6e 74 2e 0a 2a 2f 0a 73 74  heckpoint..*/.st
1400: 61 74 69 63 20 69 6e 74 20 70 61 67 65 72 5f 63  atic int pager_c
1410: 6b 70 74 5f 62 65 67 69 6e 28 0a 20 20 76 6f 69  kpt_begin(.  voi
1420: 64 20 2a 4e 6f 74 55 73 65 64 2c 0a 20 20 54 63  d *NotUsed,.  Tc
1430: 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 70  l_Interp *interp
1440: 2c 20 20 20 20 2f 2a 20 54 68 65 20 54 43 4c 20  ,    /* The TCL 
1450: 69 6e 74 65 72 70 72 65 74 65 72 20 74 68 61 74  interpreter that
1460: 20 69 6e 76 6f 6b 65 64 20 74 68 69 73 20 63 6f   invoked this co
1470: 6d 6d 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 61  mmand */.  int a
1480: 72 67 63 2c 20 20 20 20 20 20 20 20 20 20 20 20  rgc,            
1490: 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61    /* Number of a
14a0: 72 67 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 63 68  rguments */.  ch
14b0: 61 72 20 2a 2a 61 72 67 76 20 20 20 20 20 20 20  ar **argv       
14c0: 20 20 20 20 20 2f 2a 20 54 65 78 74 20 6f 66 20       /* Text of 
14d0: 65 61 63 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f  each argument */
14e0: 0a 29 7b 0a 20 20 50 61 67 65 72 20 2a 70 50 61  .){.  Pager *pPa
14f0: 67 65 72 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20  ger;.  int rc;. 
1500: 20 69 66 28 20 61 72 67 63 21 3d 32 20 29 7b 0a   if( argc!=2 ){.
1510: 20 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65      Tcl_AppendRe
1520: 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 77 72  sult(interp, "wr
1530: 6f 6e 67 20 23 20 61 72 67 73 3a 20 73 68 6f 75  ong # args: shou
1540: 6c 64 20 62 65 20 5c 22 22 2c 20 61 72 67 76 5b  ld be \"", argv[
1550: 30 5d 2c 0a 20 20 20 20 20 20 20 22 20 49 44 5c  0],.       " ID\
1560: 22 22 2c 20 30 29 3b 0a 20 20 20 20 72 65 74 75  "", 0);.    retu
1570: 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20  rn TCL_ERROR;.  
1580: 7d 0a 20 20 69 66 28 20 54 63 6c 5f 47 65 74 49  }.  if( Tcl_GetI
1590: 6e 74 28 69 6e 74 65 72 70 2c 20 61 72 67 76 5b  nt(interp, argv[
15a0: 31 5d 2c 20 28 69 6e 74 2a 29 26 70 50 61 67 65  1], (int*)&pPage
15b0: 72 29 20 29 20 72 65 74 75 72 6e 20 54 43 4c 5f  r) ) return TCL_
15c0: 45 52 52 4f 52 3b 0a 20 20 72 63 20 3d 20 73 71  ERROR;.  rc = sq
15d0: 6c 69 74 65 70 61 67 65 72 5f 63 6b 70 74 5f 62  litepager_ckpt_b
15e0: 65 67 69 6e 28 70 50 61 67 65 72 29 3b 0a 20 20  egin(pPager);.  
15f0: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f  if( rc!=SQLITE_O
1600: 4b 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70  K ){.    Tcl_App
1610: 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70  endResult(interp
1620: 2c 20 65 72 72 6f 72 4e 61 6d 65 28 72 63 29 2c  , errorName(rc),
1630: 20 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20   0);.    return 
1640: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20  TCL_ERROR;.  }. 
1650: 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a   return TCL_OK;.
1660: 7d 0a 0a 2f 2a 0a 2a 2a 20 55 73 61 67 65 3a 20  }../*.** Usage: 
1670: 20 20 70 61 67 65 72 5f 63 6b 70 74 5f 72 6f 6c    pager_ckpt_rol
1680: 6c 62 61 63 6b 20 49 44 0a 2a 2a 0a 2a 2a 20 52  lback ID.**.** R
1690: 6f 6c 6c 62 61 63 6b 20 63 68 61 6e 67 65 73 20  ollback changes 
16a0: 74 6f 20 61 20 63 68 65 63 6b 70 6f 69 6e 74 0a  to a checkpoint.
16b0: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 70 61  */.static int pa
16c0: 67 65 72 5f 63 6b 70 74 5f 72 6f 6c 6c 62 61 63  ger_ckpt_rollbac
16d0: 6b 28 0a 20 20 76 6f 69 64 20 2a 4e 6f 74 55 73  k(.  void *NotUs
16e0: 65 64 2c 0a 20 20 54 63 6c 5f 49 6e 74 65 72 70  ed,.  Tcl_Interp
16f0: 20 2a 69 6e 74 65 72 70 2c 20 20 20 20 2f 2a 20   *interp,    /* 
1700: 54 68 65 20 54 43 4c 20 69 6e 74 65 72 70 72 65  The TCL interpre
1710: 74 65 72 20 74 68 61 74 20 69 6e 76 6f 6b 65 64  ter that invoked
1720: 20 74 68 69 73 20 63 6f 6d 6d 61 6e 64 20 2a 2f   this command */
1730: 0a 20 20 69 6e 74 20 61 72 67 63 2c 20 20 20 20  .  int argc,    
1740: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d            /* Num
1750: 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73  ber of arguments
1760: 20 2a 2f 0a 20 20 63 68 61 72 20 2a 2a 61 72 67   */.  char **arg
1770: 76 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  v            /* 
1780: 54 65 78 74 20 6f 66 20 65 61 63 68 20 61 72 67  Text of each arg
1790: 75 6d 65 6e 74 20 2a 2f 0a 29 7b 0a 20 20 50 61  ument */.){.  Pa
17a0: 67 65 72 20 2a 70 50 61 67 65 72 3b 0a 20 20 69  ger *pPager;.  i
17b0: 6e 74 20 72 63 3b 0a 20 20 69 66 28 20 61 72 67  nt rc;.  if( arg
17c0: 63 21 3d 32 20 29 7b 0a 20 20 20 20 54 63 6c 5f  c!=2 ){.    Tcl_
17d0: 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74  AppendResult(int
17e0: 65 72 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72  erp, "wrong # ar
17f0: 67 73 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22  gs: should be \"
1800: 22 2c 20 61 72 67 76 5b 30 5d 2c 0a 20 20 20 20  ", argv[0],.    
1810: 20 20 20 22 20 49 44 5c 22 22 2c 20 30 29 3b 0a     " ID\"", 0);.
1820: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 45      return TCL_E
1830: 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 69 66 28 20  RROR;.  }.  if( 
1840: 54 63 6c 5f 47 65 74 49 6e 74 28 69 6e 74 65 72  Tcl_GetInt(inter
1850: 70 2c 20 61 72 67 76 5b 31 5d 2c 20 28 69 6e 74  p, argv[1], (int
1860: 2a 29 26 70 50 61 67 65 72 29 20 29 20 72 65 74  *)&pPager) ) ret
1870: 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20  urn TCL_ERROR;. 
1880: 20 72 63 20 3d 20 73 71 6c 69 74 65 70 61 67 65   rc = sqlitepage
1890: 72 5f 63 6b 70 74 5f 72 6f 6c 6c 62 61 63 6b 28  r_ckpt_rollback(
18a0: 70 50 61 67 65 72 29 3b 0a 20 20 69 66 28 20 72  pPager);.  if( r
18b0: 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c!=SQLITE_OK ){.
18c0: 20 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65      Tcl_AppendRe
18d0: 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 65 72 72  sult(interp, err
18e0: 6f 72 4e 61 6d 65 28 72 63 29 2c 20 30 29 3b 0a  orName(rc), 0);.
18f0: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 45      return TCL_E
1900: 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 72 65 74 75  RROR;.  }.  retu
1910: 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a  rn TCL_OK;.}../*
1920: 0a 2a 2a 20 55 73 61 67 65 3a 20 20 20 70 61 67  .** Usage:   pag
1930: 65 72 5f 63 6b 70 74 5f 63 6f 6d 6d 69 74 20 49  er_ckpt_commit I
1940: 44 0a 2a 2a 0a 2a 2a 20 43 6f 6d 6d 69 74 20 63  D.**.** Commit c
1950: 68 61 6e 67 65 73 20 74 6f 20 61 20 63 68 65 63  hanges to a chec
1960: 6b 70 6f 69 6e 74 0a 2a 2f 0a 73 74 61 74 69 63  kpoint.*/.static
1970: 20 69 6e 74 20 70 61 67 65 72 5f 63 6b 70 74 5f   int pager_ckpt_
1980: 63 6f 6d 6d 69 74 28 0a 20 20 76 6f 69 64 20 2a  commit(.  void *
1990: 4e 6f 74 55 73 65 64 2c 0a 20 20 54 63 6c 5f 49  NotUsed,.  Tcl_I
19a0: 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 20  nterp *interp,  
19b0: 20 20 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e 74    /* The TCL int
19c0: 65 72 70 72 65 74 65 72 20 74 68 61 74 20 69 6e  erpreter that in
19d0: 76 6f 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d 61  voked this comma
19e0: 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 61 72 67 63  nd */.  int argc
19f0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  ,              /
1a00: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67 75  * Number of argu
1a10: 6d 65 6e 74 73 20 2a 2f 0a 20 20 63 68 61 72 20  ments */.  char 
1a20: 2a 2a 61 72 67 76 20 20 20 20 20 20 20 20 20 20  **argv          
1a30: 20 20 2f 2a 20 54 65 78 74 20 6f 66 20 65 61 63    /* Text of eac
1a40: 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f 0a 29 7b  h argument */.){
1a50: 0a 20 20 50 61 67 65 72 20 2a 70 50 61 67 65 72  .  Pager *pPager
1a60: 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 69 66  ;.  int rc;.  if
1a70: 28 20 61 72 67 63 21 3d 32 20 29 7b 0a 20 20 20  ( argc!=2 ){.   
1a80: 20 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c   Tcl_AppendResul
1a90: 74 28 69 6e 74 65 72 70 2c 20 22 77 72 6f 6e 67  t(interp, "wrong
1aa0: 20 23 20 61 72 67 73 3a 20 73 68 6f 75 6c 64 20   # args: should 
1ab0: 62 65 20 5c 22 22 2c 20 61 72 67 76 5b 30 5d 2c  be \"", argv[0],
1ac0: 0a 20 20 20 20 20 20 20 22 20 49 44 5c 22 22 2c  .       " ID\"",
1ad0: 20 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20   0);.    return 
1ae0: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20  TCL_ERROR;.  }. 
1af0: 20 69 66 28 20 54 63 6c 5f 47 65 74 49 6e 74 28   if( Tcl_GetInt(
1b00: 69 6e 74 65 72 70 2c 20 61 72 67 76 5b 31 5d 2c  interp, argv[1],
1b10: 20 28 69 6e 74 2a 29 26 70 50 61 67 65 72 29 20   (int*)&pPager) 
1b20: 29 20 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52  ) return TCL_ERR
1b30: 4f 52 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74  OR;.  rc = sqlit
1b40: 65 70 61 67 65 72 5f 63 6b 70 74 5f 63 6f 6d 6d  epager_ckpt_comm
1b50: 69 74 28 70 50 61 67 65 72 29 3b 0a 20 20 69 66  it(pPager);.  if
1b60: 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc!=SQLITE_OK 
1b70: 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70 65 6e  ){.    Tcl_Appen
1b80: 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20  dResult(interp, 
1b90: 65 72 72 6f 72 4e 61 6d 65 28 72 63 29 2c 20 30  errorName(rc), 0
1ba0: 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54 43  );.    return TC
1bb0: 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 72  L_ERROR;.  }.  r
1bc0: 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a  eturn TCL_OK;.}.
1bd0: 0a 2f 2a 0a 2a 2a 20 55 73 61 67 65 3a 20 20 20  ./*.** Usage:   
1be0: 70 61 67 65 72 5f 73 74 61 74 73 20 49 44 0a 2a  pager_stats ID.*
1bf0: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 70 61 67 65  *.** Return page
1c00: 72 20 73 74 61 74 69 73 74 69 63 73 2e 0a 2a 2f  r statistics..*/
1c10: 0a 73 74 61 74 69 63 20 69 6e 74 20 70 61 67 65  .static int page
1c20: 72 5f 73 74 61 74 73 28 0a 20 20 76 6f 69 64 20  r_stats(.  void 
1c30: 2a 4e 6f 74 55 73 65 64 2c 0a 20 20 54 63 6c 5f  *NotUsed,.  Tcl_
1c40: 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20  Interp *interp, 
1c50: 20 20 20 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e     /* The TCL in
1c60: 74 65 72 70 72 65 74 65 72 20 74 68 61 74 20 69  terpreter that i
1c70: 6e 76 6f 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d  nvoked this comm
1c80: 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 61 72 67  and */.  int arg
1c90: 63 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c,              
1ca0: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67  /* Number of arg
1cb0: 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 63 68 61 72  uments */.  char
1cc0: 20 2a 2a 61 72 67 76 20 20 20 20 20 20 20 20 20   **argv         
1cd0: 20 20 20 2f 2a 20 54 65 78 74 20 6f 66 20 65 61     /* Text of ea
1ce0: 63 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f 0a 29  ch argument */.)
1cf0: 7b 0a 20 20 50 61 67 65 72 20 2a 70 50 61 67 65  {.  Pager *pPage
1d00: 72 3b 0a 20 20 69 6e 74 20 69 2c 20 2a 61 3b 0a  r;.  int i, *a;.
1d10: 20 20 69 66 28 20 61 72 67 63 21 3d 32 20 29 7b    if( argc!=2 ){
1d20: 0a 20 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52  .    Tcl_AppendR
1d30: 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 77  esult(interp, "w
1d40: 72 6f 6e 67 20 23 20 61 72 67 73 3a 20 73 68 6f  rong # args: sho
1d50: 75 6c 64 20 62 65 20 5c 22 22 2c 20 61 72 67 76  uld be \"", argv
1d60: 5b 30 5d 2c 0a 20 20 20 20 20 20 20 22 20 49 44  [0],.       " ID
1d70: 5c 22 22 2c 20 30 29 3b 0a 20 20 20 20 72 65 74  \"", 0);.    ret
1d80: 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20  urn TCL_ERROR;. 
1d90: 20 7d 0a 20 20 69 66 28 20 54 63 6c 5f 47 65 74   }.  if( Tcl_Get
1da0: 49 6e 74 28 69 6e 74 65 72 70 2c 20 61 72 67 76  Int(interp, argv
1db0: 5b 31 5d 2c 20 28 69 6e 74 2a 29 26 70 50 61 67  [1], (int*)&pPag
1dc0: 65 72 29 20 29 20 72 65 74 75 72 6e 20 54 43 4c  er) ) return TCL
1dd0: 5f 45 52 52 4f 52 3b 0a 20 20 61 20 3d 20 73 71  _ERROR;.  a = sq
1de0: 6c 69 74 65 70 61 67 65 72 5f 73 74 61 74 73 28  litepager_stats(
1df0: 70 50 61 67 65 72 29 3b 0a 20 20 66 6f 72 28 69  pPager);.  for(i
1e00: 3d 30 3b 20 69 3c 39 3b 20 69 2b 2b 29 7b 0a 20  =0; i<9; i++){. 
1e10: 20 20 20 73 74 61 74 69 63 20 63 68 61 72 20 2a     static char *
1e20: 7a 4e 61 6d 65 5b 5d 20 3d 20 7b 0a 20 20 20 20  zName[] = {.    
1e30: 20 20 22 72 65 66 22 2c 20 22 70 61 67 65 22 2c    "ref", "page",
1e40: 20 22 6d 61 78 22 2c 20 22 73 69 7a 65 22 2c 20   "max", "size", 
1e50: 22 73 74 61 74 65 22 2c 20 22 65 72 72 22 2c 0a  "state", "err",.
1e60: 20 20 20 20 20 20 22 68 69 74 22 2c 20 22 6d 69        "hit", "mi
1e70: 73 73 22 2c 20 22 6f 76 66 6c 22 2c 0a 20 20 20  ss", "ovfl",.   
1e80: 20 7d 3b 0a 20 20 20 20 63 68 61 72 20 7a 42 75   };.    char zBu
1e90: 66 5b 31 30 30 5d 3b 0a 20 20 20 20 54 63 6c 5f  f[100];.    Tcl_
1ea0: 41 70 70 65 6e 64 45 6c 65 6d 65 6e 74 28 69 6e  AppendElement(in
1eb0: 74 65 72 70 2c 20 7a 4e 61 6d 65 5b 69 5d 29 3b  terp, zName[i]);
1ec0: 0a 20 20 20 20 73 70 72 69 6e 74 66 28 7a 42 75  .    sprintf(zBu
1ed0: 66 2c 22 25 64 22 2c 61 5b 69 5d 29 3b 0a 20 20  f,"%d",a[i]);.  
1ee0: 20 20 54 63 6c 5f 41 70 70 65 6e 64 45 6c 65 6d    Tcl_AppendElem
1ef0: 65 6e 74 28 69 6e 74 65 72 70 2c 20 7a 42 75 66  ent(interp, zBuf
1f00: 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20  );.  }.  return 
1f10: 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  TCL_OK;.}../*.**
1f20: 20 55 73 61 67 65 3a 20 20 20 70 61 67 65 72 5f   Usage:   pager_
1f30: 70 61 67 65 63 6f 75 6e 74 20 49 44 0a 2a 2a 0a  pagecount ID.**.
1f40: 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 73 69  ** Return the si
1f50: 7a 65 20 6f 66 20 74 68 65 20 64 61 74 61 62 61  ze of the databa
1f60: 73 65 20 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74  se file..*/.stat
1f70: 69 63 20 69 6e 74 20 70 61 67 65 72 5f 70 61 67  ic int pager_pag
1f80: 65 63 6f 75 6e 74 28 0a 20 20 76 6f 69 64 20 2a  ecount(.  void *
1f90: 4e 6f 74 55 73 65 64 2c 0a 20 20 54 63 6c 5f 49  NotUsed,.  Tcl_I
1fa0: 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 20  nterp *interp,  
1fb0: 20 20 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e 74    /* The TCL int
1fc0: 65 72 70 72 65 74 65 72 20 74 68 61 74 20 69 6e  erpreter that in
1fd0: 76 6f 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d 61  voked this comma
1fe0: 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 61 72 67 63  nd */.  int argc
1ff0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  ,              /
2000: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67 75  * Number of argu
2010: 6d 65 6e 74 73 20 2a 2f 0a 20 20 63 68 61 72 20  ments */.  char 
2020: 2a 2a 61 72 67 76 20 20 20 20 20 20 20 20 20 20  **argv          
2030: 20 20 2f 2a 20 54 65 78 74 20 6f 66 20 65 61 63    /* Text of eac
2040: 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f 0a 29 7b  h argument */.){
2050: 0a 20 20 50 61 67 65 72 20 2a 70 50 61 67 65 72  .  Pager *pPager
2060: 3b 0a 20 20 63 68 61 72 20 7a 42 75 66 5b 31 30  ;.  char zBuf[10
2070: 30 5d 3b 0a 20 20 69 66 28 20 61 72 67 63 21 3d  0];.  if( argc!=
2080: 32 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70  2 ){.    Tcl_App
2090: 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70  endResult(interp
20a0: 2c 20 22 77 72 6f 6e 67 20 23 20 61 72 67 73 3a  , "wrong # args:
20b0: 20 73 68 6f 75 6c 64 20 62 65 20 5c 22 22 2c 20   should be \"", 
20c0: 61 72 67 76 5b 30 5d 2c 0a 20 20 20 20 20 20 20  argv[0],.       
20d0: 22 20 49 44 5c 22 22 2c 20 30 29 3b 0a 20 20 20  " ID\"", 0);.   
20e0: 20 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f   return TCL_ERRO
20f0: 52 3b 0a 20 20 7d 0a 20 20 69 66 28 20 54 63 6c  R;.  }.  if( Tcl
2100: 5f 47 65 74 49 6e 74 28 69 6e 74 65 72 70 2c 20  _GetInt(interp, 
2110: 61 72 67 76 5b 31 5d 2c 20 28 69 6e 74 2a 29 26  argv[1], (int*)&
2120: 70 50 61 67 65 72 29 20 29 20 72 65 74 75 72 6e  pPager) ) return
2130: 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 73 70   TCL_ERROR;.  sp
2140: 72 69 6e 74 66 28 7a 42 75 66 2c 22 25 64 22 2c  rintf(zBuf,"%d",
2150: 73 71 6c 69 74 65 70 61 67 65 72 5f 70 61 67 65  sqlitepager_page
2160: 63 6f 75 6e 74 28 70 50 61 67 65 72 29 29 3b 0a  count(pPager));.
2170: 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75    Tcl_AppendResu
2180: 6c 74 28 69 6e 74 65 72 70 2c 20 7a 42 75 66 2c  lt(interp, zBuf,
2190: 20 30 29 3b 0a 20 20 72 65 74 75 72 6e 20 54 43   0);.  return TC
21a0: 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55  L_OK;.}../*.** U
21b0: 73 61 67 65 3a 20 20 20 70 61 67 65 5f 67 65 74  sage:   page_get
21c0: 20 49 44 20 50 47 4e 4f 0a 2a 2a 0a 2a 2a 20 52   ID PGNO.**.** R
21d0: 65 74 75 72 6e 20 61 20 70 6f 69 6e 74 65 72 20  eturn a pointer 
21e0: 74 6f 20 61 20 70 61 67 65 20 66 72 6f 6d 20 74  to a page from t
21f0: 68 65 20 64 61 74 61 62 61 73 65 2e 0a 2a 2f 0a  he database..*/.
2200: 73 74 61 74 69 63 20 69 6e 74 20 70 61 67 65 5f  static int page_
2210: 67 65 74 28 0a 20 20 76 6f 69 64 20 2a 4e 6f 74  get(.  void *Not
2220: 55 73 65 64 2c 0a 20 20 54 63 6c 5f 49 6e 74 65  Used,.  Tcl_Inte
2230: 72 70 20 2a 69 6e 74 65 72 70 2c 20 20 20 20 2f  rp *interp,    /
2240: 2a 20 54 68 65 20 54 43 4c 20 69 6e 74 65 72 70  * The TCL interp
2250: 72 65 74 65 72 20 74 68 61 74 20 69 6e 76 6f 6b  reter that invok
2260: 65 64 20 74 68 69 73 20 63 6f 6d 6d 61 6e 64 20  ed this command 
2270: 2a 2f 0a 20 20 69 6e 74 20 61 72 67 63 2c 20 20  */.  int argc,  
2280: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e              /* N
2290: 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e  umber of argumen
22a0: 74 73 20 2a 2f 0a 20 20 63 68 61 72 20 2a 2a 61  ts */.  char **a
22b0: 72 67 76 20 20 20 20 20 20 20 20 20 20 20 20 2f  rgv            /
22c0: 2a 20 54 65 78 74 20 6f 66 20 65 61 63 68 20 61  * Text of each a
22d0: 72 67 75 6d 65 6e 74 20 2a 2f 0a 29 7b 0a 20 20  rgument */.){.  
22e0: 50 61 67 65 72 20 2a 70 50 61 67 65 72 3b 0a 20  Pager *pPager;. 
22f0: 20 63 68 61 72 20 7a 42 75 66 5b 31 30 30 5d 3b   char zBuf[100];
2300: 0a 20 20 76 6f 69 64 20 2a 70 50 61 67 65 3b 0a  .  void *pPage;.
2310: 20 20 69 6e 74 20 70 67 6e 6f 3b 0a 20 20 69 6e    int pgno;.  in
2320: 74 20 72 63 3b 0a 20 20 69 66 28 20 61 72 67 63  t rc;.  if( argc
2330: 21 3d 33 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41  !=3 ){.    Tcl_A
2340: 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65  ppendResult(inte
2350: 72 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72 67  rp, "wrong # arg
2360: 73 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22 22  s: should be \""
2370: 2c 20 61 72 67 76 5b 30 5d 2c 0a 20 20 20 20 20  , argv[0],.     
2380: 20 20 22 20 49 44 20 50 47 4e 4f 5c 22 22 2c 20    " ID PGNO\"", 
2390: 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54  0);.    return T
23a0: 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20  CL_ERROR;.  }.  
23b0: 69 66 28 20 54 63 6c 5f 47 65 74 49 6e 74 28 69  if( Tcl_GetInt(i
23c0: 6e 74 65 72 70 2c 20 61 72 67 76 5b 31 5d 2c 20  nterp, argv[1], 
23d0: 28 69 6e 74 2a 29 26 70 50 61 67 65 72 29 20 29  (int*)&pPager) )
23e0: 20 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f   return TCL_ERRO
23f0: 52 3b 0a 20 20 69 66 28 20 54 63 6c 5f 47 65 74  R;.  if( Tcl_Get
2400: 49 6e 74 28 69 6e 74 65 72 70 2c 20 61 72 67 76  Int(interp, argv
2410: 5b 32 5d 2c 20 26 70 67 6e 6f 29 20 29 20 72 65  [2], &pgno) ) re
2420: 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a  turn TCL_ERROR;.
2430: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 70 61 67    rc = sqlitepag
2440: 65 72 5f 67 65 74 28 70 50 61 67 65 72 2c 20 70  er_get(pPager, p
2450: 67 6e 6f 2c 20 26 70 50 61 67 65 29 3b 0a 20 20  gno, &pPage);.  
2460: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f  if( rc!=SQLITE_O
2470: 4b 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70  K ){.    Tcl_App
2480: 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70  endResult(interp
2490: 2c 20 65 72 72 6f 72 4e 61 6d 65 28 72 63 29 2c  , errorName(rc),
24a0: 20 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20   0);.    return 
24b0: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20  TCL_ERROR;.  }. 
24c0: 20 73 70 72 69 6e 74 66 28 7a 42 75 66 2c 22 30   sprintf(zBuf,"0
24d0: 78 25 78 22 2c 28 69 6e 74 29 70 50 61 67 65 29  x%x",(int)pPage)
24e0: 3b 0a 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65  ;.  Tcl_AppendRe
24f0: 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 7a 42 75  sult(interp, zBu
2500: 66 2c 20 30 29 3b 0a 20 20 72 65 74 75 72 6e 20  f, 0);.  return 
2510: 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  TCL_OK;.}../*.**
2520: 20 55 73 61 67 65 3a 20 20 20 70 61 67 65 5f 6c   Usage:   page_l
2530: 6f 6f 6b 75 70 20 49 44 20 50 47 4e 4f 0a 2a 2a  ookup ID PGNO.**
2540: 0a 2a 2a 20 52 65 74 75 72 6e 20 61 20 70 6f 69  .** Return a poi
2550: 6e 74 65 72 20 74 6f 20 61 20 70 61 67 65 20 69  nter to a page i
2560: 66 20 74 68 65 20 70 61 67 65 20 69 73 20 61 6c  f the page is al
2570: 72 65 61 64 79 20 69 6e 20 63 61 63 68 65 2e 0a  ready in cache..
2580: 2a 2a 20 49 66 20 6e 6f 74 20 69 6e 20 63 61 63  ** If not in cac
2590: 68 65 2c 20 72 65 74 75 72 6e 20 61 6e 20 65 6d  he, return an em
25a0: 70 74 79 20 73 74 72 69 6e 67 2e 0a 2a 2f 0a 73  pty string..*/.s
25b0: 74 61 74 69 63 20 69 6e 74 20 70 61 67 65 5f 6c  tatic int page_l
25c0: 6f 6f 6b 75 70 28 0a 20 20 76 6f 69 64 20 2a 4e  ookup(.  void *N
25d0: 6f 74 55 73 65 64 2c 0a 20 20 54 63 6c 5f 49 6e  otUsed,.  Tcl_In
25e0: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 20 20  terp *interp,   
25f0: 20 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e 74 65   /* The TCL inte
2600: 72 70 72 65 74 65 72 20 74 68 61 74 20 69 6e 76  rpreter that inv
2610: 6f 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d 61 6e  oked this comman
2620: 64 20 2a 2f 0a 20 20 69 6e 74 20 61 72 67 63 2c  d */.  int argc,
2630: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
2640: 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d   Number of argum
2650: 65 6e 74 73 20 2a 2f 0a 20 20 63 68 61 72 20 2a  ents */.  char *
2660: 2a 61 72 67 76 20 20 20 20 20 20 20 20 20 20 20  *argv           
2670: 20 2f 2a 20 54 65 78 74 20 6f 66 20 65 61 63 68   /* Text of each
2680: 20 61 72 67 75 6d 65 6e 74 20 2a 2f 0a 29 7b 0a   argument */.){.
2690: 20 20 50 61 67 65 72 20 2a 70 50 61 67 65 72 3b    Pager *pPager;
26a0: 0a 20 20 63 68 61 72 20 7a 42 75 66 5b 31 30 30  .  char zBuf[100
26b0: 5d 3b 0a 20 20 76 6f 69 64 20 2a 70 50 61 67 65  ];.  void *pPage
26c0: 3b 0a 20 20 69 6e 74 20 70 67 6e 6f 3b 0a 20 20  ;.  int pgno;.  
26d0: 69 66 28 20 61 72 67 63 21 3d 33 20 29 7b 0a 20  if( argc!=3 ){. 
26e0: 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65 73     Tcl_AppendRes
26f0: 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 77 72 6f  ult(interp, "wro
2700: 6e 67 20 23 20 61 72 67 73 3a 20 73 68 6f 75 6c  ng # args: shoul
2710: 64 20 62 65 20 5c 22 22 2c 20 61 72 67 76 5b 30  d be \"", argv[0
2720: 5d 2c 0a 20 20 20 20 20 20 20 22 20 49 44 20 50  ],.       " ID P
2730: 47 4e 4f 5c 22 22 2c 20 30 29 3b 0a 20 20 20 20  GNO\"", 0);.    
2740: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52  return TCL_ERROR
2750: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 54 63 6c 5f  ;.  }.  if( Tcl_
2760: 47 65 74 49 6e 74 28 69 6e 74 65 72 70 2c 20 61  GetInt(interp, a
2770: 72 67 76 5b 31 5d 2c 20 28 69 6e 74 2a 29 26 70  rgv[1], (int*)&p
2780: 50 61 67 65 72 29 20 29 20 72 65 74 75 72 6e 20  Pager) ) return 
2790: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 69 66 28  TCL_ERROR;.  if(
27a0: 20 54 63 6c 5f 47 65 74 49 6e 74 28 69 6e 74 65   Tcl_GetInt(inte
27b0: 72 70 2c 20 61 72 67 76 5b 32 5d 2c 20 26 70 67  rp, argv[2], &pg
27c0: 6e 6f 29 20 29 20 72 65 74 75 72 6e 20 54 43 4c  no) ) return TCL
27d0: 5f 45 52 52 4f 52 3b 0a 20 20 70 50 61 67 65 20  _ERROR;.  pPage 
27e0: 3d 20 73 71 6c 69 74 65 70 61 67 65 72 5f 6c 6f  = sqlitepager_lo
27f0: 6f 6b 75 70 28 70 50 61 67 65 72 2c 20 70 67 6e  okup(pPager, pgn
2800: 6f 29 3b 0a 20 20 69 66 28 20 70 50 61 67 65 20  o);.  if( pPage 
2810: 29 7b 0a 20 20 20 20 73 70 72 69 6e 74 66 28 7a  ){.    sprintf(z
2820: 42 75 66 2c 22 30 78 25 78 22 2c 28 69 6e 74 29  Buf,"0x%x",(int)
2830: 70 50 61 67 65 29 3b 0a 20 20 20 20 54 63 6c 5f  pPage);.    Tcl_
2840: 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74  AppendResult(int
2850: 65 72 70 2c 20 7a 42 75 66 2c 20 30 29 3b 0a 20  erp, zBuf, 0);. 
2860: 20 7d 0a 20 20 72 65 74 75 72 6e 20 54 43 4c 5f   }.  return TCL_
2870: 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55 73 61  OK;.}../*.** Usa
2880: 67 65 3a 20 20 20 70 61 67 65 5f 75 6e 72 65 66  ge:   page_unref
2890: 20 50 41 47 45 0a 2a 2a 0a 2a 2a 20 44 72 6f 70   PAGE.**.** Drop
28a0: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20   a pointer to a 
28b0: 70 61 67 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  page..*/.static 
28c0: 69 6e 74 20 70 61 67 65 5f 75 6e 72 65 66 28 0a  int page_unref(.
28d0: 20 20 76 6f 69 64 20 2a 4e 6f 74 55 73 65 64 2c    void *NotUsed,
28e0: 0a 20 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69  .  Tcl_Interp *i
28f0: 6e 74 65 72 70 2c 20 20 20 20 2f 2a 20 54 68 65  nterp,    /* The
2900: 20 54 43 4c 20 69 6e 74 65 72 70 72 65 74 65 72   TCL interpreter
2910: 20 74 68 61 74 20 69 6e 76 6f 6b 65 64 20 74 68   that invoked th
2920: 69 73 20 63 6f 6d 6d 61 6e 64 20 2a 2f 0a 20 20  is command */.  
2930: 69 6e 74 20 61 72 67 63 2c 20 20 20 20 20 20 20  int argc,       
2940: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
2950: 20 6f 66 20 61 72 67 75 6d 65 6e 74 73 20 2a 2f   of arguments */
2960: 0a 20 20 63 68 61 72 20 2a 2a 61 72 67 76 20 20  .  char **argv  
2970: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 65 78            /* Tex
2980: 74 20 6f 66 20 65 61 63 68 20 61 72 67 75 6d 65  t of each argume
2990: 6e 74 20 2a 2f 0a 29 7b 0a 20 20 76 6f 69 64 20  nt */.){.  void 
29a0: 2a 70 50 61 67 65 3b 0a 20 20 69 6e 74 20 72 63  *pPage;.  int rc
29b0: 3b 0a 20 20 69 66 28 20 61 72 67 63 21 3d 32 20  ;.  if( argc!=2 
29c0: 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70 65 6e  ){.    Tcl_Appen
29d0: 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20  dResult(interp, 
29e0: 22 77 72 6f 6e 67 20 23 20 61 72 67 73 3a 20 73  "wrong # args: s
29f0: 68 6f 75 6c 64 20 62 65 20 5c 22 22 2c 20 61 72  hould be \"", ar
2a00: 67 76 5b 30 5d 2c 0a 20 20 20 20 20 20 20 22 20  gv[0],.       " 
2a10: 50 41 47 45 5c 22 22 2c 20 30 29 3b 0a 20 20 20  PAGE\"", 0);.   
2a20: 20 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f   return TCL_ERRO
2a30: 52 3b 0a 20 20 7d 0a 20 20 69 66 28 20 54 63 6c  R;.  }.  if( Tcl
2a40: 5f 47 65 74 49 6e 74 28 69 6e 74 65 72 70 2c 20  _GetInt(interp, 
2a50: 61 72 67 76 5b 31 5d 2c 20 28 69 6e 74 2a 29 26  argv[1], (int*)&
2a60: 70 50 61 67 65 29 20 29 20 72 65 74 75 72 6e 20  pPage) ) return 
2a70: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 72 63 20  TCL_ERROR;.  rc 
2a80: 3d 20 73 71 6c 69 74 65 70 61 67 65 72 5f 75 6e  = sqlitepager_un
2a90: 72 65 66 28 70 50 61 67 65 29 3b 0a 20 20 69 66  ref(pPage);.  if
2aa0: 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc!=SQLITE_OK 
2ab0: 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70 70 65 6e  ){.    Tcl_Appen
2ac0: 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20  dResult(interp, 
2ad0: 65 72 72 6f 72 4e 61 6d 65 28 72 63 29 2c 20 30  errorName(rc), 0
2ae0: 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54 43  );.    return TC
2af0: 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 72  L_ERROR;.  }.  r
2b00: 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a  eturn TCL_OK;.}.
2b10: 0a 2f 2a 0a 2a 2a 20 55 73 61 67 65 3a 20 20 20  ./*.** Usage:   
2b20: 70 61 67 65 5f 72 65 61 64 20 50 41 47 45 0a 2a  page_read PAGE.*
2b30: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20  *.** Return the 
2b40: 63 6f 6e 74 65 6e 74 20 6f 66 20 61 20 70 61 67  content of a pag
2b50: 65 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  e.*/.static int 
2b60: 70 61 67 65 5f 72 65 61 64 28 0a 20 20 76 6f 69  page_read(.  voi
2b70: 64 20 2a 4e 6f 74 55 73 65 64 2c 0a 20 20 54 63  d *NotUsed,.  Tc
2b80: 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 70  l_Interp *interp
2b90: 2c 20 20 20 20 2f 2a 20 54 68 65 20 54 43 4c 20  ,    /* The TCL 
2ba0: 69 6e 74 65 72 70 72 65 74 65 72 20 74 68 61 74  interpreter that
2bb0: 20 69 6e 76 6f 6b 65 64 20 74 68 69 73 20 63 6f   invoked this co
2bc0: 6d 6d 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 61  mmand */.  int a
2bd0: 72 67 63 2c 20 20 20 20 20 20 20 20 20 20 20 20  rgc,            
2be0: 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61    /* Number of a
2bf0: 72 67 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 63 68  rguments */.  ch
2c00: 61 72 20 2a 2a 61 72 67 76 20 20 20 20 20 20 20  ar **argv       
2c10: 20 20 20 20 20 2f 2a 20 54 65 78 74 20 6f 66 20       /* Text of 
2c20: 65 61 63 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f  each argument */
2c30: 0a 29 7b 0a 20 20 63 68 61 72 20 7a 42 75 66 5b  .){.  char zBuf[
2c40: 31 30 30 5d 3b 0a 20 20 76 6f 69 64 20 2a 70 50  100];.  void *pP
2c50: 61 67 65 3b 0a 20 20 69 66 28 20 61 72 67 63 21  age;.  if( argc!
2c60: 3d 32 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70  =2 ){.    Tcl_Ap
2c70: 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72  pendResult(inter
2c80: 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72 67 73  p, "wrong # args
2c90: 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22 22 2c  : should be \"",
2ca0: 20 61 72 67 76 5b 30 5d 2c 0a 20 20 20 20 20 20   argv[0],.      
2cb0: 20 22 20 50 41 47 45 5c 22 22 2c 20 30 29 3b 0a   " PAGE\"", 0);.
2cc0: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 45      return TCL_E
2cd0: 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 69 66 28 20  RROR;.  }.  if( 
2ce0: 54 63 6c 5f 47 65 74 49 6e 74 28 69 6e 74 65 72  Tcl_GetInt(inter
2cf0: 70 2c 20 61 72 67 76 5b 31 5d 2c 20 28 69 6e 74  p, argv[1], (int
2d00: 2a 29 26 70 50 61 67 65 29 20 29 20 72 65 74 75  *)&pPage) ) retu
2d10: 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20  rn TCL_ERROR;.  
2d20: 6d 65 6d 63 70 79 28 7a 42 75 66 2c 20 70 50 61  memcpy(zBuf, pPa
2d30: 67 65 2c 20 73 69 7a 65 6f 66 28 7a 42 75 66 29  ge, sizeof(zBuf)
2d40: 29 3b 0a 20 20 54 63 6c 5f 41 70 70 65 6e 64 52  );.  Tcl_AppendR
2d50: 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 7a 42  esult(interp, zB
2d60: 75 66 2c 20 30 29 3b 0a 20 20 72 65 74 75 72 6e  uf, 0);.  return
2d70: 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a   TCL_OK;.}../*.*
2d80: 2a 20 55 73 61 67 65 3a 20 20 20 70 61 67 65 5f  * Usage:   page_
2d90: 6e 75 6d 62 65 72 20 50 41 47 45 0a 2a 2a 0a 2a  number PAGE.**.*
2da0: 2a 20 52 65 74 75 72 6e 20 74 68 65 20 70 61 67  * Return the pag
2db0: 65 20 6e 75 6d 62 65 72 20 66 6f 72 20 61 20 70  e number for a p
2dc0: 61 67 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  age..*/.static i
2dd0: 6e 74 20 70 61 67 65 5f 6e 75 6d 62 65 72 28 0a  nt page_number(.
2de0: 20 20 76 6f 69 64 20 2a 4e 6f 74 55 73 65 64 2c    void *NotUsed,
2df0: 0a 20 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69  .  Tcl_Interp *i
2e00: 6e 74 65 72 70 2c 20 20 20 20 2f 2a 20 54 68 65  nterp,    /* The
2e10: 20 54 43 4c 20 69 6e 74 65 72 70 72 65 74 65 72   TCL interpreter
2e20: 20 74 68 61 74 20 69 6e 76 6f 6b 65 64 20 74 68   that invoked th
2e30: 69 73 20 63 6f 6d 6d 61 6e 64 20 2a 2f 0a 20 20  is command */.  
2e40: 69 6e 74 20 61 72 67 63 2c 20 20 20 20 20 20 20  int argc,       
2e50: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
2e60: 20 6f 66 20 61 72 67 75 6d 65 6e 74 73 20 2a 2f   of arguments */
2e70: 0a 20 20 63 68 61 72 20 2a 2a 61 72 67 76 20 20  .  char **argv  
2e80: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 65 78            /* Tex
2e90: 74 20 6f 66 20 65 61 63 68 20 61 72 67 75 6d 65  t of each argume
2ea0: 6e 74 20 2a 2f 0a 29 7b 0a 20 20 63 68 61 72 20  nt */.){.  char 
2eb0: 7a 42 75 66 5b 31 30 30 5d 3b 0a 20 20 76 6f 69  zBuf[100];.  voi
2ec0: 64 20 2a 70 50 61 67 65 3b 0a 20 20 69 66 28 20  d *pPage;.  if( 
2ed0: 61 72 67 63 21 3d 32 20 29 7b 0a 20 20 20 20 54  argc!=2 ){.    T
2ee0: 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c 74 28  cl_AppendResult(
2ef0: 69 6e 74 65 72 70 2c 20 22 77 72 6f 6e 67 20 23  interp, "wrong #
2f00: 20 61 72 67 73 3a 20 73 68 6f 75 6c 64 20 62 65   args: should be
2f10: 20 5c 22 22 2c 20 61 72 67 76 5b 30 5d 2c 0a 20   \"", argv[0],. 
2f20: 20 20 20 20 20 20 22 20 50 41 47 45 5c 22 22 2c        " PAGE\"",
2f30: 20 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20   0);.    return 
2f40: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20  TCL_ERROR;.  }. 
2f50: 20 69 66 28 20 54 63 6c 5f 47 65 74 49 6e 74 28   if( Tcl_GetInt(
2f60: 69 6e 74 65 72 70 2c 20 61 72 67 76 5b 31 5d 2c  interp, argv[1],
2f70: 20 28 69 6e 74 2a 29 26 70 50 61 67 65 29 20 29   (int*)&pPage) )
2f80: 20 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f   return TCL_ERRO
2f90: 52 3b 0a 20 20 73 70 72 69 6e 74 66 28 7a 42 75  R;.  sprintf(zBu
2fa0: 66 2c 20 22 25 64 22 2c 20 73 71 6c 69 74 65 70  f, "%d", sqlitep
2fb0: 61 67 65 72 5f 70 61 67 65 6e 75 6d 62 65 72 28  ager_pagenumber(
2fc0: 70 50 61 67 65 29 29 3b 0a 20 20 54 63 6c 5f 41  pPage));.  Tcl_A
2fd0: 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65  ppendResult(inte
2fe0: 72 70 2c 20 7a 42 75 66 2c 20 30 29 3b 0a 20 20  rp, zBuf, 0);.  
2ff0: 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d  return TCL_OK;.}
3000: 0a 0a 2f 2a 0a 2a 2a 20 55 73 61 67 65 3a 20 20  ../*.** Usage:  
3010: 20 70 61 67 65 5f 77 72 69 74 65 20 50 41 47 45   page_write PAGE
3020: 20 44 41 54 41 0a 2a 2a 0a 2a 2a 20 57 72 69 74   DATA.**.** Writ
3030: 65 20 73 6f 6d 65 74 68 69 6e 67 20 69 6e 74 6f  e something into
3040: 20 61 20 70 61 67 65 2e 0a 2a 2f 0a 73 74 61 74   a page..*/.stat
3050: 69 63 20 69 6e 74 20 70 61 67 65 5f 77 72 69 74  ic int page_writ
3060: 65 28 0a 20 20 76 6f 69 64 20 2a 4e 6f 74 55 73  e(.  void *NotUs
3070: 65 64 2c 0a 20 20 54 63 6c 5f 49 6e 74 65 72 70  ed,.  Tcl_Interp
3080: 20 2a 69 6e 74 65 72 70 2c 20 20 20 20 2f 2a 20   *interp,    /* 
3090: 54 68 65 20 54 43 4c 20 69 6e 74 65 72 70 72 65  The TCL interpre
30a0: 74 65 72 20 74 68 61 74 20 69 6e 76 6f 6b 65 64  ter that invoked
30b0: 20 74 68 69 73 20 63 6f 6d 6d 61 6e 64 20 2a 2f   this command */
30c0: 0a 20 20 69 6e 74 20 61 72 67 63 2c 20 20 20 20  .  int argc,    
30d0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d            /* Num
30e0: 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e 74 73  ber of arguments
30f0: 20 2a 2f 0a 20 20 63 68 61 72 20 2a 2a 61 72 67   */.  char **arg
3100: 76 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  v            /* 
3110: 54 65 78 74 20 6f 66 20 65 61 63 68 20 61 72 67  Text of each arg
3120: 75 6d 65 6e 74 20 2a 2f 0a 29 7b 0a 20 20 76 6f  ument */.){.  vo
3130: 69 64 20 2a 70 50 61 67 65 3b 0a 20 20 69 6e 74  id *pPage;.  int
3140: 20 72 63 3b 0a 20 20 69 66 28 20 61 72 67 63 21   rc;.  if( argc!
3150: 3d 33 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41 70  =3 ){.    Tcl_Ap
3160: 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72  pendResult(inter
3170: 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72 67 73  p, "wrong # args
3180: 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22 22 2c  : should be \"",
3190: 20 61 72 67 76 5b 30 5d 2c 0a 20 20 20 20 20 20   argv[0],.      
31a0: 20 22 20 50 41 47 45 20 44 41 54 41 5c 22 22 2c   " PAGE DATA\"",
31b0: 20 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20   0);.    return 
31c0: 54 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20  TCL_ERROR;.  }. 
31d0: 20 69 66 28 20 54 63 6c 5f 47 65 74 49 6e 74 28   if( Tcl_GetInt(
31e0: 69 6e 74 65 72 70 2c 20 61 72 67 76 5b 31 5d 2c  interp, argv[1],
31f0: 20 28 69 6e 74 2a 29 26 70 50 61 67 65 29 20 29   (int*)&pPage) )
3200: 20 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f   return TCL_ERRO
3210: 52 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65  R;.  rc = sqlite
3220: 70 61 67 65 72 5f 77 72 69 74 65 28 70 50 61 67  pager_write(pPag
3230: 65 29 3b 0a 20 20 69 66 28 20 72 63 21 3d 53 51  e);.  if( rc!=SQ
3240: 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 54  LITE_OK ){.    T
3250: 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c 74 28  cl_AppendResult(
3260: 69 6e 74 65 72 70 2c 20 65 72 72 6f 72 4e 61 6d  interp, errorNam
3270: 65 28 72 63 29 2c 20 30 29 3b 0a 20 20 20 20 72  e(rc), 0);.    r
3280: 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b  eturn TCL_ERROR;
3290: 0a 20 20 7d 0a 20 20 73 74 72 6e 63 70 79 28 28  .  }.  strncpy((
32a0: 63 68 61 72 2a 29 70 50 61 67 65 2c 20 61 72 67  char*)pPage, arg
32b0: 76 5b 32 5d 2c 20 53 51 4c 49 54 45 5f 50 41 47  v[2], SQLITE_PAG
32c0: 45 5f 53 49 5a 45 2d 31 29 3b 0a 20 20 28 28 63  E_SIZE-1);.  ((c
32d0: 68 61 72 2a 29 70 50 61 67 65 29 5b 53 51 4c 49  har*)pPage)[SQLI
32e0: 54 45 5f 50 41 47 45 5f 53 49 5a 45 2d 31 5d 20  TE_PAGE_SIZE-1] 
32f0: 3d 20 30 3b 0a 20 20 72 65 74 75 72 6e 20 54 43  = 0;.  return TC
3300: 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52  L_OK;.}../*.** R
3310: 65 67 69 73 74 65 72 20 63 6f 6d 6d 61 6e 64 73  egister commands
3320: 20 77 69 74 68 20 74 68 65 20 54 43 4c 20 69 6e   with the TCL in
3330: 74 65 72 70 72 65 74 65 72 2e 0a 2a 2f 0a 69 6e  terpreter..*/.in
3340: 74 20 53 71 6c 69 74 65 74 65 73 74 32 5f 49 6e  t Sqlitetest2_In
3350: 69 74 28 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69  it(Tcl_Interp *i
3360: 6e 74 65 72 70 29 7b 0a 20 20 65 78 74 65 72 6e  nterp){.  extern
3370: 20 69 6e 74 20 73 71 6c 69 74 65 5f 69 6f 5f 65   int sqlite_io_e
3380: 72 72 6f 72 5f 70 65 6e 64 69 6e 67 3b 0a 20 20  rror_pending;.  
3390: 54 63 6c 5f 43 72 65 61 74 65 43 6f 6d 6d 61 6e  Tcl_CreateComman
33a0: 64 28 69 6e 74 65 72 70 2c 20 22 70 61 67 65 72  d(interp, "pager
33b0: 5f 6f 70 65 6e 22 2c 20 70 61 67 65 72 5f 6f 70  _open", pager_op
33c0: 65 6e 2c 20 30 2c 20 30 29 3b 0a 20 20 54 63 6c  en, 0, 0);.  Tcl
33d0: 5f 43 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 69  _CreateCommand(i
33e0: 6e 74 65 72 70 2c 20 22 70 61 67 65 72 5f 63 6c  nterp, "pager_cl
33f0: 6f 73 65 22 2c 20 70 61 67 65 72 5f 63 6c 6f 73  ose", pager_clos
3400: 65 2c 20 30 2c 20 30 29 3b 0a 20 20 54 63 6c 5f  e, 0, 0);.  Tcl_
3410: 43 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 69 6e  CreateCommand(in
3420: 74 65 72 70 2c 20 22 70 61 67 65 72 5f 63 6f 6d  terp, "pager_com
3430: 6d 69 74 22 2c 20 70 61 67 65 72 5f 63 6f 6d 6d  mit", pager_comm
3440: 69 74 2c 20 30 2c 20 30 29 3b 0a 20 20 54 63 6c  it, 0, 0);.  Tcl
3450: 5f 43 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 69  _CreateCommand(i
3460: 6e 74 65 72 70 2c 20 22 70 61 67 65 72 5f 72 6f  nterp, "pager_ro
3470: 6c 6c 62 61 63 6b 22 2c 20 70 61 67 65 72 5f 72  llback", pager_r
3480: 6f 6c 6c 62 61 63 6b 2c 20 30 2c 20 30 29 3b 0a  ollback, 0, 0);.
3490: 20 20 54 63 6c 5f 43 72 65 61 74 65 43 6f 6d 6d    Tcl_CreateComm
34a0: 61 6e 64 28 69 6e 74 65 72 70 2c 20 22 70 61 67  and(interp, "pag
34b0: 65 72 5f 63 6b 70 74 5f 62 65 67 69 6e 22 2c 20  er_ckpt_begin", 
34c0: 70 61 67 65 72 5f 63 6b 70 74 5f 62 65 67 69 6e  pager_ckpt_begin
34d0: 2c 20 30 2c 20 30 29 3b 0a 20 20 54 63 6c 5f 43  , 0, 0);.  Tcl_C
34e0: 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 69 6e 74  reateCommand(int
34f0: 65 72 70 2c 20 22 70 61 67 65 72 5f 63 6b 70 74  erp, "pager_ckpt
3500: 5f 63 6f 6d 6d 69 74 22 2c 20 70 61 67 65 72 5f  _commit", pager_
3510: 63 6b 70 74 5f 63 6f 6d 6d 69 74 2c 20 30 2c 20  ckpt_commit, 0, 
3520: 30 29 3b 0a 20 20 54 63 6c 5f 43 72 65 61 74 65  0);.  Tcl_Create
3530: 43 6f 6d 6d 61 6e 64 28 69 6e 74 65 72 70 2c 20  Command(interp, 
3540: 22 70 61 67 65 72 5f 63 6b 70 74 5f 72 6f 6c 6c  "pager_ckpt_roll
3550: 62 61 63 6b 22 2c 20 70 61 67 65 72 5f 63 6b 70  back", pager_ckp
3560: 74 5f 72 6f 6c 6c 62 61 63 6b 2c 20 30 2c 20 30  t_rollback, 0, 0
3570: 29 3b 0a 20 20 54 63 6c 5f 43 72 65 61 74 65 43  );.  Tcl_CreateC
3580: 6f 6d 6d 61 6e 64 28 69 6e 74 65 72 70 2c 20 22  ommand(interp, "
3590: 70 61 67 65 72 5f 73 74 61 74 73 22 2c 20 70 61  pager_stats", pa
35a0: 67 65 72 5f 73 74 61 74 73 2c 20 30 2c 20 30 29  ger_stats, 0, 0)
35b0: 3b 0a 20 20 54 63 6c 5f 43 72 65 61 74 65 43 6f  ;.  Tcl_CreateCo
35c0: 6d 6d 61 6e 64 28 69 6e 74 65 72 70 2c 20 22 70  mmand(interp, "p
35d0: 61 67 65 72 5f 70 61 67 65 63 6f 75 6e 74 22 2c  ager_pagecount",
35e0: 20 70 61 67 65 72 5f 70 61 67 65 63 6f 75 6e 74   pager_pagecount
35f0: 2c 20 30 2c 20 30 29 3b 0a 20 20 54 63 6c 5f 43  , 0, 0);.  Tcl_C
3600: 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 69 6e 74  reateCommand(int
3610: 65 72 70 2c 20 22 70 61 67 65 5f 67 65 74 22 2c  erp, "page_get",
3620: 20 70 61 67 65 5f 67 65 74 2c 20 30 2c 20 30 29   page_get, 0, 0)
3630: 3b 0a 20 20 54 63 6c 5f 43 72 65 61 74 65 43 6f  ;.  Tcl_CreateCo
3640: 6d 6d 61 6e 64 28 69 6e 74 65 72 70 2c 20 22 70  mmand(interp, "p
3650: 61 67 65 5f 6c 6f 6f 6b 75 70 22 2c 20 70 61 67  age_lookup", pag
3660: 65 5f 6c 6f 6f 6b 75 70 2c 20 30 2c 20 30 29 3b  e_lookup, 0, 0);
3670: 0a 20 20 54 63 6c 5f 43 72 65 61 74 65 43 6f 6d  .  Tcl_CreateCom
3680: 6d 61 6e 64 28 69 6e 74 65 72 70 2c 20 22 70 61  mand(interp, "pa
3690: 67 65 5f 75 6e 72 65 66 22 2c 20 70 61 67 65 5f  ge_unref", page_
36a0: 75 6e 72 65 66 2c 20 30 2c 20 30 29 3b 0a 20 20  unref, 0, 0);.  
36b0: 54 63 6c 5f 43 72 65 61 74 65 43 6f 6d 6d 61 6e  Tcl_CreateComman
36c0: 64 28 69 6e 74 65 72 70 2c 20 22 70 61 67 65 5f  d(interp, "page_
36d0: 72 65 61 64 22 2c 20 70 61 67 65 5f 72 65 61 64  read", page_read
36e0: 2c 20 30 2c 20 30 29 3b 0a 20 20 54 63 6c 5f 43  , 0, 0);.  Tcl_C
36f0: 72 65 61 74 65 43 6f 6d 6d 61 6e 64 28 69 6e 74  reateCommand(int
3700: 65 72 70 2c 20 22 70 61 67 65 5f 77 72 69 74 65  erp, "page_write
3710: 22 2c 20 70 61 67 65 5f 77 72 69 74 65 2c 20 30  ", page_write, 0
3720: 2c 20 30 29 3b 0a 20 20 54 63 6c 5f 43 72 65 61  , 0);.  Tcl_Crea
3730: 74 65 43 6f 6d 6d 61 6e 64 28 69 6e 74 65 72 70  teCommand(interp
3740: 2c 20 22 70 61 67 65 5f 6e 75 6d 62 65 72 22 2c  , "page_number",
3750: 20 70 61 67 65 5f 6e 75 6d 62 65 72 2c 20 30 2c   page_number, 0,
3760: 20 30 29 3b 0a 20 20 54 63 6c 5f 4c 69 6e 6b 56   0);.  Tcl_LinkV
3770: 61 72 28 69 6e 74 65 72 70 2c 20 22 73 71 6c 69  ar(interp, "sqli
3780: 74 65 5f 69 6f 5f 65 72 72 6f 72 5f 70 65 6e 64  te_io_error_pend
3790: 69 6e 67 22 2c 0a 20 20 20 20 20 28 63 68 61 72  ing",.     (char
37a0: 2a 29 26 73 71 6c 69 74 65 5f 69 6f 5f 65 72 72  *)&sqlite_io_err
37b0: 6f 72 5f 70 65 6e 64 69 6e 67 2c 20 54 43 4c 5f  or_pending, TCL_
37c0: 4c 49 4e 4b 5f 49 4e 54 29 3b 0a 20 20 72 65 74  LINK_INT);.  ret
37d0: 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a        urn TCL_OK;.}.