System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 1790dd06ee5165b0ed8a56bc941bb2f1c88be923:


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 54 68 69 73 20 66  ******.** This f
0180: 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 63 6f 64  ile contains cod
0190: 65 20 74 6f 20 69 6d 70 6c 65 6d 65 6e 74 20 74  e to implement t
01a0: 68 65 20 22 73 71 6c 69 74 65 22 20 63 6f 6d 6d  he "sqlite" comm
01b0: 61 6e 64 20 6c 69 6e 65 0a 2a 2a 20 75 74 69 6c  and line.** util
01c0: 69 74 79 20 66 6f 72 20 61 63 63 65 73 73 69 6e  ity for accessin
01d0: 67 20 53 51 4c 69 74 65 20 64 61 74 61 62 61 73  g SQLite databas
01e0: 65 73 2e 0a 2a 2a 0a 2a 2a 20 24 49 64 3a 20 73  es..**.** $Id: s
01f0: 68 65 6c 6c 2e 63 2c 76 20 31 2e 32 35 20 32 30  hell.c,v 1.25 20
0200: 30 37 2f 30 31 2f 31 30 20 31 34 3a 35 30 3a 34  07/01/10 14:50:4
0210: 36 20 72 6d 73 69 6d 70 73 6f 6e 20 45 78 70 20  6 rmsimpson Exp 
0220: 24 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 3c 73  $.*/.#include <s
0230: 74 64 6c 69 62 2e 68 3e 0a 23 69 6e 63 6c 75 64  tdlib.h>.#includ
0240: 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69 6e  e <string.h>.#in
0250: 63 6c 75 64 65 20 3c 73 74 64 69 6f 2e 68 3e 0a  clude <stdio.h>.
0260: 23 69 6e 63 6c 75 64 65 20 3c 61 73 73 65 72 74  #include <assert
0270: 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 22 73 71  .h>.#include "sq
0280: 6c 69 74 65 33 2e 68 22 0a 23 69 6e 63 6c 75 64  lite3.h".#includ
0290: 65 20 3c 63 74 79 70 65 2e 68 3e 0a 0a 23 69 66  e <ctype.h>..#if
02a0: 20 21 64 65 66 69 6e 65 64 28 5f 57 49 4e 33 32   !defined(_WIN32
02b0: 29 20 26 26 20 21 64 65 66 69 6e 65 64 28 57 49  ) && !defined(WI
02c0: 4e 33 32 29 20 26 26 20 21 64 65 66 69 6e 65 64  N32) && !defined
02d0: 28 5f 5f 4d 41 43 4f 53 5f 5f 29 20 26 26 20 21  (__MACOS__) && !
02e0: 64 65 66 69 6e 65 64 28 5f 5f 4f 53 32 5f 5f 29  defined(__OS2__)
02f0: 0a 23 20 69 6e 63 6c 75 64 65 20 3c 73 69 67 6e  .# include <sign
0300: 61 6c 2e 68 3e 0a 23 20 69 6e 63 6c 75 64 65 20  al.h>.# include 
0310: 3c 70 77 64 2e 68 3e 0a 23 20 69 6e 63 6c 75 64  <pwd.h>.# includ
0320: 65 20 3c 75 6e 69 73 74 64 2e 68 3e 0a 23 20 69  e <unistd.h>.# i
0330: 6e 63 6c 75 64 65 20 3c 73 79 73 2f 74 79 70 65  nclude <sys/type
0340: 73 2e 68 3e 0a 23 65 6e 64 69 66 0a 0a 23 69 66  s.h>.#endif..#if
0350: 64 65 66 20 5f 5f 4d 41 43 4f 53 5f 5f 0a 23 20  def __MACOS__.# 
0360: 69 6e 63 6c 75 64 65 20 3c 63 6f 6e 73 6f 6c 65  include <console
0370: 2e 68 3e 0a 23 20 69 6e 63 6c 75 64 65 20 3c 73  .h>.# include <s
0380: 69 67 6e 61 6c 2e 68 3e 0a 23 20 69 6e 63 6c 75  ignal.h>.# inclu
0390: 64 65 20 3c 75 6e 69 73 74 64 2e 68 3e 0a 23 20  de <unistd.h>.# 
03a0: 69 6e 63 6c 75 64 65 20 3c 65 78 74 72 61 73 2e  include <extras.
03b0: 68 3e 0a 23 20 69 6e 63 6c 75 64 65 20 3c 46 69  h>.# include <Fi
03c0: 6c 65 73 2e 68 3e 0a 23 20 69 6e 63 6c 75 64 65  les.h>.# include
03d0: 20 3c 46 6f 6c 64 65 72 73 2e 68 3e 0a 23 65 6e   <Folders.h>.#en
03e0: 64 69 66 0a 0a 23 69 66 64 65 66 20 5f 5f 4f 53  dif..#ifdef __OS
03f0: 32 5f 5f 0a 23 20 69 6e 63 6c 75 64 65 20 3c 75  2__.# include <u
0400: 6e 69 73 74 64 2e 68 3e 0a 23 65 6e 64 69 66 0a  nistd.h>.#endif.
0410: 0a 23 69 66 20 64 65 66 69 6e 65 64 28 48 41 56  .#if defined(HAV
0420: 45 5f 52 45 41 44 4c 49 4e 45 29 20 26 26 20 48  E_READLINE) && H
0430: 41 56 45 5f 52 45 41 44 4c 49 4e 45 3d 3d 31 0a  AVE_READLINE==1.
0440: 23 20 69 6e 63 6c 75 64 65 20 3c 72 65 61 64 6c  # include <readl
0450: 69 6e 65 2f 72 65 61 64 6c 69 6e 65 2e 68 3e 0a  ine/readline.h>.
0460: 23 20 69 6e 63 6c 75 64 65 20 3c 72 65 61 64 6c  # include <readl
0470: 69 6e 65 2f 68 69 73 74 6f 72 79 2e 68 3e 0a 23  ine/history.h>.#
0480: 65 6c 73 65 0a 23 20 64 65 66 69 6e 65 20 72 65  else.# define re
0490: 61 64 6c 69 6e 65 28 70 29 20 6c 6f 63 61 6c 5f  adline(p) local_
04a0: 67 65 74 6c 69 6e 65 28 70 2c 73 74 64 69 6e 29  getline(p,stdin)
04b0: 0a 23 20 64 65 66 69 6e 65 20 61 64 64 5f 68 69  .# define add_hi
04c0: 73 74 6f 72 79 28 58 29 0a 23 20 64 65 66 69 6e  story(X).# defin
04d0: 65 20 72 65 61 64 5f 68 69 73 74 6f 72 79 28 58  e read_history(X
04e0: 29 0a 23 20 64 65 66 69 6e 65 20 77 72 69 74 65  ).# define write
04f0: 5f 68 69 73 74 6f 72 79 28 58 29 0a 23 20 64 65  _history(X).# de
0500: 66 69 6e 65 20 73 74 69 66 6c 65 5f 68 69 73 74  fine stifle_hist
0510: 6f 72 79 28 58 29 0a 23 65 6e 64 69 66 0a 0a 23  ory(X).#endif..#
0520: 69 66 20 64 65 66 69 6e 65 64 28 5f 57 49 4e 33  if defined(_WIN3
0530: 32 29 20 7c 7c 20 64 65 66 69 6e 65 64 28 57 49  2) || defined(WI
0540: 4e 33 32 29 0a 23 20 69 6e 63 6c 75 64 65 20 3c  N32).# include <
0550: 69 6f 2e 68 3e 0a 23 65 6c 73 65 0a 2f 2a 20 4d  io.h>.#else./* M
0560: 61 6b 65 20 73 75 72 65 20 69 73 61 74 74 79 28  ake sure isatty(
0570: 29 20 68 61 73 20 61 20 70 72 6f 74 6f 74 79 70  ) has a prototyp
0580: 65 2e 0a 2a 2f 0a 65 78 74 65 72 6e 20 69 6e 74  e..*/.extern int
0590: 20 69 73 61 74 74 79 28 29 3b 0a 23 65 6e 64 69   isatty();.#endi
05a0: 66 0a 0a 2f 2a 0a 2a 2a 20 49 66 20 74 68 65 20  f../*.** If the 
05b0: 66 6f 6c 6c 6f 77 69 6e 67 20 66 6c 61 67 20 69  following flag i
05c0: 73 20 73 65 74 2c 20 74 68 65 6e 20 63 6f 6d 6d  s set, then comm
05d0: 61 6e 64 20 65 78 65 63 75 74 69 6f 6e 20 73 74  and execution st
05e0: 6f 70 73 0a 2a 2a 20 61 74 20 61 6e 20 65 72 72  ops.** at an err
05f0: 6f 72 20 69 66 20 77 65 20 61 72 65 20 6e 6f 74  or if we are not
0600: 20 69 6e 74 65 72 61 63 74 69 76 65 2e 0a 2a 2f   interactive..*/
0610: 0a 73 74 61 74 69 63 20 69 6e 74 20 62 61 69 6c  .static int bail
0620: 5f 6f 6e 5f 65 72 72 6f 72 20 3d 20 30 3b 0a 0a  _on_error = 0;..
0630: 2f 2a 0a 2a 2a 20 54 68 72 65 61 74 20 73 74 64  /*.** Threat std
0640: 69 6e 20 61 73 20 61 6e 20 69 6e 74 65 72 61 63  in as an interac
0650: 74 69 76 65 20 69 6e 70 75 74 20 69 66 20 74 68  tive input if th
0660: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 76 61 72 69  e following vari
0670: 61 62 6c 65 0a 2a 2a 20 69 73 20 74 72 75 65 2e  able.** is true.
0680: 20 20 4f 74 68 65 72 77 69 73 65 2c 20 61 73 73    Otherwise, ass
0690: 75 6d 65 20 73 74 64 69 6e 20 69 73 20 63 6f 6e  ume stdin is con
06a0: 6e 65 63 74 65 64 20 74 6f 20 61 20 66 69 6c 65  nected to a file
06b0: 20 6f 72 20 70 69 70 65 2e 0a 2a 2f 0a 73 74 61   or pipe..*/.sta
06c0: 74 69 63 20 69 6e 74 20 73 74 64 69 6e 5f 69 73  tic int stdin_is
06d0: 5f 69 6e 74 65 72 61 63 74 69 76 65 20 3d 20 31  _interactive = 1
06e0: 3b 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c  ;../*.** The fol
06f0: 6c 6f 77 69 6e 67 20 69 73 20 74 68 65 20 6f 70  lowing is the op
0700: 65 6e 20 53 51 4c 69 74 65 20 64 61 74 61 62 61  en SQLite databa
0710: 73 65 2e 20 20 57 65 20 6d 61 6b 65 20 61 20 70  se.  We make a p
0720: 6f 69 6e 74 65 72 0a 2a 2a 20 74 6f 20 74 68 69  ointer.** to thi
0730: 73 20 64 61 74 61 62 61 73 65 20 61 20 73 74 61  s database a sta
0740: 74 69 63 20 76 61 72 69 61 62 6c 65 20 73 6f 20  tic variable so 
0750: 74 68 61 74 20 69 74 20 63 61 6e 20 62 65 20 61  that it can be a
0760: 63 63 65 73 73 65 64 0a 2a 2a 20 62 79 20 74 68  ccessed.** by th
0770: 65 20 53 49 47 49 4e 54 20 68 61 6e 64 6c 65 72  e SIGINT handler
0780: 20 74 6f 20 69 6e 74 65 72 72 75 70 74 20 64 61   to interrupt da
0790: 74 61 62 61 73 65 20 70 72 6f 63 65 73 73 69 6e  tabase processin
07a0: 67 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 73 71 6c  g..*/.static sql
07b0: 69 74 65 33 20 2a 64 62 20 3d 20 30 3b 0a 0a 2f  ite3 *db = 0;../
07c0: 2a 0a 2a 2a 20 54 72 75 65 20 69 66 20 61 6e 20  *.** True if an 
07d0: 69 6e 74 65 72 72 75 70 74 20 28 43 6f 6e 74 72  interrupt (Contr
07e0: 6f 6c 2d 43 29 20 68 61 73 20 62 65 65 6e 20 72  ol-C) has been r
07f0: 65 63 65 69 76 65 64 2e 0a 2a 2f 0a 73 74 61 74  eceived..*/.stat
0800: 69 63 20 76 6f 6c 61 74 69 6c 65 20 69 6e 74 20  ic volatile int 
0810: 73 65 65 6e 49 6e 74 65 72 72 75 70 74 20 3d 20  seenInterrupt = 
0820: 30 3b 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 69  0;../*.** This i
0830: 73 20 74 68 65 20 6e 61 6d 65 20 6f 66 20 6f 75  s the name of ou
0840: 72 20 70 72 6f 67 72 61 6d 2e 20 49 74 20 69 73  r program. It is
0850: 20 73 65 74 20 69 6e 20 6d 61 69 6e 28 29 2c 20   set in main(), 
0860: 75 73 65 64 0a 2a 2a 20 69 6e 20 61 20 6e 75 6d  used.** in a num
0870: 62 65 72 20 6f 66 20 6f 74 68 65 72 20 70 6c 61  ber of other pla
0880: 63 65 73 2c 20 6d 6f 73 74 6c 79 20 66 6f 72 20  ces, mostly for 
0890: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 73 2e 0a  error messages..
08a0: 2a 2f 0a 73 74 61 74 69 63 20 63 68 61 72 20 2a  */.static char *
08b0: 41 72 67 76 30 3b 0a 0a 2f 2a 0a 2a 2a 20 50 72  Argv0;../*.** Pr
08c0: 6f 6d 70 74 20 73 74 72 69 6e 67 73 2e 20 49 6e  ompt strings. In
08d0: 69 74 69 61 6c 69 7a 65 64 20 69 6e 20 6d 61 69  itialized in mai
08e0: 6e 2e 20 53 65 74 74 61 62 6c 65 20 77 69 74 68  n. Settable with
08f0: 0a 2a 2a 20 20 20 2e 70 72 6f 6d 70 74 20 6d 61  .**   .prompt ma
0900: 69 6e 20 63 6f 6e 74 69 6e 75 65 0a 2a 2f 0a 73  in continue.*/.s
0910: 74 61 74 69 63 20 63 68 61 72 20 6d 61 69 6e 50  tatic char mainP
0920: 72 6f 6d 70 74 5b 32 30 5d 3b 20 20 20 20 20 2f  rompt[20];     /
0930: 2a 20 46 69 72 73 74 20 6c 69 6e 65 20 70 72 6f  * First line pro
0940: 6d 70 74 2e 20 64 65 66 61 75 6c 74 3a 20 22 73  mpt. default: "s
0950: 71 6c 69 74 65 3e 20 22 2a 2f 0a 73 74 61 74 69  qlite> "*/.stati
0960: 63 20 63 68 61 72 20 63 6f 6e 74 69 6e 75 65 50  c char continueP
0970: 72 6f 6d 70 74 5b 32 30 5d 3b 20 2f 2a 20 43 6f  rompt[20]; /* Co
0980: 6e 74 69 6e 75 61 74 69 6f 6e 20 70 72 6f 6d 70  ntinuation promp
0990: 74 2e 20 64 65 66 61 75 6c 74 3a 20 22 20 20 20  t. default: "   
09a0: 2e 2e 2e 3e 20 22 20 2a 2f 0a 0a 0a 2f 2a 0a 2a  ...> " */.../*.*
09b0: 2a 20 44 65 74 65 72 6d 69 6e 65 73 20 69 66 20  * Determines if 
09c0: 61 20 73 74 72 69 6e 67 20 69 73 20 61 20 6e 75  a string is a nu
09d0: 6d 62 65 72 20 6f 66 20 6e 6f 74 2e 0a 2a 2f 0a  mber of not..*/.
09e0: 73 74 61 74 69 63 20 69 6e 74 20 69 73 4e 75 6d  static int isNum
09f0: 62 65 72 28 63 6f 6e 73 74 20 63 68 61 72 20 2a  ber(const char *
0a00: 7a 2c 20 69 6e 74 20 2a 72 65 61 6c 6e 75 6d 29  z, int *realnum)
0a10: 7b 0a 20 20 69 66 28 20 2a 7a 3d 3d 27 2d 27 20  {.  if( *z=='-' 
0a20: 7c 7c 20 2a 7a 3d 3d 27 2b 27 20 29 20 7a 2b 2b  || *z=='+' ) z++
0a30: 3b 0a 20 20 69 66 28 20 21 69 73 64 69 67 69 74  ;.  if( !isdigit
0a40: 28 2a 7a 29 20 29 7b 0a 20 20 20 20 72 65 74 75  (*z) ){.    retu
0a50: 72 6e 20 30 3b 0a 20 20 7d 0a 20 20 7a 2b 2b 3b  rn 0;.  }.  z++;
0a60: 0a 20 20 69 66 28 20 72 65 61 6c 6e 75 6d 20 29  .  if( realnum )
0a70: 20 2a 72 65 61 6c 6e 75 6d 20 3d 20 30 3b 0a 20   *realnum = 0;. 
0a80: 20 77 68 69 6c 65 28 20 69 73 64 69 67 69 74 28   while( isdigit(
0a90: 2a 7a 29 20 29 7b 20 7a 2b 2b 3b 20 7d 0a 20 20  *z) ){ z++; }.  
0aa0: 69 66 28 20 2a 7a 3d 3d 27 2e 27 20 29 7b 0a 20  if( *z=='.' ){. 
0ab0: 20 20 20 7a 2b 2b 3b 0a 20 20 20 20 69 66 28 20     z++;.    if( 
0ac0: 21 69 73 64 69 67 69 74 28 2a 7a 29 20 29 20 72  !isdigit(*z) ) r
0ad0: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 77 68 69  eturn 0;.    whi
0ae0: 6c 65 28 20 69 73 64 69 67 69 74 28 2a 7a 29 20  le( isdigit(*z) 
0af0: 29 7b 20 7a 2b 2b 3b 20 7d 0a 20 20 20 20 69 66  ){ z++; }.    if
0b00: 28 20 72 65 61 6c 6e 75 6d 20 29 20 2a 72 65 61  ( realnum ) *rea
0b10: 6c 6e 75 6d 20 3d 20 31 3b 0a 20 20 7d 0a 20 20  lnum = 1;.  }.  
0b20: 69 66 28 20 2a 7a 3d 3d 27 65 27 20 7c 7c 20 2a  if( *z=='e' || *
0b30: 7a 3d 3d 27 45 27 20 29 7b 0a 20 20 20 20 7a 2b  z=='E' ){.    z+
0b40: 2b 3b 0a 20 20 20 20 69 66 28 20 2a 7a 3d 3d 27  +;.    if( *z=='
0b50: 2b 27 20 7c 7c 20 2a 7a 3d 3d 27 2d 27 20 29 20  +' || *z=='-' ) 
0b60: 7a 2b 2b 3b 0a 20 20 20 20 69 66 28 20 21 69 73  z++;.    if( !is
0b70: 64 69 67 69 74 28 2a 7a 29 20 29 20 72 65 74 75  digit(*z) ) retu
0b80: 72 6e 20 30 3b 0a 20 20 20 20 77 68 69 6c 65 28  rn 0;.    while(
0b90: 20 69 73 64 69 67 69 74 28 2a 7a 29 20 29 7b 20   isdigit(*z) ){ 
0ba0: 7a 2b 2b 3b 20 7d 0a 20 20 20 20 69 66 28 20 72  z++; }.    if( r
0bb0: 65 61 6c 6e 75 6d 20 29 20 2a 72 65 61 6c 6e 75  ealnum ) *realnu
0bc0: 6d 20 3d 20 31 3b 0a 20 20 7d 0a 20 20 72 65 74  m = 1;.  }.  ret
0bd0: 75 72 6e 20 2a 7a 3d 3d 30 3b 0a 7d 0a 0a 2f 2a  urn *z==0;.}../*
0be0: 0a 2a 2a 20 41 20 67 6c 6f 62 61 6c 20 63 68 61  .** A global cha
0bf0: 72 2a 20 61 6e 64 20 61 6e 20 53 51 4c 20 66 75  r* and an SQL fu
0c00: 6e 63 74 69 6f 6e 20 74 6f 20 61 63 63 65 73 73  nction to access
0c10: 20 69 74 73 20 63 75 72 72 65 6e 74 20 76 61 6c   its current val
0c20: 75 65 20 0a 2a 2a 20 66 72 6f 6d 20 77 69 74 68  ue .** from with
0c30: 69 6e 20 61 6e 20 53 51 4c 20 73 74 61 74 65 6d  in an SQL statem
0c40: 65 6e 74 2e 20 54 68 69 73 20 70 72 6f 67 72 61  ent. This progra
0c50: 6d 20 75 73 65 64 20 74 6f 20 75 73 65 20 74 68  m used to use th
0c60: 65 20 0a 2a 2a 20 73 71 6c 69 74 65 5f 65 78 65  e .** sqlite_exe
0c70: 63 5f 70 72 69 6e 74 66 28 29 20 41 50 49 20 74  c_printf() API t
0c80: 6f 20 73 75 62 73 74 69 74 75 65 20 61 20 73 74  o substitue a st
0c90: 72 69 6e 67 20 69 6e 74 6f 20 61 6e 20 53 51 4c  ring into an SQL
0ca0: 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2a 20 54   statement..** T
0cb0: 68 65 20 63 6f 72 72 65 63 74 20 77 61 79 20 74  he correct way t
0cc0: 6f 20 64 6f 20 74 68 69 73 20 77 69 74 68 20 73  o do this with s
0cd0: 71 6c 69 74 65 33 20 69 73 20 74 6f 20 75 73 65  qlite3 is to use
0ce0: 20 74 68 65 20 62 69 6e 64 20 41 50 49 2c 20 62   the bind API, b
0cf0: 75 74 0a 2a 2a 20 73 69 6e 63 65 20 74 68 65 20  ut.** since the 
0d00: 73 68 65 6c 6c 20 69 73 20 62 75 69 6c 74 20 61  shell is built a
0d10: 72 6f 75 6e 64 20 74 68 65 20 63 61 6c 6c 62 61  round the callba
0d20: 63 6b 20 70 61 72 61 64 69 67 6d 20 69 74 20 77  ck paradigm it w
0d30: 6f 75 6c 64 20 62 65 20 61 20 6c 6f 74 0a 2a 2a  ould be a lot.**
0d40: 20 6f 66 20 77 6f 72 6b 2e 20 49 6e 73 74 65 61   of work. Instea
0d50: 64 20 6a 75 73 74 20 75 73 65 20 74 68 69 73 20  d just use this 
0d60: 68 61 63 6b 2c 20 77 68 69 63 68 20 69 73 20 71  hack, which is q
0d70: 75 69 74 65 20 68 61 72 6d 6c 65 73 73 2e 0a 2a  uite harmless..*
0d80: 2f 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20 63  /.static const c
0d90: 68 61 72 20 2a 7a 53 68 65 6c 6c 53 74 61 74 69  har *zShellStati
0da0: 63 20 3d 20 30 3b 0a 73 74 61 74 69 63 20 76 6f  c = 0;.static vo
0db0: 69 64 20 73 68 65 6c 6c 73 74 61 74 69 63 46 75  id shellstaticFu
0dc0: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
0dd0: 6e 74 65 78 74 20 2a 63 6f 6e 74 65 78 74 2c 0a  ntext *context,.
0de0: 20 20 69 6e 74 20 61 72 67 63 2c 0a 20 20 73 71    int argc,.  sq
0df0: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 72  lite3_value **ar
0e00: 67 76 0a 29 7b 0a 20 20 61 73 73 65 72 74 28 20  gv.){.  assert( 
0e10: 30 3d 3d 61 72 67 63 20 29 3b 0a 20 20 61 73 73  0==argc );.  ass
0e20: 65 72 74 28 20 7a 53 68 65 6c 6c 53 74 61 74 69  ert( zShellStati
0e30: 63 20 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 72  c );.  sqlite3_r
0e40: 65 73 75 6c 74 5f 74 65 78 74 28 63 6f 6e 74 65  esult_text(conte
0e50: 78 74 2c 20 7a 53 68 65 6c 6c 53 74 61 74 69 63  xt, zShellStatic
0e60: 2c 20 2d 31 2c 20 53 51 4c 49 54 45 5f 53 54 41  , -1, SQLITE_STA
0e70: 54 49 43 29 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20  TIC);.}.../*.** 
0e80: 54 68 69 73 20 72 6f 75 74 69 6e 65 20 72 65 61  This routine rea
0e90: 64 73 20 61 20 6c 69 6e 65 20 6f 66 20 74 65 78  ds a line of tex
0ea0: 74 20 66 72 6f 6d 20 46 49 4c 45 20 69 6e 2c 20  t from FILE in, 
0eb0: 73 74 6f 72 65 73 0a 2a 2a 20 74 68 65 20 74 65  stores.** the te
0ec0: 78 74 20 69 6e 20 6d 65 6d 6f 72 79 20 6f 62 74  xt in memory obt
0ed0: 61 69 6e 65 64 20 66 72 6f 6d 20 6d 61 6c 6c 6f  ained from mallo
0ee0: 63 28 29 20 61 6e 64 20 72 65 74 75 72 6e 73 20  c() and returns 
0ef0: 61 20 70 6f 69 6e 74 65 72 0a 2a 2a 20 74 6f 20  a pointer.** to 
0f00: 74 68 65 20 74 65 78 74 2e 20 20 4e 55 4c 4c 20  the text.  NULL 
0f10: 69 73 20 72 65 74 75 72 6e 65 64 20 61 74 20 65  is returned at e
0f20: 6e 64 20 6f 66 20 66 69 6c 65 2c 20 6f 72 20 69  nd of file, or i
0f30: 66 20 6d 61 6c 6c 6f 63 28 29 0a 2a 2a 20 66 61  f malloc().** fa
0f40: 69 6c 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 69  ils..**.** The i
0f50: 6e 74 65 72 66 61 63 65 20 69 73 20 6c 69 6b 65  nterface is like
0f60: 20 22 72 65 61 64 6c 69 6e 65 22 20 62 75 74 20   "readline" but 
0f70: 6e 6f 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65 20  no command-line 
0f80: 65 64 69 74 69 6e 67 0a 2a 2a 20 69 73 20 64 6f  editing.** is do
0f90: 6e 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 63 68  ne..*/.static ch
0fa0: 61 72 20 2a 6c 6f 63 61 6c 5f 67 65 74 6c 69 6e  ar *local_getlin
0fb0: 65 28 63 68 61 72 20 2a 7a 50 72 6f 6d 70 74 2c  e(char *zPrompt,
0fc0: 20 46 49 4c 45 20 2a 69 6e 29 7b 0a 20 20 63 68   FILE *in){.  ch
0fd0: 61 72 20 2a 7a 4c 69 6e 65 3b 0a 20 20 69 6e 74  ar *zLine;.  int
0fe0: 20 6e 4c 69 6e 65 3b 0a 20 20 69 6e 74 20 6e 3b   nLine;.  int n;
0ff0: 0a 20 20 69 6e 74 20 65 6f 6c 3b 0a 0a 20 20 69  .  int eol;..  i
1000: 66 28 20 7a 50 72 6f 6d 70 74 20 26 26 20 2a 7a  f( zPrompt && *z
1010: 50 72 6f 6d 70 74 20 29 7b 0a 20 20 20 20 70 72  Prompt ){.    pr
1020: 69 6e 74 66 28 22 25 73 22 2c 7a 50 72 6f 6d 70  intf("%s",zPromp
1030: 74 29 3b 0a 20 20 20 20 66 66 6c 75 73 68 28 73  t);.    fflush(s
1040: 74 64 6f 75 74 29 3b 0a 20 20 7d 0a 20 20 6e 4c  tdout);.  }.  nL
1050: 69 6e 65 20 3d 20 31 30 30 3b 0a 20 20 7a 4c 69  ine = 100;.  zLi
1060: 6e 65 20 3d 20 6d 61 6c 6c 6f 63 28 20 6e 4c 69  ne = malloc( nLi
1070: 6e 65 20 29 3b 0a 20 20 69 66 28 20 7a 4c 69 6e  ne );.  if( zLin
1080: 65 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b  e==0 ) return 0;
1090: 0a 20 20 6e 20 3d 20 30 3b 0a 20 20 65 6f 6c 20  .  n = 0;.  eol 
10a0: 3d 20 30 3b 0a 20 20 77 68 69 6c 65 28 20 21 65  = 0;.  while( !e
10b0: 6f 6c 20 29 7b 0a 20 20 20 20 69 66 28 20 6e 2b  ol ){.    if( n+
10c0: 31 30 30 3e 6e 4c 69 6e 65 20 29 7b 0a 20 20 20  100>nLine ){.   
10d0: 20 20 20 6e 4c 69 6e 65 20 3d 20 6e 4c 69 6e 65     nLine = nLine
10e0: 2a 32 20 2b 20 31 30 30 3b 0a 20 20 20 20 20 20  *2 + 100;.      
10f0: 7a 4c 69 6e 65 20 3d 20 72 65 61 6c 6c 6f 63 28  zLine = realloc(
1100: 7a 4c 69 6e 65 2c 20 6e 4c 69 6e 65 29 3b 0a 20  zLine, nLine);. 
1110: 20 20 20 20 20 69 66 28 20 7a 4c 69 6e 65 3d 3d       if( zLine==
1120: 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  0 ) return 0;.  
1130: 20 20 7d 0a 20 20 20 20 69 66 28 20 66 67 65 74    }.    if( fget
1140: 73 28 26 7a 4c 69 6e 65 5b 6e 5d 2c 20 6e 4c 69  s(&zLine[n], nLi
1150: 6e 65 20 2d 20 6e 2c 20 69 6e 29 3d 3d 30 20 29  ne - n, in)==0 )
1160: 7b 0a 20 20 20 20 20 20 69 66 28 20 6e 3d 3d 30  {.      if( n==0
1170: 20 29 7b 0a 20 20 20 20 20 20 20 20 66 72 65 65   ){.        free
1180: 28 7a 4c 69 6e 65 29 3b 0a 20 20 20 20 20 20 20  (zLine);.       
1190: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 20   return 0;.     
11a0: 20 7d 0a 20 20 20 20 20 20 7a 4c 69 6e 65 5b 6e   }.      zLine[n
11b0: 5d 20 3d 20 30 3b 0a 20 20 20 20 20 20 65 6f 6c  ] = 0;.      eol
11c0: 20 3d 20 31 3b 0a 20 20 20 20 20 20 62 72 65 61   = 1;.      brea
11d0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 77 68 69  k;.    }.    whi
11e0: 6c 65 28 20 7a 4c 69 6e 65 5b 6e 5d 20 29 7b 20  le( zLine[n] ){ 
11f0: 6e 2b 2b 3b 20 7d 0a 20 20 20 20 69 66 28 20 6e  n++; }.    if( n
1200: 3e 30 20 26 26 20 7a 4c 69 6e 65 5b 6e 2d 31 5d  >0 && zLine[n-1]
1210: 3d 3d 27 5c 6e 27 20 29 7b 0a 20 20 20 20 20 20  =='\n' ){.      
1220: 6e 2d 2d 3b 0a 20 20 20 20 20 20 7a 4c 69 6e 65  n--;.      zLine
1230: 5b 6e 5d 20 3d 20 30 3b 0a 20 20 20 20 20 20 65  [n] = 0;.      e
1240: 6f 6c 20 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20  ol = 1;.    }.  
1250: 7d 0a 20 20 7a 4c 69 6e 65 20 3d 20 72 65 61 6c  }.  zLine = real
1260: 6c 6f 63 28 20 7a 4c 69 6e 65 2c 20 6e 2b 31 20  loc( zLine, n+1 
1270: 29 3b 0a 20 20 72 65 74 75 72 6e 20 7a 4c 69 6e  );.  return zLin
1280: 65 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 72  e;.}../*.** Retr
1290: 69 65 76 65 20 61 20 73 69 6e 67 6c 65 20 6c 69  ieve a single li
12a0: 6e 65 20 6f 66 20 69 6e 70 75 74 20 74 65 78 74  ne of input text
12b0: 2e 0a 2a 2a 0a 2a 2a 20 7a 50 72 69 6f 72 20 69  ..**.** zPrior i
12c0: 73 20 61 20 73 74 72 69 6e 67 20 6f 66 20 70 72  s a string of pr
12d0: 69 6f 72 20 74 65 78 74 20 72 65 74 72 69 65 76  ior text retriev
12e0: 65 64 2e 20 20 49 66 20 6e 6f 74 20 74 68 65 20  ed.  If not the 
12f0: 65 6d 70 74 79 0a 2a 2a 20 73 74 72 69 6e 67 2c  empty.** string,
1300: 20 74 68 65 6e 20 69 73 73 75 65 20 61 20 63 6f   then issue a co
1310: 6e 74 69 6e 75 61 74 69 6f 6e 20 70 72 6f 6d 70  ntinuation promp
1320: 74 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 63 68 61  t..*/.static cha
1330: 72 20 2a 6f 6e 65 5f 69 6e 70 75 74 5f 6c 69 6e  r *one_input_lin
1340: 65 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50  e(const char *zP
1350: 72 69 6f 72 2c 20 46 49 4c 45 20 2a 69 6e 29 7b  rior, FILE *in){
1360: 0a 20 20 63 68 61 72 20 2a 7a 50 72 6f 6d 70 74  .  char *zPrompt
1370: 3b 0a 20 20 63 68 61 72 20 2a 7a 52 65 73 75 6c  ;.  char *zResul
1380: 74 3b 0a 20 20 69 66 28 20 69 6e 21 3d 30 20 29  t;.  if( in!=0 )
1390: 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 6c 6f 63  {.    return loc
13a0: 61 6c 5f 67 65 74 6c 69 6e 65 28 30 2c 20 69 6e  al_getline(0, in
13b0: 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 7a 50 72  );.  }.  if( zPr
13c0: 69 6f 72 20 26 26 20 7a 50 72 69 6f 72 5b 30 5d  ior && zPrior[0]
13d0: 20 29 7b 0a 20 20 20 20 7a 50 72 6f 6d 70 74 20   ){.    zPrompt 
13e0: 3d 20 63 6f 6e 74 69 6e 75 65 50 72 6f 6d 70 74  = continuePrompt
13f0: 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 7a  ;.  }else{.    z
1400: 50 72 6f 6d 70 74 20 3d 20 6d 61 69 6e 50 72 6f  Prompt = mainPro
1410: 6d 70 74 3b 0a 20 20 7d 0a 20 20 7a 52 65 73 75  mpt;.  }.  zResu
1420: 6c 74 20 3d 20 72 65 61 64 6c 69 6e 65 28 7a 50  lt = readline(zP
1430: 72 6f 6d 70 74 29 3b 0a 23 69 66 20 64 65 66 69  rompt);.#if defi
1440: 6e 65 64 28 48 41 56 45 5f 52 45 41 44 4c 49 4e  ned(HAVE_READLIN
1450: 45 29 20 26 26 20 48 41 56 45 5f 52 45 41 44 4c  E) && HAVE_READL
1460: 49 4e 45 3d 3d 31 0a 20 20 69 66 28 20 7a 52 65  INE==1.  if( zRe
1470: 73 75 6c 74 20 26 26 20 2a 7a 52 65 73 75 6c 74  sult && *zResult
1480: 20 29 20 61 64 64 5f 68 69 73 74 6f 72 79 28 7a   ) add_history(z
1490: 52 65 73 75 6c 74 29 3b 0a 23 65 6e 64 69 66 0a  Result);.#endif.
14a0: 20 20 72 65 74 75 72 6e 20 7a 52 65 73 75 6c 74    return zResult
14b0: 3b 0a 7d 0a 0a 73 74 72 75 63 74 20 70 72 65 76  ;.}..struct prev
14c0: 69 6f 75 73 5f 6d 6f 64 65 5f 64 61 74 61 20 7b  ious_mode_data {
14d0: 0a 20 20 69 6e 74 20 76 61 6c 69 64 3b 20 20 20  .  int valid;   
14e0: 20 20 20 20 20 2f 2a 20 49 73 20 74 68 65 72 65       /* Is there
14f0: 20 6c 65 67 69 74 20 64 61 74 61 20 69 6e 20 68   legit data in h
1500: 65 72 65 3f 20 2a 2f 0a 20 20 69 6e 74 20 6d 6f  ere? */.  int mo
1510: 64 65 3b 0a 20 20 69 6e 74 20 73 68 6f 77 48 65  de;.  int showHe
1520: 61 64 65 72 3b 0a 20 20 69 6e 74 20 63 6f 6c 57  ader;.  int colW
1530: 69 64 74 68 5b 31 30 30 5d 3b 0a 7d 3b 0a 0a 2f  idth[100];.};../
1540: 2a 0a 2a 2a 20 41 6e 20 70 6f 69 6e 74 65 72 20  *.** An pointer 
1550: 74 6f 20 61 6e 20 69 6e 73 74 61 6e 63 65 20 6f  to an instance o
1560: 66 20 74 68 69 73 20 73 74 72 75 63 74 75 72 65  f this structure
1570: 20 69 73 20 70 61 73 73 65 64 20 66 72 6f 6d 0a   is passed from.
1580: 2a 2a 20 74 68 65 20 6d 61 69 6e 20 70 72 6f 67  ** the main prog
1590: 72 61 6d 20 74 6f 20 74 68 65 20 63 61 6c 6c 62  ram to the callb
15a0: 61 63 6b 2e 20 20 54 68 69 73 20 69 73 20 75 73  ack.  This is us
15b0: 65 64 20 74 6f 20 63 6f 6d 6d 75 6e 69 63 61 74  ed to communicat
15c0: 65 0a 2a 2a 20 73 74 61 74 65 20 61 6e 64 20 6d  e.** state and m
15d0: 6f 64 65 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 2e  ode information.
15e0: 0a 2a 2f 0a 73 74 72 75 63 74 20 63 61 6c 6c 62  .*/.struct callb
15f0: 61 63 6b 5f 64 61 74 61 20 7b 0a 20 20 73 71 6c  ack_data {.  sql
1600: 69 74 65 33 20 2a 64 62 3b 20 20 20 20 20 20 20  ite3 *db;       
1610: 20 20 20 20 20 2f 2a 20 54 68 65 20 64 61 74 61       /* The data
1620: 62 61 73 65 20 2a 2f 0a 20 20 69 6e 74 20 65 63  base */.  int ec
1630: 68 6f 4f 6e 3b 20 20 20 20 20 20 20 20 20 20 20  hoOn;           
1640: 20 2f 2a 20 54 72 75 65 20 74 6f 20 65 63 68 6f   /* True to echo
1650: 20 69 6e 70 75 74 20 63 6f 6d 6d 61 6e 64 73 20   input commands 
1660: 2a 2f 0a 20 20 69 6e 74 20 63 6e 74 3b 20 20 20  */.  int cnt;   
1670: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e              /* N
1680: 75 6d 62 65 72 20 6f 66 20 72 65 63 6f 72 64 73  umber of records
1690: 20 64 69 73 70 6c 61 79 65 64 20 73 6f 20 66 61   displayed so fa
16a0: 72 20 2a 2f 0a 20 20 46 49 4c 45 20 2a 6f 75 74  r */.  FILE *out
16b0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ;             /*
16c0: 20 57 72 69 74 65 20 72 65 73 75 6c 74 73 20 68   Write results h
16d0: 65 72 65 20 2a 2f 0a 20 20 69 6e 74 20 6d 6f 64  ere */.  int mod
16e0: 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e;              
16f0: 2f 2a 20 41 6e 20 6f 75 74 70 75 74 20 6d 6f 64  /* An output mod
1700: 65 20 73 65 74 74 69 6e 67 20 2a 2f 0a 20 20 69  e setting */.  i
1710: 6e 74 20 77 72 69 74 61 62 6c 65 53 63 68 65 6d  nt writableSchem
1720: 61 3b 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66  a;    /* True if
1730: 20 50 52 41 47 4d 41 20 77 72 69 74 61 62 6c 65   PRAGMA writable
1740: 5f 73 63 68 65 6d 61 3d 4f 4e 20 2a 2f 0a 20 20  _schema=ON */.  
1750: 69 6e 74 20 73 68 6f 77 48 65 61 64 65 72 3b 20  int showHeader; 
1760: 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 74         /* True t
1770: 6f 20 73 68 6f 77 20 63 6f 6c 75 6d 6e 20 6e 61  o show column na
1780: 6d 65 73 20 69 6e 20 4c 69 73 74 20 6f 72 20 43  mes in List or C
1790: 6f 6c 75 6d 6e 20 6d 6f 64 65 20 2a 2f 0a 20 20  olumn mode */.  
17a0: 63 68 61 72 20 2a 7a 44 65 73 74 54 61 62 6c 65  char *zDestTable
17b0: 3b 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f  ;      /* Name o
17c0: 66 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 74 61  f destination ta
17d0: 62 6c 65 20 77 68 65 6e 20 4d 4f 44 45 5f 49 6e  ble when MODE_In
17e0: 73 65 72 74 20 2a 2f 0a 20 20 63 68 61 72 20 73  sert */.  char s
17f0: 65 70 61 72 61 74 6f 72 5b 32 30 5d 3b 20 20 20  eparator[20];   
1800: 20 2f 2a 20 53 65 70 61 72 61 74 6f 72 20 63 68   /* Separator ch
1810: 61 72 61 63 74 65 72 20 66 6f 72 20 4d 4f 44 45  aracter for MODE
1820: 5f 4c 69 73 74 20 2a 2f 0a 20 20 69 6e 74 20 63  _List */.  int c
1830: 6f 6c 57 69 64 74 68 5b 31 30 30 5d 3b 20 20 20  olWidth[100];   
1840: 20 20 2f 2a 20 52 65 71 75 65 73 74 65 64 20 77    /* Requested w
1850: 69 64 74 68 20 6f 66 20 65 61 63 68 20 63 6f 6c  idth of each col
1860: 75 6d 6e 20 77 68 65 6e 20 69 6e 20 63 6f 6c 75  umn when in colu
1870: 6d 6e 20 6d 6f 64 65 2a 2f 0a 20 20 69 6e 74 20  mn mode*/.  int 
1880: 61 63 74 75 61 6c 57 69 64 74 68 5b 31 30 30 5d  actualWidth[100]
1890: 3b 20 20 2f 2a 20 41 63 74 75 61 6c 20 77 69 64  ;  /* Actual wid
18a0: 74 68 20 6f 66 20 65 61 63 68 20 63 6f 6c 75 6d  th of each colum
18b0: 6e 20 2a 2f 0a 20 20 63 68 61 72 20 6e 75 6c 6c  n */.  char null
18c0: 76 61 6c 75 65 5b 32 30 5d 3b 20 20 20 20 2f 2a  value[20];    /*
18d0: 20 54 68 65 20 74 65 78 74 20 74 6f 20 70 72 69   The text to pri
18e0: 6e 74 20 77 68 65 6e 20 61 20 4e 55 4c 4c 20 63  nt when a NULL c
18f0: 6f 6d 65 73 20 62 61 63 6b 20 66 72 6f 6d 0a 20  omes back from. 
1900: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1910: 20 20 20 20 20 20 20 20 2a 2a 20 74 68 65 20 64          ** the d
1920: 61 74 61 62 61 73 65 20 2a 2f 0a 20 20 73 74 72  atabase */.  str
1930: 75 63 74 20 70 72 65 76 69 6f 75 73 5f 6d 6f 64  uct previous_mod
1940: 65 5f 64 61 74 61 20 65 78 70 6c 61 69 6e 50 72  e_data explainPr
1950: 65 76 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  ev;.            
1960: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1970: 48 6f 6c 64 73 20 74 68 65 20 6d 6f 64 65 20 69  Holds the mode i
1980: 6e 66 6f 72 6d 61 74 69 6f 6e 20 6a 75 73 74 20  nformation just 
1990: 62 65 66 6f 72 65 0a 20 20 20 20 20 20 20 20 20  before.         
19a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
19b0: 2a 2a 20 2e 65 78 70 6c 61 69 6e 20 4f 4e 20 2a  ** .explain ON *
19c0: 2f 0a 20 20 63 68 61 72 20 6f 75 74 66 69 6c 65  /.  char outfile
19d0: 5b 46 49 4c 45 4e 41 4d 45 5f 4d 41 58 5d 3b 20  [FILENAME_MAX]; 
19e0: 2f 2a 20 46 69 6c 65 6e 61 6d 65 20 66 6f 72 20  /* Filename for 
19f0: 2a 6f 75 74 20 2a 2f 0a 20 20 63 6f 6e 73 74 20  *out */.  const 
1a00: 63 68 61 72 20 2a 7a 44 62 46 69 6c 65 6e 61 6d  char *zDbFilenam
1a10: 65 3b 20 20 20 20 2f 2a 20 6e 61 6d 65 20 6f 66  e;    /* name of
1a20: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 66 69   the database fi
1a30: 6c 65 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  le */.};../*.** 
1a40: 54 68 65 73 65 20 61 72 65 20 74 68 65 20 61 6c  These are the al
1a50: 6c 6f 77 65 64 20 6d 6f 64 65 73 2e 0a 2a 2f 0a  lowed modes..*/.
1a60: 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 4c 69 6e  #define MODE_Lin
1a70: 65 20 20 20 20 20 30 20 20 2f 2a 20 4f 6e 65 20  e     0  /* One 
1a80: 63 6f 6c 75 6d 6e 20 70 65 72 20 6c 69 6e 65 2e  column per line.
1a90: 20 20 42 6c 61 6e 6b 20 6c 69 6e 65 20 62 65 74    Blank line bet
1aa0: 77 65 65 6e 20 72 65 63 6f 72 64 73 20 2a 2f 0a  ween records */.
1ab0: 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 43 6f 6c  #define MODE_Col
1ac0: 75 6d 6e 20 20 20 31 20 20 2f 2a 20 4f 6e 65 20  umn   1  /* One 
1ad0: 72 65 63 6f 72 64 20 70 65 72 20 6c 69 6e 65 20  record per line 
1ae0: 69 6e 20 6e 65 61 74 20 63 6f 6c 75 6d 6e 73 20  in neat columns 
1af0: 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f  */.#define MODE_
1b00: 4c 69 73 74 20 20 20 20 20 32 20 20 2f 2a 20 4f  List     2  /* O
1b10: 6e 65 20 72 65 63 6f 72 64 20 70 65 72 20 6c 69  ne record per li
1b20: 6e 65 20 77 69 74 68 20 61 20 73 65 70 61 72 61  ne with a separa
1b30: 74 6f 72 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d  tor */.#define M
1b40: 4f 44 45 5f 53 65 6d 69 20 20 20 20 20 33 20 20  ODE_Semi     3  
1b50: 2f 2a 20 53 61 6d 65 20 61 73 20 4d 4f 44 45 5f  /* Same as MODE_
1b60: 4c 69 73 74 20 62 75 74 20 61 70 70 65 6e 64 20  List but append 
1b70: 22 3b 22 20 74 6f 20 65 61 63 68 20 6c 69 6e 65  ";" to each line
1b80: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45   */.#define MODE
1b90: 5f 48 74 6d 6c 20 20 20 20 20 34 20 20 2f 2a 20  _Html     4  /* 
1ba0: 47 65 6e 65 72 61 74 65 20 61 6e 20 58 48 54 4d  Generate an XHTM
1bb0: 4c 20 74 61 62 6c 65 20 2a 2f 0a 23 64 65 66 69  L table */.#defi
1bc0: 6e 65 20 4d 4f 44 45 5f 49 6e 73 65 72 74 20 20  ne MODE_Insert  
1bd0: 20 35 20 20 2f 2a 20 47 65 6e 65 72 61 74 65 20   5  /* Generate 
1be0: 53 51 4c 20 22 69 6e 73 65 72 74 22 20 73 74 61  SQL "insert" sta
1bf0: 74 65 6d 65 6e 74 73 20 2a 2f 0a 23 64 65 66 69  tements */.#defi
1c00: 6e 65 20 4d 4f 44 45 5f 54 63 6c 20 20 20 20 20  ne MODE_Tcl     
1c10: 20 36 20 20 2f 2a 20 47 65 6e 65 72 61 74 65 20   6  /* Generate 
1c20: 41 4e 53 49 2d 43 20 6f 72 20 54 43 4c 20 71 75  ANSI-C or TCL qu
1c30: 6f 74 65 64 20 65 6c 65 6d 65 6e 74 73 20 2a 2f  oted elements */
1c40: 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 43 73  .#define MODE_Cs
1c50: 76 20 20 20 20 20 20 37 20 20 2f 2a 20 51 75 6f  v      7  /* Quo
1c60: 74 65 20 73 74 72 69 6e 67 73 2c 20 6e 75 6d 62  te strings, numb
1c70: 65 72 73 20 61 72 65 20 70 6c 61 69 6e 20 2a 2f  ers are plain */
1c80: 0a 23 64 65 66 69 6e 65 20 4d 4f 44 45 5f 4e 55  .#define MODE_NU
1c90: 4d 5f 4f 46 20 20 20 38 20 20 2f 2a 20 54 68 65  M_OF   8  /* The
1ca0: 20 6e 75 6d 62 65 72 20 6f 66 20 6d 6f 64 65 73   number of modes
1cb0: 20 28 6e 6f 74 20 61 20 6d 6f 64 65 20 69 74 73   (not a mode its
1cc0: 65 6c 66 29 20 2a 2f 0a 0a 73 74 61 74 69 63 20  elf) */..static 
1cd0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 6d 6f 64 65  const char *mode
1ce0: 44 65 73 63 72 5b 4d 4f 44 45 5f 4e 55 4d 5f 4f  Descr[MODE_NUM_O
1cf0: 46 5d 20 3d 20 7b 0a 20 20 22 6c 69 6e 65 22 2c  F] = {.  "line",
1d00: 0a 20 20 22 63 6f 6c 75 6d 6e 22 2c 0a 20 20 22  .  "column",.  "
1d10: 6c 69 73 74 22 2c 0a 20 20 22 73 65 6d 69 22 2c  list",.  "semi",
1d20: 0a 20 20 22 68 74 6d 6c 22 2c 0a 20 20 22 69 6e  .  "html",.  "in
1d30: 73 65 72 74 22 2c 0a 20 20 22 74 63 6c 22 2c 0a  sert",.  "tcl",.
1d40: 20 20 22 63 73 76 22 2c 0a 7d 3b 0a 0a 2f 2a 0a    "csv",.};../*.
1d50: 2a 2a 20 4e 75 6d 62 65 72 20 6f 66 20 65 6c 65  ** Number of ele
1d60: 6d 65 6e 74 73 20 69 6e 20 61 6e 20 61 72 72 61  ments in an arra
1d70: 79 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 41 72 72  y.*/.#define Arr
1d80: 61 79 53 69 7a 65 28 58 29 20 20 28 73 69 7a 65  aySize(X)  (size
1d90: 6f 66 28 58 29 2f 73 69 7a 65 6f 66 28 58 5b 30  of(X)/sizeof(X[0
1da0: 5d 29 29 0a 0a 2f 2a 0a 2a 2a 20 4f 75 74 70 75  ]))../*.** Outpu
1db0: 74 20 74 68 65 20 67 69 76 65 6e 20 73 74 72 69  t the given stri
1dc0: 6e 67 20 61 73 20 61 20 71 75 6f 74 65 64 20 73  ng as a quoted s
1dd0: 74 72 69 6e 67 20 75 73 69 6e 67 20 53 51 4c 20  tring using SQL 
1de0: 71 75 6f 74 69 6e 67 20 63 6f 6e 76 65 6e 74 69  quoting conventi
1df0: 6f 6e 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76  ons..*/.static v
1e00: 6f 69 64 20 6f 75 74 70 75 74 5f 71 75 6f 74 65  oid output_quote
1e10: 64 5f 73 74 72 69 6e 67 28 46 49 4c 45 20 2a 6f  d_string(FILE *o
1e20: 75 74 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ut, const char *
1e30: 7a 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 69  z){.  int i;.  i
1e40: 6e 74 20 6e 53 69 6e 67 6c 65 20 3d 20 30 3b 0a  nt nSingle = 0;.
1e50: 20 20 66 6f 72 28 69 3d 30 3b 20 7a 5b 69 5d 3b    for(i=0; z[i];
1e60: 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 7a   i++){.    if( z
1e70: 5b 69 5d 3d 3d 27 5c 27 27 20 29 20 6e 53 69 6e  [i]=='\'' ) nSin
1e80: 67 6c 65 2b 2b 3b 0a 20 20 7d 0a 20 20 69 66 28  gle++;.  }.  if(
1e90: 20 6e 53 69 6e 67 6c 65 3d 3d 30 20 29 7b 0a 20   nSingle==0 ){. 
1ea0: 20 20 20 66 70 72 69 6e 74 66 28 6f 75 74 2c 22     fprintf(out,"
1eb0: 27 25 73 27 22 2c 7a 29 3b 0a 20 20 7d 65 6c 73  '%s'",z);.  }els
1ec0: 65 7b 0a 20 20 20 20 66 70 72 69 6e 74 66 28 6f  e{.    fprintf(o
1ed0: 75 74 2c 22 27 22 29 3b 0a 20 20 20 20 77 68 69  ut,"'");.    whi
1ee0: 6c 65 28 20 2a 7a 20 29 7b 0a 20 20 20 20 20 20  le( *z ){.      
1ef0: 66 6f 72 28 69 3d 30 3b 20 7a 5b 69 5d 20 26 26  for(i=0; z[i] &&
1f00: 20 7a 5b 69 5d 21 3d 27 5c 27 27 3b 20 69 2b 2b   z[i]!='\''; i++
1f10: 29 7b 7d 0a 20 20 20 20 20 20 69 66 28 20 69 3d  ){}.      if( i=
1f20: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 66 70  =0 ){.        fp
1f30: 72 69 6e 74 66 28 6f 75 74 2c 22 27 27 22 29 3b  rintf(out,"''");
1f40: 0a 20 20 20 20 20 20 20 20 7a 2b 2b 3b 0a 20 20  .        z++;.  
1f50: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 7a 5b      }else if( z[
1f60: 69 5d 3d 3d 27 5c 27 27 20 29 7b 0a 20 20 20 20  i]=='\'' ){.    
1f70: 20 20 20 20 66 70 72 69 6e 74 66 28 6f 75 74 2c      fprintf(out,
1f80: 22 25 2e 2a 73 27 27 22 2c 69 2c 7a 29 3b 0a 20  "%.*s''",i,z);. 
1f90: 20 20 20 20 20 20 20 7a 20 2b 3d 20 69 2b 31 3b         z += i+1;
1fa0: 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  .      }else{.  
1fb0: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 6f 75        fprintf(ou
1fc0: 74 2c 22 25 73 22 2c 7a 29 3b 0a 20 20 20 20 20  t,"%s",z);.     
1fd0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
1fe0: 7d 0a 20 20 20 20 7d 0a 20 20 20 20 66 70 72 69  }.    }.    fpri
1ff0: 6e 74 66 28 6f 75 74 2c 22 27 22 29 3b 0a 20 20  ntf(out,"'");.  
2000: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4f 75 74 70 75  }.}../*.** Outpu
2010: 74 20 74 68 65 20 67 69 76 65 6e 20 73 74 72 69  t the given stri
2020: 6e 67 20 61 73 20 61 20 71 75 6f 74 65 64 20 61  ng as a quoted a
2030: 63 63 6f 72 64 69 6e 67 20 74 6f 20 43 20 6f 72  ccording to C or
2040: 20 54 43 4c 20 71 75 6f 74 69 6e 67 20 72 75 6c   TCL quoting rul
2050: 65 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  es..*/.static vo
2060: 69 64 20 6f 75 74 70 75 74 5f 63 5f 73 74 72 69  id output_c_stri
2070: 6e 67 28 46 49 4c 45 20 2a 6f 75 74 2c 20 63 6f  ng(FILE *out, co
2080: 6e 73 74 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20  nst char *z){.  
2090: 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 63 3b 0a  unsigned int c;.
20a0: 20 20 66 70 75 74 63 28 27 22 27 2c 20 6f 75 74    fputc('"', out
20b0: 29 3b 0a 20 20 77 68 69 6c 65 28 20 28 63 20 3d  );.  while( (c =
20c0: 20 2a 28 7a 2b 2b 29 29 21 3d 30 20 29 7b 0a 20   *(z++))!=0 ){. 
20d0: 20 20 20 69 66 28 20 63 3d 3d 27 5c 5c 27 20 29     if( c=='\\' )
20e0: 7b 0a 20 20 20 20 20 20 66 70 75 74 63 28 63 2c  {.      fputc(c,
20f0: 20 6f 75 74 29 3b 0a 20 20 20 20 20 20 66 70 75   out);.      fpu
2100: 74 63 28 63 2c 20 6f 75 74 29 3b 0a 20 20 20 20  tc(c, out);.    
2110: 7d 65 6c 73 65 20 69 66 28 20 63 3d 3d 27 5c 74  }else if( c=='\t
2120: 27 20 29 7b 0a 20 20 20 20 20 20 66 70 75 74 63  ' ){.      fputc
2130: 28 27 5c 5c 27 2c 20 6f 75 74 29 3b 0a 20 20 20  ('\\', out);.   
2140: 20 20 20 66 70 75 74 63 28 27 74 27 2c 20 6f 75     fputc('t', ou
2150: 74 29 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66  t);.    }else if
2160: 28 20 63 3d 3d 27 5c 6e 27 20 29 7b 0a 20 20 20  ( c=='\n' ){.   
2170: 20 20 20 66 70 75 74 63 28 27 5c 5c 27 2c 20 6f     fputc('\\', o
2180: 75 74 29 3b 0a 20 20 20 20 20 20 66 70 75 74 63  ut);.      fputc
2190: 28 27 6e 27 2c 20 6f 75 74 29 3b 0a 20 20 20 20  ('n', out);.    
21a0: 7d 65 6c 73 65 20 69 66 28 20 63 3d 3d 27 5c 72  }else if( c=='\r
21b0: 27 20 29 7b 0a 20 20 20 20 20 20 66 70 75 74 63  ' ){.      fputc
21c0: 28 27 5c 5c 27 2c 20 6f 75 74 29 3b 0a 20 20 20  ('\\', out);.   
21d0: 20 20 20 66 70 75 74 63 28 27 72 27 2c 20 6f 75     fputc('r', ou
21e0: 74 29 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66  t);.    }else if
21f0: 28 20 21 69 73 70 72 69 6e 74 28 63 29 20 29 7b  ( !isprint(c) ){
2200: 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 6f  .      fprintf(o
2210: 75 74 2c 20 22 5c 5c 25 30 33 6f 22 2c 20 63 26  ut, "\\%03o", c&
2220: 30 78 66 66 29 3b 0a 20 20 20 20 7d 65 6c 73 65  0xff);.    }else
2230: 7b 0a 20 20 20 20 20 20 66 70 75 74 63 28 63 2c  {.      fputc(c,
2240: 20 6f 75 74 29 3b 0a 20 20 20 20 7d 0a 20 20 7d   out);.    }.  }
2250: 0a 20 20 66 70 75 74 63 28 27 22 27 2c 20 6f 75  .  fputc('"', ou
2260: 74 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4f 75 74  t);.}../*.** Out
2270: 70 75 74 20 74 68 65 20 67 69 76 65 6e 20 73 74  put the given st
2280: 72 69 6e 67 20 77 69 74 68 20 63 68 61 72 61 63  ring with charac
2290: 74 65 72 73 20 74 68 61 74 20 61 72 65 20 73 70  ters that are sp
22a0: 65 63 69 61 6c 20 74 6f 0a 2a 2a 20 48 54 4d 4c  ecial to.** HTML
22b0: 20 65 73 63 61 70 65 64 2e 0a 2a 2f 0a 73 74 61   escaped..*/.sta
22c0: 74 69 63 20 76 6f 69 64 20 6f 75 74 70 75 74 5f  tic void output_
22d0: 68 74 6d 6c 5f 73 74 72 69 6e 67 28 46 49 4c 45  html_string(FILE
22e0: 20 2a 6f 75 74 2c 20 63 6f 6e 73 74 20 63 68 61   *out, const cha
22f0: 72 20 2a 7a 29 7b 0a 20 20 69 6e 74 20 69 3b 0a  r *z){.  int i;.
2300: 20 20 77 68 69 6c 65 28 20 2a 7a 20 29 7b 0a 20    while( *z ){. 
2310: 20 20 20 66 6f 72 28 69 3d 30 3b 20 7a 5b 69 5d     for(i=0; z[i]
2320: 20 26 26 20 7a 5b 69 5d 21 3d 27 3c 27 20 26 26   && z[i]!='<' &&
2330: 20 7a 5b 69 5d 21 3d 27 26 27 3b 20 69 2b 2b 29   z[i]!='&'; i++)
2340: 7b 7d 0a 20 20 20 20 69 66 28 20 69 3e 30 20 29  {}.    if( i>0 )
2350: 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28  {.      fprintf(
2360: 6f 75 74 2c 22 25 2e 2a 73 22 2c 69 2c 7a 29 3b  out,"%.*s",i,z);
2370: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 7a  .    }.    if( z
2380: 5b 69 5d 3d 3d 27 3c 27 20 29 7b 0a 20 20 20 20  [i]=='<' ){.    
2390: 20 20 66 70 72 69 6e 74 66 28 6f 75 74 2c 22 26    fprintf(out,"&
23a0: 6c 74 3b 22 29 3b 0a 20 20 20 20 7d 65 6c 73 65  lt;");.    }else
23b0: 20 69 66 28 20 7a 5b 69 5d 3d 3d 27 26 27 20 29   if( z[i]=='&' )
23c0: 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28  {.      fprintf(
23d0: 6f 75 74 2c 22 26 61 6d 70 3b 22 29 3b 0a 20 20  out,"&amp;");.  
23e0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 62    }else{.      b
23f0: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  reak;.    }.    
2400: 7a 20 2b 3d 20 69 20 2b 20 31 3b 0a 20 20 7d 0a  z += i + 1;.  }.
2410: 7d 0a 0a 2f 2a 0a 2a 2a 20 49 66 20 61 20 66 69  }../*.** If a fi
2420: 65 6c 64 20 63 6f 6e 74 61 69 6e 73 20 61 6e 79  eld contains any
2430: 20 63 68 61 72 61 63 74 65 72 20 69 64 65 6e 74   character ident
2440: 69 66 69 65 64 20 62 79 20 61 20 31 20 69 6e 20  ified by a 1 in 
2450: 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 0a 2a 2a  the following.**
2460: 20 61 72 72 61 79 2c 20 74 68 65 6e 20 74 68 65   array, then the
2470: 20 73 74 72 69 6e 67 20 6d 75 73 74 20 62 65 20   string must be 
2480: 71 75 6f 74 65 64 20 66 6f 72 20 43 53 56 2e 0a  quoted for CSV..
2490: 2a 2f 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20  */.static const 
24a0: 63 68 61 72 20 6e 65 65 64 43 73 76 51 75 6f 74  char needCsvQuot
24b0: 65 5b 5d 20 3d 20 7b 0a 20 20 31 2c 20 31 2c 20  e[] = {.  1, 1, 
24c0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31  1, 1, 1, 1, 1, 1
24d0: 2c 20 20 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20  ,   1, 1, 1, 1, 
24e0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 20 20 0a 20  1, 1, 1, 1,   . 
24f0: 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20   1, 1, 1, 1, 1, 
2500: 31 2c 20 31 2c 20 31 2c 20 20 20 31 2c 20 31 2c  1, 1, 1,   1, 1,
2510: 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20   1, 1, 1, 1, 1, 
2520: 31 2c 20 20 20 0a 20 20 31 2c 20 30 2c 20 31 2c  1,   .  1, 0, 1,
2530: 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 31 2c 20   0, 0, 0, 0, 1, 
2540: 20 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c    0, 0, 0, 0, 0,
2550: 20 30 2c 20 30 2c 20 30 2c 20 0a 20 20 30 2c 20   0, 0, 0, .  0, 
2560: 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30  0, 0, 0, 0, 0, 0
2570: 2c 20 30 2c 20 20 20 30 2c 20 30 2c 20 30 2c 20  , 0,   0, 0, 0, 
2580: 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 0a  0, 0, 0, 0, 0, .
2590: 20 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c    0, 0, 0, 0, 0,
25a0: 20 30 2c 20 30 2c 20 30 2c 20 20 20 30 2c 20 30   0, 0, 0,   0, 0
25b0: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c  , 0, 0, 0, 0, 0,
25c0: 20 30 2c 20 0a 20 20 30 2c 20 30 2c 20 30 2c 20   0, .  0, 0, 0, 
25d0: 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 20  0, 0, 0, 0, 0,  
25e0: 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20   0, 0, 0, 0, 0, 
25f0: 30 2c 20 30 2c 20 30 2c 20 0a 20 20 30 2c 20 30  0, 0, 0, .  0, 0
2600: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c  , 0, 0, 0, 0, 0,
2610: 20 30 2c 20 20 20 30 2c 20 30 2c 20 30 2c 20 30   0,   0, 0, 0, 0
2620: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 0a 20  , 0, 0, 0, 0, . 
2630: 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20   0, 0, 0, 0, 0, 
2640: 30 2c 20 30 2c 20 30 2c 20 20 20 30 2c 20 30 2c  0, 0, 0,   0, 0,
2650: 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20 30 2c 20   0, 0, 0, 0, 0, 
2660: 31 2c 20 0a 20 20 31 2c 20 31 2c 20 31 2c 20 31  1, .  1, 1, 1, 1
2670: 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 20 20  , 1, 1, 1, 1,   
2680: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31  1, 1, 1, 1, 1, 1
2690: 2c 20 31 2c 20 31 2c 20 20 20 0a 20 20 31 2c 20  , 1, 1,   .  1, 
26a0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31  1, 1, 1, 1, 1, 1
26b0: 2c 20 31 2c 20 20 20 31 2c 20 31 2c 20 31 2c 20  , 1,   1, 1, 1, 
26c0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 20  1, 1, 1, 1, 1,  
26d0: 20 0a 20 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20   .  1, 1, 1, 1, 
26e0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 20 20 31 2c  1, 1, 1, 1,   1,
26f0: 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20   1, 1, 1, 1, 1, 
2700: 31 2c 20 31 2c 20 20 20 0a 20 20 31 2c 20 31 2c  1, 1,   .  1, 1,
2710: 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20   1, 1, 1, 1, 1, 
2720: 31 2c 20 20 20 31 2c 20 31 2c 20 31 2c 20 31 2c  1,   1, 1, 1, 1,
2730: 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 20 20 0a   1, 1, 1, 1,   .
2740: 20 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c    1, 1, 1, 1, 1,
2750: 20 31 2c 20 31 2c 20 31 2c 20 20 20 31 2c 20 31   1, 1, 1,   1, 1
2760: 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c  , 1, 1, 1, 1, 1,
2770: 20 31 2c 20 20 20 0a 20 20 31 2c 20 31 2c 20 31   1,   .  1, 1, 1
2780: 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c  , 1, 1, 1, 1, 1,
2790: 20 20 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31     1, 1, 1, 1, 1
27a0: 2c 20 31 2c 20 31 2c 20 31 2c 20 20 20 0a 20 20  , 1, 1, 1,   .  
27b0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31  1, 1, 1, 1, 1, 1
27c0: 2c 20 31 2c 20 31 2c 20 20 20 31 2c 20 31 2c 20  , 1, 1,   1, 1, 
27d0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31  1, 1, 1, 1, 1, 1
27e0: 2c 20 20 20 0a 20 20 31 2c 20 31 2c 20 31 2c 20  ,   .  1, 1, 1, 
27f0: 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 20  1, 1, 1, 1, 1,  
2800: 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20 31 2c 20   1, 1, 1, 1, 1, 
2810: 31 2c 20 31 2c 20 31 2c 20 20 20 0a 7d 3b 0a 0a  1, 1, 1,   .};..
2820: 2f 2a 0a 2a 2a 20 4f 75 74 70 75 74 20 61 20 73  /*.** Output a s
2830: 69 6e 67 6c 65 20 74 65 72 6d 20 6f 66 20 43 53  ingle term of CS
2840: 56 2e 20 20 41 63 74 75 61 6c 6c 79 2c 20 70 2d  V.  Actually, p-
2850: 3e 73 65 70 61 72 61 74 6f 72 20 69 73 20 75 73  >separator is us
2860: 65 64 20 66 6f 72 0a 2a 2a 20 74 68 65 20 73 65  ed for.** the se
2870: 70 61 72 61 74 6f 72 2c 20 77 68 69 63 68 20 6d  parator, which m
2880: 61 79 20 6f 72 20 6d 61 79 20 6e 6f 74 20 62 65  ay or may not be
2890: 20 61 20 63 6f 6d 6d 61 2e 20 20 70 2d 3e 6e 75   a comma.  p->nu
28a0: 6c 6c 76 61 6c 75 65 20 69 73 0a 2a 2a 20 74 68  llvalue is.** th
28b0: 65 20 6e 75 6c 6c 20 76 61 6c 75 65 2e 20 20 53  e null value.  S
28c0: 74 72 69 6e 67 73 20 61 72 65 20 71 75 6f 74 65  trings are quote
28d0: 64 20 75 73 69 6e 67 20 41 4e 53 49 2d 43 20 72  d using ANSI-C r
28e0: 75 6c 65 73 2e 20 20 4e 75 6d 62 65 72 73 0a 2a  ules.  Numbers.*
28f0: 2a 20 61 70 70 65 61 72 20 6f 75 74 73 69 64 65  * appear outside
2900: 20 6f 66 20 71 75 6f 74 65 73 2e 0a 2a 2f 0a 73   of quotes..*/.s
2910: 74 61 74 69 63 20 76 6f 69 64 20 6f 75 74 70 75  tatic void outpu
2920: 74 5f 63 73 76 28 73 74 72 75 63 74 20 63 61 6c  t_csv(struct cal
2930: 6c 62 61 63 6b 5f 64 61 74 61 20 2a 70 2c 20 63  lback_data *p, c
2940: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 2c 20 69 6e  onst char *z, in
2950: 74 20 62 53 65 70 29 7b 0a 20 20 46 49 4c 45 20  t bSep){.  FILE 
2960: 2a 6f 75 74 20 3d 20 70 2d 3e 6f 75 74 3b 0a 20  *out = p->out;. 
2970: 20 69 66 28 20 7a 3d 3d 30 20 29 7b 0a 20 20 20   if( z==0 ){.   
2980: 20 66 70 72 69 6e 74 66 28 6f 75 74 2c 22 25 73   fprintf(out,"%s
2990: 22 2c 70 2d 3e 6e 75 6c 6c 76 61 6c 75 65 29 3b  ",p->nullvalue);
29a0: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 69 6e  .  }else{.    in
29b0: 74 20 69 3b 0a 20 20 20 20 66 6f 72 28 69 3d 30  t i;.    for(i=0
29c0: 3b 20 7a 5b 69 5d 3b 20 69 2b 2b 29 7b 0a 20 20  ; z[i]; i++){.  
29d0: 20 20 20 20 69 66 28 20 6e 65 65 64 43 73 76 51      if( needCsvQ
29e0: 75 6f 74 65 5b 28 28 75 6e 73 69 67 6e 65 64 20  uote[((unsigned 
29f0: 63 68 61 72 2a 29 7a 29 5b 69 5d 5d 20 29 7b 0a  char*)z)[i]] ){.
2a00: 20 20 20 20 20 20 20 20 69 20 3d 20 30 3b 0a 20          i = 0;. 
2a10: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
2a20: 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20      }.    }.    
2a30: 69 66 28 20 69 3d 3d 30 20 29 7b 0a 20 20 20 20  if( i==0 ){.    
2a40: 20 20 70 75 74 63 28 27 22 27 2c 20 6f 75 74 29    putc('"', out)
2a50: 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b  ;.      for(i=0;
2a60: 20 7a 5b 69 5d 3b 20 69 2b 2b 29 7b 0a 20 20 20   z[i]; i++){.   
2a70: 20 20 20 20 20 69 66 28 20 7a 5b 69 5d 3d 3d 27       if( z[i]=='
2a80: 22 27 20 29 20 70 75 74 63 28 27 22 27 2c 20 6f  "' ) putc('"', o
2a90: 75 74 29 3b 0a 20 20 20 20 20 20 20 20 70 75 74  ut);.        put
2aa0: 63 28 7a 5b 69 5d 2c 20 6f 75 74 29 3b 0a 20 20  c(z[i], out);.  
2ab0: 20 20 20 20 7d 0a 20 20 20 20 20 20 70 75 74 63      }.      putc
2ac0: 28 27 22 27 2c 20 6f 75 74 29 3b 0a 20 20 20 20  ('"', out);.    
2ad0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 66 70 72  }else{.      fpr
2ae0: 69 6e 74 66 28 6f 75 74 2c 20 22 25 73 22 2c 20  intf(out, "%s", 
2af0: 7a 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  z);.    }.  }.  
2b00: 69 66 28 20 62 53 65 70 20 29 7b 0a 20 20 20 20  if( bSep ){.    
2b10: 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 20  fprintf(p->out, 
2b20: 70 2d 3e 73 65 70 61 72 61 74 6f 72 29 3b 0a 20  p->separator);. 
2b30: 20 7d 0a 7d 0a 0a 23 69 66 64 65 66 20 53 49 47   }.}..#ifdef SIG
2b40: 49 4e 54 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 72  INT./*.** This r
2b50: 6f 75 74 69 6e 65 20 72 75 6e 73 20 77 68 65 6e  outine runs when
2b60: 20 74 68 65 20 75 73 65 72 20 70 72 65 73 73 65   the user presse
2b70: 73 20 43 74 72 6c 2d 43 0a 2a 2f 0a 73 74 61 74  s Ctrl-C.*/.stat
2b80: 69 63 20 76 6f 69 64 20 69 6e 74 65 72 72 75 70  ic void interrup
2b90: 74 5f 68 61 6e 64 6c 65 72 28 69 6e 74 20 4e 6f  t_handler(int No
2ba0: 74 55 73 65 64 29 7b 0a 20 20 73 65 65 6e 49 6e  tUsed){.  seenIn
2bb0: 74 65 72 72 75 70 74 20 3d 20 31 3b 0a 20 20 69  terrupt = 1;.  i
2bc0: 66 28 20 64 62 20 29 20 73 71 6c 69 74 65 33 5f  f( db ) sqlite3_
2bd0: 69 6e 74 65 72 72 75 70 74 28 64 62 29 3b 0a 7d  interrupt(db);.}
2be0: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54  .#endif../*.** T
2bf0: 68 69 73 20 69 73 20 74 68 65 20 63 61 6c 6c 62  his is the callb
2c00: 61 63 6b 20 72 6f 75 74 69 6e 65 20 74 68 61 74  ack routine that
2c10: 20 74 68 65 20 53 51 4c 69 74 65 20 6c 69 62 72   the SQLite libr
2c20: 61 72 79 0a 2a 2a 20 69 6e 76 6f 6b 65 73 20 66  ary.** invokes f
2c30: 6f 72 20 65 61 63 68 20 72 6f 77 20 6f 66 20 61  or each row of a
2c40: 20 71 75 65 72 79 20 72 65 73 75 6c 74 2e 0a 2a   query result..*
2c50: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 63 61 6c  /.static int cal
2c60: 6c 62 61 63 6b 28 76 6f 69 64 20 2a 70 41 72 67  lback(void *pArg
2c70: 2c 20 69 6e 74 20 6e 41 72 67 2c 20 63 68 61 72  , int nArg, char
2c80: 20 2a 2a 61 7a 41 72 67 2c 20 63 68 61 72 20 2a   **azArg, char *
2c90: 2a 61 7a 43 6f 6c 29 7b 0a 20 20 69 6e 74 20 69  *azCol){.  int i
2ca0: 3b 0a 20 20 73 74 72 75 63 74 20 63 61 6c 6c 62  ;.  struct callb
2cb0: 61 63 6b 5f 64 61 74 61 20 2a 70 20 3d 20 28 73  ack_data *p = (s
2cc0: 74 72 75 63 74 20 63 61 6c 6c 62 61 63 6b 5f 64  truct callback_d
2cd0: 61 74 61 2a 29 70 41 72 67 3b 0a 20 20 73 77 69  ata*)pArg;.  swi
2ce0: 74 63 68 28 20 70 2d 3e 6d 6f 64 65 20 29 7b 0a  tch( p->mode ){.
2cf0: 20 20 20 20 63 61 73 65 20 4d 4f 44 45 5f 4c 69      case MODE_Li
2d00: 6e 65 3a 20 7b 0a 20 20 20 20 20 20 69 6e 74 20  ne: {.      int 
2d10: 77 20 3d 20 35 3b 0a 20 20 20 20 20 20 69 66 28  w = 5;.      if(
2d20: 20 61 7a 41 72 67 3d 3d 30 20 29 20 62 72 65 61   azArg==0 ) brea
2d30: 6b 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30  k;.      for(i=0
2d40: 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b 0a  ; i<nArg; i++){.
2d50: 20 20 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 20          int len 
2d60: 3d 20 73 74 72 6c 65 6e 28 61 7a 43 6f 6c 5b 69  = strlen(azCol[i
2d70: 5d 20 3f 20 61 7a 43 6f 6c 5b 69 5d 20 3a 20 22  ] ? azCol[i] : "
2d80: 22 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20  ");.        if( 
2d90: 6c 65 6e 3e 77 20 29 20 77 20 3d 20 6c 65 6e 3b  len>w ) w = len;
2da0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69  .      }.      i
2db0: 66 28 20 70 2d 3e 63 6e 74 2b 2b 3e 30 20 29 20  f( p->cnt++>0 ) 
2dc0: 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22  fprintf(p->out,"
2dd0: 5c 6e 22 29 3b 0a 20 20 20 20 20 20 66 6f 72 28  \n");.      for(
2de0: 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b  i=0; i<nArg; i++
2df0: 29 7b 0a 20 20 20 20 20 20 20 20 66 70 72 69 6e  ){.        fprin
2e00: 74 66 28 70 2d 3e 6f 75 74 2c 22 25 2a 73 20 3d  tf(p->out,"%*s =
2e10: 20 25 73 5c 6e 22 2c 20 77 2c 20 61 7a 43 6f 6c   %s\n", w, azCol
2e20: 5b 69 5d 2c 0a 20 20 20 20 20 20 20 20 20 20 20  [i],.           
2e30: 20 20 20 20 20 61 7a 41 72 67 5b 69 5d 20 3f 20       azArg[i] ? 
2e40: 61 7a 41 72 67 5b 69 5d 20 3a 20 70 2d 3e 6e 75  azArg[i] : p->nu
2e50: 6c 6c 76 61 6c 75 65 29 3b 0a 20 20 20 20 20 20  llvalue);.      
2e60: 7d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  }.      break;. 
2e70: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 4d 4f     }.    case MO
2e80: 44 45 5f 43 6f 6c 75 6d 6e 3a 20 7b 0a 20 20 20  DE_Column: {.   
2e90: 20 20 20 69 66 28 20 70 2d 3e 63 6e 74 2b 2b 3d     if( p->cnt++=
2ea0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 66 6f  =0 ){.        fo
2eb0: 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69  r(i=0; i<nArg; i
2ec0: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20 69  ++){.          i
2ed0: 6e 74 20 77 2c 20 6e 3b 0a 20 20 20 20 20 20 20  nt w, n;.       
2ee0: 20 20 20 69 66 28 20 69 3c 41 72 72 61 79 53 69     if( i<ArraySi
2ef0: 7a 65 28 70 2d 3e 63 6f 6c 57 69 64 74 68 29 20  ze(p->colWidth) 
2f00: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  ){.             
2f10: 77 20 3d 20 70 2d 3e 63 6f 6c 57 69 64 74 68 5b  w = p->colWidth[
2f20: 69 5d 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 65  i];.          }e
2f30: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 20  lse{.           
2f40: 20 20 77 20 3d 20 30 3b 0a 20 20 20 20 20 20 20    w = 0;.       
2f50: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 69     }.          i
2f60: 66 28 20 77 3c 3d 30 20 29 7b 0a 20 20 20 20 20  f( w<=0 ){.     
2f70: 20 20 20 20 20 20 20 77 20 3d 20 73 74 72 6c 65         w = strle
2f80: 6e 28 61 7a 43 6f 6c 5b 69 5d 20 3f 20 61 7a 43  n(azCol[i] ? azC
2f90: 6f 6c 5b 69 5d 20 3a 20 22 22 29 3b 0a 20 20 20  ol[i] : "");.   
2fa0: 20 20 20 20 20 20 20 20 20 69 66 28 20 77 3c 31           if( w<1
2fb0: 30 20 29 20 77 20 3d 20 31 30 3b 0a 20 20 20 20  0 ) w = 10;.    
2fc0: 20 20 20 20 20 20 20 20 6e 20 3d 20 73 74 72 6c          n = strl
2fd0: 65 6e 28 61 7a 41 72 67 20 26 26 20 61 7a 41 72  en(azArg && azAr
2fe0: 67 5b 69 5d 20 3f 20 61 7a 41 72 67 5b 69 5d 20  g[i] ? azArg[i] 
2ff0: 3a 20 70 2d 3e 6e 75 6c 6c 76 61 6c 75 65 29 3b  : p->nullvalue);
3000: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28  .            if(
3010: 20 77 3c 6e 20 29 20 77 20 3d 20 6e 3b 0a 20 20   w<n ) w = n;.  
3020: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3030: 20 20 20 20 69 66 28 20 69 3c 41 72 72 61 79 53      if( i<ArrayS
3040: 69 7a 65 28 70 2d 3e 61 63 74 75 61 6c 57 69 64  ize(p->actualWid
3050: 74 68 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20  th) ){.         
3060: 20 20 20 70 2d 3e 61 63 74 75 61 6c 57 69 64 74     p->actualWidt
3070: 68 5b 69 5d 20 3d 20 77 3b 0a 20 20 20 20 20 20  h[i] = w;.      
3080: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
3090: 69 66 28 20 70 2d 3e 73 68 6f 77 48 65 61 64 65  if( p->showHeade
30a0: 72 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  r ){.           
30b0: 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c   fprintf(p->out,
30c0: 22 25 2d 2a 2e 2a 73 25 73 22 2c 77 2c 77 2c 61  "%-*.*s%s",w,w,a
30d0: 7a 43 6f 6c 5b 69 5d 2c 20 69 3d 3d 6e 41 72 67  zCol[i], i==nArg
30e0: 2d 31 20 3f 20 22 5c 6e 22 3a 20 22 20 20 22 29  -1 ? "\n": "  ")
30f0: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  ;.          }.  
3100: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
3110: 69 66 28 20 70 2d 3e 73 68 6f 77 48 65 61 64 65  if( p->showHeade
3120: 72 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 66  r ){.          f
3130: 6f 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20  or(i=0; i<nArg; 
3140: 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  i++){.          
3150: 20 20 69 6e 74 20 77 3b 0a 20 20 20 20 20 20 20    int w;.       
3160: 20 20 20 20 20 69 66 28 20 69 3c 41 72 72 61 79       if( i<Array
3170: 53 69 7a 65 28 70 2d 3e 61 63 74 75 61 6c 57 69  Size(p->actualWi
3180: 64 74 68 29 20 29 7b 0a 20 20 20 20 20 20 20 20  dth) ){.        
3190: 20 20 20 20 20 20 20 77 20 3d 20 70 2d 3e 61 63         w = p->ac
31a0: 74 75 61 6c 57 69 64 74 68 5b 69 5d 3b 0a 20 20  tualWidth[i];.  
31b0: 20 20 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b            }else{
31c0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
31d0: 77 20 3d 20 31 30 3b 0a 20 20 20 20 20 20 20 20  w = 10;.        
31e0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20      }.          
31f0: 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74    fprintf(p->out
3200: 2c 22 25 2d 2a 2e 2a 73 25 73 22 2c 77 2c 77 2c  ,"%-*.*s%s",w,w,
3210: 22 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  "---------------
3220: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3230: 2d 2d 2d 2d 22 0a 20 20 20 20 20 20 20 20 20 20  ----".          
3240: 20 20 20 20 20 20 20 20 20 22 2d 2d 2d 2d 2d 2d           "------
3250: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3260: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3270: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
3280: 2d 2d 2d 2d 22 2c 0a 20 20 20 20 20 20 20 20 20  ----",.         
3290: 20 20 20 20 20 20 20 20 20 20 20 69 3d 3d 6e 41             i==nA
32a0: 72 67 2d 31 20 3f 20 22 5c 6e 22 3a 20 22 20 20  rg-1 ? "\n": "  
32b0: 22 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  ");.          }.
32c0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
32d0: 7d 0a 20 20 20 20 20 20 69 66 28 20 61 7a 41 72  }.      if( azAr
32e0: 67 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20 20  g==0 ) break;.  
32f0: 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e      for(i=0; i<n
3300: 41 72 67 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20  Arg; i++){.     
3310: 20 20 20 69 6e 74 20 77 3b 0a 20 20 20 20 20 20     int w;.      
3320: 20 20 69 66 28 20 69 3c 41 72 72 61 79 53 69 7a    if( i<ArraySiz
3330: 65 28 70 2d 3e 61 63 74 75 61 6c 57 69 64 74 68  e(p->actualWidth
3340: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20  ) ){.           
3350: 77 20 3d 20 70 2d 3e 61 63 74 75 61 6c 57 69 64  w = p->actualWid
3360: 74 68 5b 69 5d 3b 0a 20 20 20 20 20 20 20 20 7d  th[i];.        }
3370: 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20  else{.          
3380: 20 77 20 3d 20 31 30 3b 0a 20 20 20 20 20 20 20   w = 10;.       
3390: 20 7d 0a 20 20 20 20 20 20 20 20 66 70 72 69 6e   }.        fprin
33a0: 74 66 28 70 2d 3e 6f 75 74 2c 22 25 2d 2a 2e 2a  tf(p->out,"%-*.*
33b0: 73 25 73 22 2c 77 2c 77 2c 0a 20 20 20 20 20 20  s%s",w,w,.      
33c0: 20 20 20 20 20 20 61 7a 41 72 67 5b 69 5d 20 3f        azArg[i] ?
33d0: 20 61 7a 41 72 67 5b 69 5d 20 3a 20 70 2d 3e 6e   azArg[i] : p->n
33e0: 75 6c 6c 76 61 6c 75 65 2c 20 69 3d 3d 6e 41 72  ullvalue, i==nAr
33f0: 67 2d 31 20 3f 20 22 5c 6e 22 3a 20 22 20 20 22  g-1 ? "\n": "  "
3400: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  );.      }.     
3410: 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20   break;.    }.  
3420: 20 20 63 61 73 65 20 4d 4f 44 45 5f 53 65 6d 69    case MODE_Semi
3430: 3a 0a 20 20 20 20 63 61 73 65 20 4d 4f 44 45 5f  :.    case MODE_
3440: 4c 69 73 74 3a 20 7b 0a 20 20 20 20 20 20 69 66  List: {.      if
3450: 28 20 70 2d 3e 63 6e 74 2b 2b 3d 3d 30 20 26 26  ( p->cnt++==0 &&
3460: 20 70 2d 3e 73 68 6f 77 48 65 61 64 65 72 20 29   p->showHeader )
3470: 7b 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d  {.        for(i=
3480: 30 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b  0; i<nArg; i++){
3490: 0a 20 20 20 20 20 20 20 20 20 20 66 70 72 69 6e  .          fprin
34a0: 74 66 28 70 2d 3e 6f 75 74 2c 22 25 73 25 73 22  tf(p->out,"%s%s"
34b0: 2c 61 7a 43 6f 6c 5b 69 5d 2c 20 69 3d 3d 6e 41  ,azCol[i], i==nA
34c0: 72 67 2d 31 20 3f 20 22 5c 6e 22 20 3a 20 70 2d  rg-1 ? "\n" : p-
34d0: 3e 73 65 70 61 72 61 74 6f 72 29 3b 0a 20 20 20  >separator);.   
34e0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20       }.      }. 
34f0: 20 20 20 20 20 69 66 28 20 61 7a 41 72 67 3d 3d       if( azArg==
3500: 30 20 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 20  0 ) break;.     
3510: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67   for(i=0; i<nArg
3520: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; i++){.        
3530: 63 68 61 72 20 2a 7a 20 3d 20 61 7a 41 72 67 5b  char *z = azArg[
3540: 69 5d 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20  i];.        if( 
3550: 7a 3d 3d 30 20 29 20 7a 20 3d 20 70 2d 3e 6e 75  z==0 ) z = p->nu
3560: 6c 6c 76 61 6c 75 65 3b 0a 20 20 20 20 20 20 20  llvalue;.       
3570: 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c   fprintf(p->out,
3580: 20 22 25 73 22 2c 20 7a 29 3b 0a 20 20 20 20 20   "%s", z);.     
3590: 20 20 20 69 66 28 20 69 3c 6e 41 72 67 2d 31 20     if( i<nArg-1 
35a0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 66 70 72  ){.          fpr
35b0: 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 20 22 25 73  intf(p->out, "%s
35c0: 22 2c 20 70 2d 3e 73 65 70 61 72 61 74 6f 72 29  ", p->separator)
35d0: 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 20  ;.        }else 
35e0: 69 66 28 20 70 2d 3e 6d 6f 64 65 3d 3d 4d 4f 44  if( p->mode==MOD
35f0: 45 5f 53 65 6d 69 20 29 7b 0a 20 20 20 20 20 20  E_Semi ){.      
3600: 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f      fprintf(p->o
3610: 75 74 2c 20 22 3b 5c 6e 22 29 3b 0a 20 20 20 20  ut, ";\n");.    
3620: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
3630: 20 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e       fprintf(p->
3640: 6f 75 74 2c 20 22 5c 6e 22 29 3b 0a 20 20 20 20  out, "\n");.    
3650: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
3660: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
3670: 0a 20 20 20 20 63 61 73 65 20 4d 4f 44 45 5f 48  .    case MODE_H
3680: 74 6d 6c 3a 20 7b 0a 20 20 20 20 20 20 69 66 28  tml: {.      if(
3690: 20 70 2d 3e 63 6e 74 2b 2b 3d 3d 30 20 26 26 20   p->cnt++==0 && 
36a0: 70 2d 3e 73 68 6f 77 48 65 61 64 65 72 20 29 7b  p->showHeader ){
36b0: 0a 20 20 20 20 20 20 20 20 66 70 72 69 6e 74 66  .        fprintf
36c0: 28 70 2d 3e 6f 75 74 2c 22 3c 54 52 3e 22 29 3b  (p->out,"<TR>");
36d0: 0a 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30  .        for(i=0
36e0: 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b 0a  ; i<nArg; i++){.
36f0: 20 20 20 20 20 20 20 20 20 20 66 70 72 69 6e 74            fprint
3700: 66 28 70 2d 3e 6f 75 74 2c 22 3c 54 48 3e 25 73  f(p->out,"<TH>%s
3710: 3c 2f 54 48 3e 22 2c 61 7a 43 6f 6c 5b 69 5d 29  </TH>",azCol[i])
3720: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
3730: 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f      fprintf(p->o
3740: 75 74 2c 22 3c 2f 54 52 3e 5c 6e 22 29 3b 0a 20  ut,"</TR>\n");. 
3750: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28       }.      if(
3760: 20 61 7a 41 72 67 3d 3d 30 20 29 20 62 72 65 61   azArg==0 ) brea
3770: 6b 3b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66  k;.      fprintf
3780: 28 70 2d 3e 6f 75 74 2c 22 3c 54 52 3e 22 29 3b  (p->out,"<TR>");
3790: 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20  .      for(i=0; 
37a0: 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b 0a 20 20  i<nArg; i++){.  
37b0: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d        fprintf(p-
37c0: 3e 6f 75 74 2c 22 3c 54 44 3e 22 29 3b 0a 20 20  >out,"<TD>");.  
37d0: 20 20 20 20 20 20 6f 75 74 70 75 74 5f 68 74 6d        output_htm
37e0: 6c 5f 73 74 72 69 6e 67 28 70 2d 3e 6f 75 74 2c  l_string(p->out,
37f0: 20 61 7a 41 72 67 5b 69 5d 20 3f 20 61 7a 41 72   azArg[i] ? azAr
3800: 67 5b 69 5d 20 3a 20 70 2d 3e 6e 75 6c 6c 76 61  g[i] : p->nullva
3810: 6c 75 65 29 3b 0a 20 20 20 20 20 20 20 20 66 70  lue);.        fp
3820: 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22 3c 2f  rintf(p->out,"</
3830: 54 44 3e 5c 6e 22 29 3b 0a 20 20 20 20 20 20 7d  TD>\n");.      }
3840: 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70  .      fprintf(p
3850: 2d 3e 6f 75 74 2c 22 3c 2f 54 52 3e 5c 6e 22 29  ->out,"</TR>\n")
3860: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
3870: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 4d 4f     }.    case MO
3880: 44 45 5f 54 63 6c 3a 20 7b 0a 20 20 20 20 20 20  DE_Tcl: {.      
3890: 69 66 28 20 70 2d 3e 63 6e 74 2b 2b 3d 3d 30 20  if( p->cnt++==0 
38a0: 26 26 20 70 2d 3e 73 68 6f 77 48 65 61 64 65 72  && p->showHeader
38b0: 20 29 7b 0a 20 20 20 20 20 20 20 20 66 6f 72 28   ){.        for(
38c0: 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b  i=0; i<nArg; i++
38d0: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 6f 75 74  ){.          out
38e0: 70 75 74 5f 63 5f 73 74 72 69 6e 67 28 70 2d 3e  put_c_string(p->
38f0: 6f 75 74 2c 61 7a 43 6f 6c 5b 69 5d 20 3f 20 61  out,azCol[i] ? a
3900: 7a 43 6f 6c 5b 69 5d 20 3a 20 22 22 29 3b 0a 20  zCol[i] : "");. 
3910: 20 20 20 20 20 20 20 20 20 66 70 72 69 6e 74 66           fprintf
3920: 28 70 2d 3e 6f 75 74 2c 20 22 25 73 22 2c 20 70  (p->out, "%s", p
3930: 2d 3e 73 65 70 61 72 61 74 6f 72 29 3b 0a 20 20  ->separator);.  
3940: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
3950: 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22  fprintf(p->out,"
3960: 5c 6e 22 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  \n");.      }.  
3970: 20 20 20 20 69 66 28 20 61 7a 41 72 67 3d 3d 30      if( azArg==0
3980: 20 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20   ) break;.      
3990: 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b  for(i=0; i<nArg;
39a0: 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 6f   i++){.        o
39b0: 75 74 70 75 74 5f 63 5f 73 74 72 69 6e 67 28 70  utput_c_string(p
39c0: 2d 3e 6f 75 74 2c 20 61 7a 41 72 67 5b 69 5d 20  ->out, azArg[i] 
39d0: 3f 20 61 7a 41 72 67 5b 69 5d 20 3a 20 70 2d 3e  ? azArg[i] : p->
39e0: 6e 75 6c 6c 76 61 6c 75 65 29 3b 0a 20 20 20 20  nullvalue);.    
39f0: 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f      fprintf(p->o
3a00: 75 74 2c 20 22 25 73 22 2c 20 70 2d 3e 73 65 70  ut, "%s", p->sep
3a10: 61 72 61 74 6f 72 29 3b 0a 20 20 20 20 20 20 7d  arator);.      }
3a20: 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70  .      fprintf(p
3a30: 2d 3e 6f 75 74 2c 22 5c 6e 22 29 3b 0a 20 20 20  ->out,"\n");.   
3a40: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
3a50: 20 20 20 20 63 61 73 65 20 4d 4f 44 45 5f 43 73      case MODE_Cs
3a60: 76 3a 20 7b 0a 20 20 20 20 20 20 69 66 28 20 70  v: {.      if( p
3a70: 2d 3e 63 6e 74 2b 2b 3d 3d 30 20 26 26 20 70 2d  ->cnt++==0 && p-
3a80: 3e 73 68 6f 77 48 65 61 64 65 72 20 29 7b 0a 20  >showHeader ){. 
3a90: 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20         for(i=0; 
3aa0: 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b 0a 20 20  i<nArg; i++){.  
3ab0: 20 20 20 20 20 20 20 20 6f 75 74 70 75 74 5f 63          output_c
3ac0: 73 76 28 70 2c 20 61 7a 43 6f 6c 5b 69 5d 20 3f  sv(p, azCol[i] ?
3ad0: 20 61 7a 43 6f 6c 5b 69 5d 20 3a 20 22 22 2c 20   azCol[i] : "", 
3ae0: 69 3c 6e 41 72 67 2d 31 29 3b 0a 20 20 20 20 20  i<nArg-1);.     
3af0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 66 70 72     }.        fpr
3b00: 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22 5c 6e 22  intf(p->out,"\n"
3b10: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  );.      }.     
3b20: 20 69 66 28 20 61 7a 41 72 67 3d 3d 30 20 29 20   if( azArg==0 ) 
3b30: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 66 6f 72  break;.      for
3b40: 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69 2b  (i=0; i<nArg; i+
3b50: 2b 29 7b 0a 20 20 20 20 20 20 20 20 6f 75 74 70  +){.        outp
3b60: 75 74 5f 63 73 76 28 70 2c 20 61 7a 41 72 67 5b  ut_csv(p, azArg[
3b70: 69 5d 2c 20 69 3c 6e 41 72 67 2d 31 29 3b 0a 20  i], i<nArg-1);. 
3b80: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 66 70 72       }.      fpr
3b90: 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22 5c 6e 22  intf(p->out,"\n"
3ba0: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
3bb0: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 4d      }.    case M
3bc0: 4f 44 45 5f 49 6e 73 65 72 74 3a 20 7b 0a 20 20  ODE_Insert: {.  
3bd0: 20 20 20 20 69 66 28 20 61 7a 41 72 67 3d 3d 30      if( azArg==0
3be0: 20 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20   ) break;.      
3bf0: 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22  fprintf(p->out,"
3c00: 49 4e 53 45 52 54 20 49 4e 54 4f 20 25 73 20 56  INSERT INTO %s V
3c10: 41 4c 55 45 53 28 22 2c 70 2d 3e 7a 44 65 73 74  ALUES(",p->zDest
3c20: 54 61 62 6c 65 29 3b 0a 20 20 20 20 20 20 66 6f  Table);.      fo
3c30: 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69  r(i=0; i<nArg; i
3c40: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 63 68 61  ++){.        cha
3c50: 72 20 2a 7a 53 65 70 20 3d 20 69 3e 30 20 3f 20  r *zSep = i>0 ? 
3c60: 22 2c 22 3a 20 22 22 3b 0a 20 20 20 20 20 20 20  ",": "";.       
3c70: 20 69 66 28 20 61 7a 41 72 67 5b 69 5d 3d 3d 30   if( azArg[i]==0
3c80: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 66 70   ){.          fp
3c90: 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22 25 73  rintf(p->out,"%s
3ca0: 4e 55 4c 4c 22 2c 7a 53 65 70 29 3b 0a 20 20 20  NULL",zSep);.   
3cb0: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 69       }else if( i
3cc0: 73 4e 75 6d 62 65 72 28 61 7a 41 72 67 5b 69 5d  sNumber(azArg[i]
3cd0: 2c 20 30 29 20 29 7b 0a 20 20 20 20 20 20 20 20  , 0) ){.        
3ce0: 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74    fprintf(p->out
3cf0: 2c 22 25 73 25 73 22 2c 7a 53 65 70 2c 20 61 7a  ,"%s%s",zSep, az
3d00: 41 72 67 5b 69 5d 29 3b 0a 20 20 20 20 20 20 20  Arg[i]);.       
3d10: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
3d20: 20 20 69 66 28 20 7a 53 65 70 5b 30 5d 20 29 20    if( zSep[0] ) 
3d30: 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22  fprintf(p->out,"
3d40: 25 73 22 2c 7a 53 65 70 29 3b 0a 20 20 20 20 20  %s",zSep);.     
3d50: 20 20 20 20 20 6f 75 74 70 75 74 5f 71 75 6f 74       output_quot
3d60: 65 64 5f 73 74 72 69 6e 67 28 70 2d 3e 6f 75 74  ed_string(p->out
3d70: 2c 20 61 7a 41 72 67 5b 69 5d 29 3b 0a 20 20 20  , azArg[i]);.   
3d80: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20       }.      }. 
3d90: 20 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e       fprintf(p->
3da0: 6f 75 74 2c 22 29 3b 5c 6e 22 29 3b 0a 20 20 20  out,");\n");.   
3db0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
3dc0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a    }.  return 0;.
3dd0: 7d 0a 0a 2f 2a 0a 2a 2a 20 53 65 74 20 74 68 65  }../*.** Set the
3de0: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 74 61 62   destination tab
3df0: 6c 65 20 66 69 65 6c 64 20 6f 66 20 74 68 65 20  le field of the 
3e00: 63 61 6c 6c 62 61 63 6b 5f 64 61 74 61 20 73 74  callback_data st
3e10: 72 75 63 74 75 72 65 20 74 6f 0a 2a 2a 20 74 68  ructure to.** th
3e20: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 74 61  e name of the ta
3e30: 62 6c 65 20 67 69 76 65 6e 2e 20 20 45 73 63 61  ble given.  Esca
3e40: 70 65 20 61 6e 79 20 71 75 6f 74 65 20 63 68 61  pe any quote cha
3e50: 72 61 63 74 65 72 73 20 69 6e 20 74 68 65 0a 2a  racters in the.*
3e60: 2a 20 74 61 62 6c 65 20 6e 61 6d 65 2e 0a 2a 2f  * table name..*/
3e70: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 73 65 74  .static void set
3e80: 5f 74 61 62 6c 65 5f 6e 61 6d 65 28 73 74 72 75  _table_name(stru
3e90: 63 74 20 63 61 6c 6c 62 61 63 6b 5f 64 61 74 61  ct callback_data
3ea0: 20 2a 70 2c 20 63 6f 6e 73 74 20 63 68 61 72 20   *p, const char 
3eb0: 2a 7a 4e 61 6d 65 29 7b 0a 20 20 69 6e 74 20 69  *zName){.  int i
3ec0: 2c 20 6e 3b 0a 20 20 69 6e 74 20 6e 65 65 64 51  , n;.  int needQ
3ed0: 75 6f 74 65 3b 0a 20 20 63 68 61 72 20 2a 7a 3b  uote;.  char *z;
3ee0: 0a 0a 20 20 69 66 28 20 70 2d 3e 7a 44 65 73 74  ..  if( p->zDest
3ef0: 54 61 62 6c 65 20 29 7b 0a 20 20 20 20 66 72 65  Table ){.    fre
3f00: 65 28 70 2d 3e 7a 44 65 73 74 54 61 62 6c 65 29  e(p->zDestTable)
3f10: 3b 0a 20 20 20 20 70 2d 3e 7a 44 65 73 74 54 61  ;.    p->zDestTa
3f20: 62 6c 65 20 3d 20 30 3b 0a 20 20 7d 0a 20 20 69  ble = 0;.  }.  i
3f30: 66 28 20 7a 4e 61 6d 65 3d 3d 30 20 29 20 72 65  f( zName==0 ) re
3f40: 74 75 72 6e 3b 0a 20 20 6e 65 65 64 51 75 6f 74  turn;.  needQuot
3f50: 65 20 3d 20 21 69 73 61 6c 70 68 61 28 28 75 6e  e = !isalpha((un
3f60: 73 69 67 6e 65 64 20 63 68 61 72 29 2a 7a 4e 61  signed char)*zNa
3f70: 6d 65 29 20 26 26 20 2a 7a 4e 61 6d 65 21 3d 27  me) && *zName!='
3f80: 5f 27 3b 0a 20 20 66 6f 72 28 69 3d 6e 3d 30 3b  _';.  for(i=n=0;
3f90: 20 7a 4e 61 6d 65 5b 69 5d 3b 20 69 2b 2b 2c 20   zName[i]; i++, 
3fa0: 6e 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 21 69  n++){.    if( !i
3fb0: 73 61 6c 6e 75 6d 28 28 75 6e 73 69 67 6e 65 64  salnum((unsigned
3fc0: 20 63 68 61 72 29 7a 4e 61 6d 65 5b 69 5d 29 20   char)zName[i]) 
3fd0: 26 26 20 7a 4e 61 6d 65 5b 69 5d 21 3d 27 5f 27  && zName[i]!='_'
3fe0: 20 29 7b 0a 20 20 20 20 20 20 6e 65 65 64 51 75   ){.      needQu
3ff0: 6f 74 65 20 3d 20 31 3b 0a 20 20 20 20 20 20 69  ote = 1;.      i
4000: 66 28 20 7a 4e 61 6d 65 5b 69 5d 3d 3d 27 5c 27  f( zName[i]=='\'
4010: 27 20 29 20 6e 2b 2b 3b 0a 20 20 20 20 7d 0a 20  ' ) n++;.    }. 
4020: 20 7d 0a 20 20 69 66 28 20 6e 65 65 64 51 75 6f   }.  if( needQuo
4030: 74 65 20 29 20 6e 20 2b 3d 20 32 3b 0a 20 20 7a  te ) n += 2;.  z
4040: 20 3d 20 70 2d 3e 7a 44 65 73 74 54 61 62 6c 65   = p->zDestTable
4050: 20 3d 20 6d 61 6c 6c 6f 63 28 20 6e 2b 31 20 29   = malloc( n+1 )
4060: 3b 0a 20 20 69 66 28 20 7a 3d 3d 30 20 29 7b 0a  ;.  if( z==0 ){.
4070: 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65      fprintf(stde
4080: 72 72 2c 22 4f 75 74 20 6f 66 20 6d 65 6d 6f 72  rr,"Out of memor
4090: 79 21 5c 6e 22 29 3b 0a 20 20 20 20 65 78 69 74  y!\n");.    exit
40a0: 28 31 29 3b 0a 20 20 7d 0a 20 20 6e 20 3d 20 30  (1);.  }.  n = 0
40b0: 3b 0a 20 20 69 66 28 20 6e 65 65 64 51 75 6f 74  ;.  if( needQuot
40c0: 65 20 29 20 7a 5b 6e 2b 2b 5d 20 3d 20 27 5c 27  e ) z[n++] = '\'
40d0: 27 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 7a 4e  ';.  for(i=0; zN
40e0: 61 6d 65 5b 69 5d 3b 20 69 2b 2b 29 7b 0a 20 20  ame[i]; i++){.  
40f0: 20 20 7a 5b 6e 2b 2b 5d 20 3d 20 7a 4e 61 6d 65    z[n++] = zName
4100: 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 7a 4e 61  [i];.    if( zNa
4110: 6d 65 5b 69 5d 3d 3d 27 5c 27 27 20 29 20 7a 5b  me[i]=='\'' ) z[
4120: 6e 2b 2b 5d 20 3d 20 27 5c 27 27 3b 0a 20 20 7d  n++] = '\'';.  }
4130: 0a 20 20 69 66 28 20 6e 65 65 64 51 75 6f 74 65  .  if( needQuote
4140: 20 29 20 7a 5b 6e 2b 2b 5d 20 3d 20 27 5c 27 27   ) z[n++] = '\''
4150: 3b 0a 20 20 7a 5b 6e 5d 20 3d 20 30 3b 0a 7d 0a  ;.  z[n] = 0;.}.
4160: 0a 2f 2a 20 7a 49 6e 20 69 73 20 65 69 74 68 65  ./* zIn is eithe
4170: 72 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61  r a pointer to a
4180: 20 4e 55 4c 4c 2d 74 65 72 6d 69 6e 61 74 65 64   NULL-terminated
4190: 20 73 74 72 69 6e 67 20 69 6e 20 6d 65 6d 6f 72   string in memor
41a0: 79 20 6f 62 74 61 69 6e 65 64 0a 2a 2a 20 66 72  y obtained.** fr
41b0: 6f 6d 20 6d 61 6c 6c 6f 63 28 29 2c 20 6f 72 20  om malloc(), or 
41c0: 61 20 4e 55 4c 4c 20 70 6f 69 6e 74 65 72 2e 20  a NULL pointer. 
41d0: 54 68 65 20 73 74 72 69 6e 67 20 70 6f 69 6e 74  The string point
41e0: 65 64 20 74 6f 20 62 79 20 7a 41 70 70 65 6e 64  ed to by zAppend
41f0: 20 69 73 0a 2a 2a 20 61 64 64 65 64 20 74 6f 20   is.** added to 
4200: 7a 49 6e 2c 20 61 6e 64 20 74 68 65 20 72 65 73  zIn, and the res
4210: 75 6c 74 20 72 65 74 75 72 6e 65 64 20 69 6e 20  ult returned in 
4220: 6d 65 6d 6f 72 79 20 6f 62 74 61 69 6e 65 64 20  memory obtained 
4230: 66 72 6f 6d 20 6d 61 6c 6c 6f 63 28 29 2e 0a 2a  from malloc()..*
4240: 2a 20 7a 49 6e 2c 20 69 66 20 69 74 20 77 61 73  * zIn, if it was
4250: 20 6e 6f 74 20 4e 55 4c 4c 2c 20 69 73 20 66 72   not NULL, is fr
4260: 65 65 64 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68  eed..**.** If th
4270: 65 20 74 68 69 72 64 20 61 72 67 75 6d 65 6e 74  e third argument
4280: 2c 20 71 75 6f 74 65 2c 20 69 73 20 6e 6f 74 20  , quote, is not 
4290: 27 5c 30 27 2c 20 74 68 65 6e 20 69 74 20 69 73  '\0', then it is
42a0: 20 75 73 65 64 20 61 73 20 61 20 0a 2a 2a 20 71   used as a .** q
42b0: 75 6f 74 65 20 63 68 61 72 61 63 74 65 72 20 66  uote character f
42c0: 6f 72 20 7a 41 70 70 65 6e 64 2e 0a 2a 2f 0a 73  or zAppend..*/.s
42d0: 74 61 74 69 63 20 63 68 61 72 20 2a 61 70 70 65  tatic char *appe
42e0: 6e 64 54 65 78 74 28 63 68 61 72 20 2a 7a 49 6e  ndText(char *zIn
42f0: 2c 20 63 68 61 72 20 63 6f 6e 73 74 20 2a 7a 41  , char const *zA
4300: 70 70 65 6e 64 2c 20 63 68 61 72 20 71 75 6f 74  ppend, char quot
4310: 65 29 7b 0a 20 20 69 6e 74 20 6c 65 6e 3b 0a 20  e){.  int len;. 
4320: 20 69 6e 74 20 69 3b 0a 20 20 69 6e 74 20 6e 41   int i;.  int nA
4330: 70 70 65 6e 64 20 3d 20 73 74 72 6c 65 6e 28 7a  ppend = strlen(z
4340: 41 70 70 65 6e 64 29 3b 0a 20 20 69 6e 74 20 6e  Append);.  int n
4350: 49 6e 20 3d 20 28 7a 49 6e 3f 73 74 72 6c 65 6e  In = (zIn?strlen
4360: 28 7a 49 6e 29 3a 30 29 3b 0a 0a 20 20 6c 65 6e  (zIn):0);..  len
4370: 20 3d 20 6e 41 70 70 65 6e 64 2b 6e 49 6e 2b 31   = nAppend+nIn+1
4380: 3b 0a 20 20 69 66 28 20 71 75 6f 74 65 20 29 7b  ;.  if( quote ){
4390: 0a 20 20 20 20 6c 65 6e 20 2b 3d 20 32 3b 0a 20  .    len += 2;. 
43a0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 41     for(i=0; i<nA
43b0: 70 70 65 6e 64 3b 20 69 2b 2b 29 7b 0a 20 20 20  ppend; i++){.   
43c0: 20 20 20 69 66 28 20 7a 41 70 70 65 6e 64 5b 69     if( zAppend[i
43d0: 5d 3d 3d 71 75 6f 74 65 20 29 20 6c 65 6e 2b 2b  ]==quote ) len++
43e0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 7a  ;.    }.  }..  z
43f0: 49 6e 20 3d 20 28 63 68 61 72 20 2a 29 72 65 61  In = (char *)rea
4400: 6c 6c 6f 63 28 7a 49 6e 2c 20 6c 65 6e 29 3b 0a  lloc(zIn, len);.
4410: 20 20 69 66 28 20 21 7a 49 6e 20 29 7b 0a 20 20    if( !zIn ){.  
4420: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a    return 0;.  }.
4430: 0a 20 20 69 66 28 20 71 75 6f 74 65 20 29 7b 0a  .  if( quote ){.
4440: 20 20 20 20 63 68 61 72 20 2a 7a 43 73 72 20 3d      char *zCsr =
4450: 20 26 7a 49 6e 5b 6e 49 6e 5d 3b 0a 20 20 20 20   &zIn[nIn];.    
4460: 2a 7a 43 73 72 2b 2b 20 3d 20 71 75 6f 74 65 3b  *zCsr++ = quote;
4470: 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  .    for(i=0; i<
4480: 6e 41 70 70 65 6e 64 3b 20 69 2b 2b 29 7b 0a 20  nAppend; i++){. 
4490: 20 20 20 20 20 2a 7a 43 73 72 2b 2b 20 3d 20 7a       *zCsr++ = z
44a0: 41 70 70 65 6e 64 5b 69 5d 3b 0a 20 20 20 20 20  Append[i];.     
44b0: 20 69 66 28 20 7a 41 70 70 65 6e 64 5b 69 5d 3d   if( zAppend[i]=
44c0: 3d 71 75 6f 74 65 20 29 20 2a 7a 43 73 72 2b 2b  =quote ) *zCsr++
44d0: 20 3d 20 71 75 6f 74 65 3b 0a 20 20 20 20 7d 0a   = quote;.    }.
44e0: 20 20 20 20 2a 7a 43 73 72 2b 2b 20 3d 20 71 75      *zCsr++ = qu
44f0: 6f 74 65 3b 0a 20 20 20 20 2a 7a 43 73 72 2b 2b  ote;.    *zCsr++
4500: 20 3d 20 27 5c 30 27 3b 0a 20 20 20 20 61 73 73   = '\0';.    ass
4510: 65 72 74 28 20 28 7a 43 73 72 2d 7a 49 6e 29 3d  ert( (zCsr-zIn)=
4520: 3d 6c 65 6e 20 29 3b 0a 20 20 7d 65 6c 73 65 7b  =len );.  }else{
4530: 0a 20 20 20 20 6d 65 6d 63 70 79 28 26 7a 49 6e  .    memcpy(&zIn
4540: 5b 6e 49 6e 5d 2c 20 7a 41 70 70 65 6e 64 2c 20  [nIn], zAppend, 
4550: 6e 41 70 70 65 6e 64 29 3b 0a 20 20 20 20 7a 49  nAppend);.    zI
4560: 6e 5b 6c 65 6e 2d 31 5d 20 3d 20 27 5c 30 27 3b  n[len-1] = '\0';
4570: 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20 7a  .  }..  return z
4580: 49 6e 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 45 78  In;.}.../*.** Ex
4590: 65 63 75 74 65 20 61 20 71 75 65 72 79 20 73 74  ecute a query st
45a0: 61 74 65 6d 65 6e 74 20 74 68 61 74 20 68 61 73  atement that has
45b0: 20 61 20 73 69 6e 67 6c 65 20 72 65 73 75 6c 74   a single result
45c0: 20 63 6f 6c 75 6d 6e 2e 20 20 50 72 69 6e 74 0a   column.  Print.
45d0: 2a 2a 20 74 68 61 74 20 72 65 73 75 6c 74 20 63  ** that result c
45e0: 6f 6c 75 6d 6e 20 6f 6e 20 61 20 6c 69 6e 65 20  olumn on a line 
45f0: 62 79 20 69 74 73 65 6c 66 20 77 69 74 68 20 61  by itself with a
4600: 20 73 65 6d 69 63 6f 6c 6f 6e 20 74 65 72 6d 69   semicolon termi
4610: 6e 61 74 6f 72 2e 0a 2a 2a 0a 2a 2a 20 54 68 69  nator..**.** Thi
4620: 73 20 69 73 20 75 73 65 64 2c 20 66 6f 72 20 65  s is used, for e
4630: 78 61 6d 70 6c 65 2c 20 74 6f 20 73 68 6f 77 20  xample, to show 
4640: 74 68 65 20 73 63 68 65 6d 61 20 6f 66 20 74 68  the schema of th
4650: 65 20 64 61 74 61 62 61 73 65 20 62 79 0a 2a 2a  e database by.**
4660: 20 71 75 65 72 79 69 6e 67 20 74 68 65 20 53 51   querying the SQ
4670: 4c 49 54 45 5f 4d 41 53 54 45 52 20 74 61 62 6c  LITE_MASTER tabl
4680: 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  e..*/.static int
4690: 20 72 75 6e 5f 74 61 62 6c 65 5f 64 75 6d 70 5f   run_table_dump_
46a0: 71 75 65 72 79 28 46 49 4c 45 20 2a 6f 75 74 2c  query(FILE *out,
46b0: 20 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f   sqlite3 *db, co
46c0: 6e 73 74 20 63 68 61 72 20 2a 7a 53 65 6c 65 63  nst char *zSelec
46d0: 74 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f 73 74  t){.  sqlite3_st
46e0: 6d 74 20 2a 70 53 65 6c 65 63 74 3b 0a 20 20 69  mt *pSelect;.  i
46f0: 6e 74 20 72 63 3b 0a 20 20 72 63 20 3d 20 73 71  nt rc;.  rc = sq
4700: 6c 69 74 65 33 5f 70 72 65 70 61 72 65 28 64 62  lite3_prepare(db
4710: 2c 20 7a 53 65 6c 65 63 74 2c 20 2d 31 2c 20 26  , zSelect, -1, &
4720: 70 53 65 6c 65 63 74 2c 20 30 29 3b 0a 20 20 69  pSelect, 0);.  i
4730: 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc!=SQLITE_OK
4740: 20 7c 7c 20 21 70 53 65 6c 65 63 74 20 29 7b 0a   || !pSelect ){.
4750: 20 20 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 20      return rc;. 
4760: 20 7d 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65   }.  rc = sqlite
4770: 33 5f 73 74 65 70 28 70 53 65 6c 65 63 74 29 3b  3_step(pSelect);
4780: 0a 20 20 77 68 69 6c 65 28 20 72 63 3d 3d 53 51  .  while( rc==SQ
4790: 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20  LITE_ROW ){.    
47a0: 66 70 72 69 6e 74 66 28 6f 75 74 2c 20 22 25 73  fprintf(out, "%s
47b0: 3b 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f 63 6f  ;\n", sqlite3_co
47c0: 6c 75 6d 6e 5f 74 65 78 74 28 70 53 65 6c 65 63  lumn_text(pSelec
47d0: 74 2c 20 30 29 29 3b 0a 20 20 20 20 72 63 20 3d  t, 0));.    rc =
47e0: 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53   sqlite3_step(pS
47f0: 65 6c 65 63 74 29 3b 0a 20 20 7d 0a 20 20 72 65  elect);.  }.  re
4800: 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 66 69 6e  turn sqlite3_fin
4810: 61 6c 69 7a 65 28 70 53 65 6c 65 63 74 29 3b 0a  alize(pSelect);.
4820: 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 69  }.../*.** This i
4830: 73 20 61 20 64 69 66 66 65 72 65 6e 74 20 63 61  s a different ca
4840: 6c 6c 62 61 63 6b 20 72 6f 75 74 69 6e 65 20 75  llback routine u
4850: 73 65 64 20 66 6f 72 20 64 75 6d 70 69 6e 67 20  sed for dumping 
4860: 74 68 65 20 64 61 74 61 62 61 73 65 2e 0a 2a 2a  the database..**
4870: 20 45 61 63 68 20 72 6f 77 20 72 65 63 65 69 76   Each row receiv
4880: 65 64 20 62 79 20 74 68 69 73 20 63 61 6c 6c 62  ed by this callb
4890: 61 63 6b 20 63 6f 6e 73 69 73 74 73 20 6f 66 20  ack consists of 
48a0: 61 20 74 61 62 6c 65 20 6e 61 6d 65 2c 0a 2a 2a  a table name,.**
48b0: 20 74 68 65 20 74 61 62 6c 65 20 74 79 70 65 20   the table type 
48c0: 28 22 69 6e 64 65 78 22 20 6f 72 20 22 74 61 62  ("index" or "tab
48d0: 6c 65 22 29 20 61 6e 64 20 53 51 4c 20 74 6f 20  le") and SQL to 
48e0: 63 72 65 61 74 65 20 74 68 65 20 74 61 62 6c 65  create the table
48f0: 2e 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69 6e  ..** This routin
4900: 65 20 73 68 6f 75 6c 64 20 70 72 69 6e 74 20 74  e should print t
4910: 65 78 74 20 73 75 66 66 69 63 69 65 6e 74 20 74  ext sufficient t
4920: 6f 20 72 65 63 72 65 61 74 65 20 74 68 65 20 74  o recreate the t
4930: 61 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  able..*/.static 
4940: 69 6e 74 20 64 75 6d 70 5f 63 61 6c 6c 62 61 63  int dump_callbac
4950: 6b 28 76 6f 69 64 20 2a 70 41 72 67 2c 20 69 6e  k(void *pArg, in
4960: 74 20 6e 41 72 67 2c 20 63 68 61 72 20 2a 2a 61  t nArg, char **a
4970: 7a 41 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a 43  zArg, char **azC
4980: 6f 6c 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20  ol){.  int rc;. 
4990: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 54 61   const char *zTa
49a0: 62 6c 65 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61  ble;.  const cha
49b0: 72 20 2a 7a 54 79 70 65 3b 0a 20 20 63 6f 6e 73  r *zType;.  cons
49c0: 74 20 63 68 61 72 20 2a 7a 53 71 6c 3b 0a 20 20  t char *zSql;.  
49d0: 73 74 72 75 63 74 20 63 61 6c 6c 62 61 63 6b 5f  struct callback_
49e0: 64 61 74 61 20 2a 70 20 3d 20 28 73 74 72 75 63  data *p = (struc
49f0: 74 20 63 61 6c 6c 62 61 63 6b 5f 64 61 74 61 20  t callback_data 
4a00: 2a 29 70 41 72 67 3b 0a 0a 20 20 69 66 28 20 6e  *)pArg;..  if( n
4a10: 41 72 67 21 3d 33 20 29 20 72 65 74 75 72 6e 20  Arg!=3 ) return 
4a20: 31 3b 0a 20 20 7a 54 61 62 6c 65 20 3d 20 61 7a  1;.  zTable = az
4a30: 41 72 67 5b 30 5d 3b 0a 20 20 7a 54 79 70 65 20  Arg[0];.  zType 
4a40: 3d 20 61 7a 41 72 67 5b 31 5d 3b 0a 20 20 7a 53  = azArg[1];.  zS
4a50: 71 6c 20 3d 20 61 7a 41 72 67 5b 32 5d 3b 0a 20  ql = azArg[2];. 
4a60: 20 0a 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a   .  if( strcmp(z
4a70: 54 61 62 6c 65 2c 20 22 73 71 6c 69 74 65 5f 73  Table, "sqlite_s
4a80: 65 71 75 65 6e 63 65 22 29 3d 3d 30 20 29 7b 0a  equence")==0 ){.
4a90: 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f      fprintf(p->o
4aa0: 75 74 2c 20 22 44 45 4c 45 54 45 20 46 52 4f 4d  ut, "DELETE FROM
4ab0: 20 73 71 6c 69 74 65 5f 73 65 71 75 65 6e 63 65   sqlite_sequence
4ac0: 3b 5c 6e 22 29 3b 0a 20 20 7d 65 6c 73 65 20 69  ;\n");.  }else i
4ad0: 66 28 20 73 74 72 63 6d 70 28 7a 54 61 62 6c 65  f( strcmp(zTable
4ae0: 2c 20 22 73 71 6c 69 74 65 5f 73 74 61 74 31 22  , "sqlite_stat1"
4af0: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 66 70 72 69  )==0 ){.    fpri
4b00: 6e 74 66 28 70 2d 3e 6f 75 74 2c 20 22 41 4e 41  ntf(p->out, "ANA
4b10: 4c 59 5a 45 20 73 71 6c 69 74 65 5f 6d 61 73 74  LYZE sqlite_mast
4b20: 65 72 3b 5c 6e 22 29 3b 0a 20 20 7d 65 6c 73 65  er;\n");.  }else
4b30: 20 69 66 28 20 73 74 72 6e 63 6d 70 28 7a 54 61   if( strncmp(zTa
4b40: 62 6c 65 2c 20 22 73 71 6c 69 74 65 5f 22 2c 20  ble, "sqlite_", 
4b50: 37 29 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74  7)==0 ){.    ret
4b60: 75 72 6e 20 30 3b 0a 20 20 7d 65 6c 73 65 20 69  urn 0;.  }else i
4b70: 66 28 20 73 74 72 6e 63 6d 70 28 7a 53 71 6c 2c  f( strncmp(zSql,
4b80: 20 22 43 52 45 41 54 45 20 56 49 52 54 55 41 4c   "CREATE VIRTUAL
4b90: 20 54 41 42 4c 45 22 2c 20 32 30 29 3d 3d 30 20   TABLE", 20)==0 
4ba0: 29 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 49 6e  ){.    char *zIn
4bb0: 73 3b 0a 20 20 20 20 69 66 28 20 21 70 2d 3e 77  s;.    if( !p->w
4bc0: 72 69 74 61 62 6c 65 53 63 68 65 6d 61 20 29 7b  ritableSchema ){
4bd0: 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70  .      fprintf(p
4be0: 2d 3e 6f 75 74 2c 20 22 50 52 41 47 4d 41 20 77  ->out, "PRAGMA w
4bf0: 72 69 74 61 62 6c 65 5f 73 63 68 65 6d 61 3d 4f  ritable_schema=O
4c00: 4e 3b 5c 6e 22 29 3b 0a 20 20 20 20 20 20 70 2d  N;\n");.      p-
4c10: 3e 77 72 69 74 61 62 6c 65 53 63 68 65 6d 61 20  >writableSchema 
4c20: 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 20 20 7a  = 1;.    }.    z
4c30: 49 6e 73 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70  Ins = sqlite3_mp
4c40: 72 69 6e 74 66 28 0a 20 20 20 20 20 20 20 22 49  rintf(.       "I
4c50: 4e 53 45 52 54 20 49 4e 54 4f 20 73 71 6c 69 74  NSERT INTO sqlit
4c60: 65 5f 6d 61 73 74 65 72 28 74 79 70 65 2c 6e 61  e_master(type,na
4c70: 6d 65 2c 74 62 6c 5f 6e 61 6d 65 2c 72 6f 6f 74  me,tbl_name,root
4c80: 70 61 67 65 2c 73 71 6c 29 22 0a 20 20 20 20 20  page,sql)".     
4c90: 20 20 22 56 41 4c 55 45 53 28 27 74 61 62 6c 65    "VALUES('table
4ca0: 27 2c 27 25 71 27 2c 27 25 71 27 2c 30 2c 27 25  ','%q','%q',0,'%
4cb0: 71 27 29 3b 22 2c 0a 20 20 20 20 20 20 20 7a 54  q');",.       zT
4cc0: 61 62 6c 65 2c 20 7a 54 61 62 6c 65 2c 20 7a 53  able, zTable, zS
4cd0: 71 6c 29 3b 0a 20 20 20 20 66 70 72 69 6e 74 66  ql);.    fprintf
4ce0: 28 70 2d 3e 6f 75 74 2c 20 22 25 73 5c 6e 22 2c  (p->out, "%s\n",
4cf0: 20 7a 49 6e 73 29 3b 0a 20 20 20 20 73 71 6c 69   zIns);.    sqli
4d00: 74 65 33 5f 66 72 65 65 28 7a 49 6e 73 29 3b 0a  te3_free(zIns);.
4d10: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20      return 0;.  
4d20: 7d 65 6c 73 65 7b 0a 20 20 20 20 66 70 72 69 6e  }else{.    fprin
4d30: 74 66 28 70 2d 3e 6f 75 74 2c 20 22 25 73 3b 5c  tf(p->out, "%s;\
4d40: 6e 22 2c 20 7a 53 71 6c 29 3b 0a 20 20 7d 0a 0a  n", zSql);.  }..
4d50: 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 54 79    if( strcmp(zTy
4d60: 70 65 2c 20 22 74 61 62 6c 65 22 29 3d 3d 30 20  pe, "table")==0 
4d70: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73  ){.    sqlite3_s
4d80: 74 6d 74 20 2a 70 54 61 62 6c 65 49 6e 66 6f 20  tmt *pTableInfo 
4d90: 3d 20 30 3b 0a 20 20 20 20 63 68 61 72 20 2a 7a  = 0;.    char *z
4da0: 53 65 6c 65 63 74 20 3d 20 30 3b 0a 20 20 20 20  Select = 0;.    
4db0: 63 68 61 72 20 2a 7a 54 61 62 6c 65 49 6e 66 6f  char *zTableInfo
4dc0: 20 3d 20 30 3b 0a 20 20 20 20 63 68 61 72 20 2a   = 0;.    char *
4dd0: 7a 54 6d 70 20 3d 20 30 3b 0a 20 20 20 0a 20 20  zTmp = 0;.   .  
4de0: 20 20 7a 54 61 62 6c 65 49 6e 66 6f 20 3d 20 61    zTableInfo = a
4df0: 70 70 65 6e 64 54 65 78 74 28 7a 54 61 62 6c 65  ppendText(zTable
4e00: 49 6e 66 6f 2c 20 22 50 52 41 47 4d 41 20 74 61  Info, "PRAGMA ta
4e10: 62 6c 65 5f 69 6e 66 6f 28 22 2c 20 30 29 3b 0a  ble_info(", 0);.
4e20: 20 20 20 20 7a 54 61 62 6c 65 49 6e 66 6f 20 3d      zTableInfo =
4e30: 20 61 70 70 65 6e 64 54 65 78 74 28 7a 54 61 62   appendText(zTab
4e40: 6c 65 49 6e 66 6f 2c 20 7a 54 61 62 6c 65 2c 20  leInfo, zTable, 
4e50: 27 22 27 29 3b 0a 20 20 20 20 7a 54 61 62 6c 65  '"');.    zTable
4e60: 49 6e 66 6f 20 3d 20 61 70 70 65 6e 64 54 65 78  Info = appendTex
4e70: 74 28 7a 54 61 62 6c 65 49 6e 66 6f 2c 20 22 29  t(zTableInfo, ")
4e80: 3b 22 2c 20 30 29 3b 0a 0a 20 20 20 20 72 63 20  ;", 0);..    rc 
4e90: 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  = sqlite3_prepar
4ea0: 65 28 70 2d 3e 64 62 2c 20 7a 54 61 62 6c 65 49  e(p->db, zTableI
4eb0: 6e 66 6f 2c 20 2d 31 2c 20 26 70 54 61 62 6c 65  nfo, -1, &pTable
4ec0: 49 6e 66 6f 2c 20 30 29 3b 0a 20 20 20 20 69 66  Info, 0);.    if
4ed0: 28 20 7a 54 61 62 6c 65 49 6e 66 6f 20 29 20 66  ( zTableInfo ) f
4ee0: 72 65 65 28 7a 54 61 62 6c 65 49 6e 66 6f 29 3b  ree(zTableInfo);
4ef0: 0a 20 20 20 20 69 66 28 20 72 63 21 3d 53 51 4c  .    if( rc!=SQL
4f00: 49 54 45 5f 4f 4b 20 7c 7c 20 21 70 54 61 62 6c  ITE_OK || !pTabl
4f10: 65 49 6e 66 6f 20 29 7b 0a 20 20 20 20 20 20 72  eInfo ){.      r
4f20: 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 0a  eturn 1;.    }..
4f30: 20 20 20 20 7a 53 65 6c 65 63 74 20 3d 20 61 70      zSelect = ap
4f40: 70 65 6e 64 54 65 78 74 28 7a 53 65 6c 65 63 74  pendText(zSelect
4f50: 2c 20 22 53 45 4c 45 43 54 20 27 49 4e 53 45 52  , "SELECT 'INSER
4f60: 54 20 49 4e 54 4f 20 27 20 7c 7c 20 22 2c 20 30  T INTO ' || ", 0
4f70: 29 3b 0a 20 20 20 20 7a 54 6d 70 20 3d 20 61 70  );.    zTmp = ap
4f80: 70 65 6e 64 54 65 78 74 28 7a 54 6d 70 2c 20 7a  pendText(zTmp, z
4f90: 54 61 62 6c 65 2c 20 27 22 27 29 3b 0a 20 20 20  Table, '"');.   
4fa0: 20 69 66 28 20 7a 54 6d 70 20 29 7b 0a 20 20 20   if( zTmp ){.   
4fb0: 20 20 20 7a 53 65 6c 65 63 74 20 3d 20 61 70 70     zSelect = app
4fc0: 65 6e 64 54 65 78 74 28 7a 53 65 6c 65 63 74 2c  endText(zSelect,
4fd0: 20 7a 54 6d 70 2c 20 27 5c 27 27 29 3b 0a 20 20   zTmp, '\'');.  
4fe0: 20 20 7d 0a 20 20 20 20 7a 53 65 6c 65 63 74 20    }.    zSelect 
4ff0: 3d 20 61 70 70 65 6e 64 54 65 78 74 28 7a 53 65  = appendText(zSe
5000: 6c 65 63 74 2c 20 22 20 7c 7c 20 27 20 56 41 4c  lect, " || ' VAL
5010: 55 45 53 28 27 20 7c 7c 20 22 2c 20 30 29 3b 0a  UES(' || ", 0);.
5020: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
5030: 5f 73 74 65 70 28 70 54 61 62 6c 65 49 6e 66 6f  _step(pTableInfo
5040: 29 3b 0a 20 20 20 20 77 68 69 6c 65 28 20 72 63  );.    while( rc
5050: 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a  ==SQLITE_ROW ){.
5060: 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72        const char
5070: 20 2a 7a 54 65 78 74 20 3d 20 28 63 6f 6e 73 74   *zText = (const
5080: 20 63 68 61 72 20 2a 29 73 71 6c 69 74 65 33 5f   char *)sqlite3_
5090: 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70 54 61 62  column_text(pTab
50a0: 6c 65 49 6e 66 6f 2c 20 31 29 3b 0a 20 20 20 20  leInfo, 1);.    
50b0: 20 20 7a 53 65 6c 65 63 74 20 3d 20 61 70 70 65    zSelect = appe
50c0: 6e 64 54 65 78 74 28 7a 53 65 6c 65 63 74 2c 20  ndText(zSelect, 
50d0: 22 71 75 6f 74 65 28 22 2c 20 30 29 3b 0a 20 20  "quote(", 0);.  
50e0: 20 20 20 20 7a 53 65 6c 65 63 74 20 3d 20 61 70      zSelect = ap
50f0: 70 65 6e 64 54 65 78 74 28 7a 53 65 6c 65 63 74  pendText(zSelect
5100: 2c 20 7a 54 65 78 74 2c 20 27 22 27 29 3b 0a 20  , zText, '"');. 
5110: 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65       rc = sqlite
5120: 33 5f 73 74 65 70 28 70 54 61 62 6c 65 49 6e 66  3_step(pTableInf
5130: 6f 29 3b 0a 20 20 20 20 20 20 69 66 28 20 72 63  o);.      if( rc
5140: 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a  ==SQLITE_ROW ){.
5150: 20 20 20 20 20 20 20 20 7a 53 65 6c 65 63 74 20          zSelect 
5160: 3d 20 61 70 70 65 6e 64 54 65 78 74 28 7a 53 65  = appendText(zSe
5170: 6c 65 63 74 2c 20 22 29 20 7c 7c 20 27 2c 27 20  lect, ") || ',' 
5180: 7c 7c 20 22 2c 20 30 29 3b 0a 20 20 20 20 20 20  || ", 0);.      
5190: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 7a  }else{.        z
51a0: 53 65 6c 65 63 74 20 3d 20 61 70 70 65 6e 64 54  Select = appendT
51b0: 65 78 74 28 7a 53 65 6c 65 63 74 2c 20 22 29 20  ext(zSelect, ") 
51c0: 22 2c 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 20  ", 0);.      }. 
51d0: 20 20 20 7d 0a 20 20 20 20 72 63 20 3d 20 73 71     }.    rc = sq
51e0: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
51f0: 54 61 62 6c 65 49 6e 66 6f 29 3b 0a 20 20 20 20  TableInfo);.    
5200: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f  if( rc!=SQLITE_O
5210: 4b 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 7a  K ){.      if( z
5220: 53 65 6c 65 63 74 20 29 20 66 72 65 65 28 7a 53  Select ) free(zS
5230: 65 6c 65 63 74 29 3b 0a 20 20 20 20 20 20 72 65  elect);.      re
5240: 74 75 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 20 20  turn 1;.    }.  
5250: 20 20 7a 53 65 6c 65 63 74 20 3d 20 61 70 70 65    zSelect = appe
5260: 6e 64 54 65 78 74 28 7a 53 65 6c 65 63 74 2c 20  ndText(zSelect, 
5270: 22 7c 7c 20 27 29 27 20 46 52 4f 4d 20 20 22 2c  "|| ')' FROM  ",
5280: 20 30 29 3b 0a 20 20 20 20 7a 53 65 6c 65 63 74   0);.    zSelect
5290: 20 3d 20 61 70 70 65 6e 64 54 65 78 74 28 7a 53   = appendText(zS
52a0: 65 6c 65 63 74 2c 20 7a 54 61 62 6c 65 2c 20 27  elect, zTable, '
52b0: 22 27 29 3b 0a 0a 20 20 20 20 72 63 20 3d 20 72  "');..    rc = r
52c0: 75 6e 5f 74 61 62 6c 65 5f 64 75 6d 70 5f 71 75  un_table_dump_qu
52d0: 65 72 79 28 70 2d 3e 6f 75 74 2c 20 70 2d 3e 64  ery(p->out, p->d
52e0: 62 2c 20 7a 53 65 6c 65 63 74 29 3b 0a 20 20 20  b, zSelect);.   
52f0: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
5300: 43 4f 52 52 55 50 54 20 29 7b 0a 20 20 20 20 20  CORRUPT ){.     
5310: 20 7a 53 65 6c 65 63 74 20 3d 20 61 70 70 65 6e   zSelect = appen
5320: 64 54 65 78 74 28 7a 53 65 6c 65 63 74 2c 20 22  dText(zSelect, "
5330: 20 4f 52 44 45 52 20 42 59 20 72 6f 77 69 64 20   ORDER BY rowid 
5340: 44 45 53 43 22 2c 20 30 29 3b 0a 20 20 20 20 20  DESC", 0);.     
5350: 20 72 63 20 3d 20 72 75 6e 5f 74 61 62 6c 65 5f   rc = run_table_
5360: 64 75 6d 70 5f 71 75 65 72 79 28 70 2d 3e 6f 75  dump_query(p->ou
5370: 74 2c 20 70 2d 3e 64 62 2c 20 7a 53 65 6c 65 63  t, p->db, zSelec
5380: 74 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66  t);.    }.    if
5390: 28 20 7a 53 65 6c 65 63 74 20 29 20 66 72 65 65  ( zSelect ) free
53a0: 28 7a 53 65 6c 65 63 74 29 3b 0a 20 20 7d 0a 20  (zSelect);.  }. 
53b0: 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a   return 0;.}../*
53c0: 0a 2a 2a 20 52 75 6e 20 7a 51 75 65 72 79 2e 20  .** Run zQuery. 
53d0: 20 55 73 65 20 64 75 6d 70 5f 63 61 6c 6c 62 61   Use dump_callba
53e0: 63 6b 28 29 20 61 73 20 74 68 65 20 63 61 6c 6c  ck() as the call
53f0: 62 61 63 6b 20 72 6f 75 74 69 6e 65 20 73 6f 20  back routine so 
5400: 74 68 61 74 0a 2a 2a 20 74 68 65 20 63 6f 6e 74  that.** the cont
5410: 65 6e 74 73 20 6f 66 20 74 68 65 20 71 75 65 72  ents of the quer
5420: 79 20 61 72 65 20 6f 75 74 70 75 74 20 61 73 20  y are output as 
5430: 53 51 4c 20 73 74 61 74 65 6d 65 6e 74 73 2e 0a  SQL statements..
5440: 2a 2a 0a 2a 2a 20 49 66 20 77 65 20 67 65 74 20  **.** If we get 
5450: 61 20 53 51 4c 49 54 45 5f 43 4f 52 52 55 50 54  a SQLITE_CORRUPT
5460: 20 65 72 72 6f 72 2c 20 72 65 72 75 6e 20 74 68   error, rerun th
5470: 65 20 71 75 65 72 79 20 61 66 74 65 72 20 61 70  e query after ap
5480: 70 65 6e 64 69 6e 67 0a 2a 2a 20 22 4f 52 44 45  pending.** "ORDE
5490: 52 20 42 59 20 72 6f 77 69 64 20 44 45 53 43 22  R BY rowid DESC"
54a0: 20 74 6f 20 74 68 65 20 65 6e 64 2e 0a 2a 2f 0a   to the end..*/.
54b0: 73 74 61 74 69 63 20 69 6e 74 20 72 75 6e 5f 73  static int run_s
54c0: 63 68 65 6d 61 5f 64 75 6d 70 5f 71 75 65 72 79  chema_dump_query
54d0: 28 0a 20 20 73 74 72 75 63 74 20 63 61 6c 6c 62  (.  struct callb
54e0: 61 63 6b 5f 64 61 74 61 20 2a 70 2c 20 0a 20 20  ack_data *p, .  
54f0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 51 75 65  const char *zQue
5500: 72 79 2c 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45  ry,.  char **pzE
5510: 72 72 4d 73 67 0a 29 7b 0a 20 20 69 6e 74 20 72  rrMsg.){.  int r
5520: 63 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65  c;.  rc = sqlite
5530: 33 5f 65 78 65 63 28 70 2d 3e 64 62 2c 20 7a 51  3_exec(p->db, zQ
5540: 75 65 72 79 2c 20 64 75 6d 70 5f 63 61 6c 6c 62  uery, dump_callb
5550: 61 63 6b 2c 20 70 2c 20 70 7a 45 72 72 4d 73 67  ack, p, pzErrMsg
5560: 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c  );.  if( rc==SQL
5570: 49 54 45 5f 43 4f 52 52 55 50 54 20 29 7b 0a 20  ITE_CORRUPT ){. 
5580: 20 20 20 63 68 61 72 20 2a 7a 51 32 3b 0a 20 20     char *zQ2;.  
5590: 20 20 69 6e 74 20 6c 65 6e 20 3d 20 73 74 72 6c    int len = strl
55a0: 65 6e 28 7a 51 75 65 72 79 29 3b 0a 20 20 20 20  en(zQuery);.    
55b0: 69 66 28 20 70 7a 45 72 72 4d 73 67 20 29 20 73  if( pzErrMsg ) s
55c0: 71 6c 69 74 65 33 5f 66 72 65 65 28 2a 70 7a 45  qlite3_free(*pzE
55d0: 72 72 4d 73 67 29 3b 0a 20 20 20 20 7a 51 32 20  rrMsg);.    zQ2 
55e0: 3d 20 6d 61 6c 6c 6f 63 28 20 6c 65 6e 2b 31 30  = malloc( len+10
55f0: 30 20 29 3b 0a 20 20 20 20 69 66 28 20 7a 51 32  0 );.    if( zQ2
5600: 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 72 63 3b  ==0 ) return rc;
5610: 0a 20 20 20 20 73 70 72 69 6e 74 66 28 7a 51 32  .    sprintf(zQ2
5620: 2c 20 22 25 73 20 4f 52 44 45 52 20 42 59 20 72  , "%s ORDER BY r
5630: 6f 77 69 64 20 44 45 53 43 22 2c 20 7a 51 75 65  owid DESC", zQue
5640: 72 79 29 3b 0a 20 20 20 20 72 63 20 3d 20 73 71  ry);.    rc = sq
5650: 6c 69 74 65 33 5f 65 78 65 63 28 70 2d 3e 64 62  lite3_exec(p->db
5660: 2c 20 7a 51 32 2c 20 64 75 6d 70 5f 63 61 6c 6c  , zQ2, dump_call
5670: 62 61 63 6b 2c 20 70 2c 20 70 7a 45 72 72 4d 73  back, p, pzErrMs
5680: 67 29 3b 0a 20 20 20 20 66 72 65 65 28 7a 51 32  g);.    free(zQ2
5690: 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20  );.  }.  return 
56a0: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 65 78  rc;.}../*.** Tex
56b0: 74 20 6f 66 20 61 20 68 65 6c 70 20 6d 65 73 73  t of a help mess
56c0: 61 67 65 0a 2a 2f 0a 73 74 61 74 69 63 20 63 68  age.*/.static ch
56d0: 61 72 20 7a 48 65 6c 70 5b 5d 20 3d 0a 20 20 22  ar zHelp[] =.  "
56e0: 2e 62 61 69 6c 20 4f 4e 7c 4f 46 46 20 20 20 20  .bail ON|OFF    
56f0: 20 20 20 20 20 20 20 53 74 6f 70 20 61 66 74 65         Stop afte
5700: 72 20 68 69 74 74 69 6e 67 20 61 6e 20 65 72 72  r hitting an err
5710: 6f 72 2e 20 20 44 65 66 61 75 6c 74 20 4f 46 46  or.  Default OFF
5720: 5c 6e 22 0a 20 20 22 2e 64 61 74 61 62 61 73 65  \n".  ".database
5730: 73 20 20 20 20 20 20 20 20 20 20 20 20 20 4c 69  s             Li
5740: 73 74 20 6e 61 6d 65 73 20 61 6e 64 20 66 69 6c  st names and fil
5750: 65 73 20 6f 66 20 61 74 74 61 63 68 65 64 20 64  es of attached d
5760: 61 74 61 62 61 73 65 73 5c 6e 22 0a 20 20 22 2e  atabases\n".  ".
5770: 64 75 6d 70 20 3f 54 41 42 4c 45 3f 20 2e 2e 2e  dump ?TABLE? ...
5780: 20 20 20 20 20 20 44 75 6d 70 20 74 68 65 20 64        Dump the d
5790: 61 74 61 62 61 73 65 20 69 6e 20 61 6e 20 53 51  atabase in an SQ
57a0: 4c 20 74 65 78 74 20 66 6f 72 6d 61 74 5c 6e 22  L text format\n"
57b0: 0a 20 20 22 2e 65 63 68 6f 20 4f 4e 7c 4f 46 46  .  ".echo ON|OFF
57c0: 20 20 20 20 20 20 20 20 20 20 20 54 75 72 6e 20             Turn 
57d0: 63 6f 6d 6d 61 6e 64 20 65 63 68 6f 20 6f 6e 20  command echo on 
57e0: 6f 72 20 6f 66 66 5c 6e 22 0a 20 20 22 2e 65 78  or off\n".  ".ex
57f0: 69 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20  it              
5800: 20 20 20 20 45 78 69 74 20 74 68 69 73 20 70 72      Exit this pr
5810: 6f 67 72 61 6d 5c 6e 22 0a 20 20 22 2e 65 78 70  ogram\n".  ".exp
5820: 6c 61 69 6e 20 4f 4e 7c 4f 46 46 20 20 20 20 20  lain ON|OFF     
5830: 20 20 20 54 75 72 6e 20 6f 75 74 70 75 74 20 6d     Turn output m
5840: 6f 64 65 20 73 75 69 74 61 62 6c 65 20 66 6f 72  ode suitable for
5850: 20 45 58 50 4c 41 49 4e 20 6f 6e 20 6f 72 20 6f   EXPLAIN on or o
5860: 66 66 2e 5c 6e 22 0a 20 20 22 2e 68 65 61 64 65  ff.\n".  ".heade
5870: 72 28 73 29 20 4f 4e 7c 4f 46 46 20 20 20 20 20  r(s) ON|OFF     
5880: 20 54 75 72 6e 20 64 69 73 70 6c 61 79 20 6f 66   Turn display of
5890: 20 68 65 61 64 65 72 73 20 6f 6e 20 6f 72 20 6f   headers on or o
58a0: 66 66 5c 6e 22 0a 20 20 22 2e 68 65 6c 70 20 20  ff\n".  ".help  
58b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
58c0: 53 68 6f 77 20 74 68 69 73 20 6d 65 73 73 61 67  Show this messag
58d0: 65 5c 6e 22 0a 20 20 22 2e 69 6d 70 6f 72 74 20  e\n".  ".import 
58e0: 46 49 4c 45 20 54 41 42 4c 45 20 20 20 20 20 49  FILE TABLE     I
58f0: 6d 70 6f 72 74 20 64 61 74 61 20 66 72 6f 6d 20  mport data from 
5900: 46 49 4c 45 20 69 6e 74 6f 20 54 41 42 4c 45 5c  FILE into TABLE\
5910: 6e 22 0a 20 20 22 2e 69 6e 64 69 63 65 73 20 54  n".  ".indices T
5920: 41 42 4c 45 20 20 20 20 20 20 20 20 20 53 68 6f  ABLE         Sho
5930: 77 20 6e 61 6d 65 73 20 6f 66 20 61 6c 6c 20 69  w names of all i
5940: 6e 64 69 63 65 73 20 6f 6e 20 54 41 42 4c 45 5c  ndices on TABLE\
5950: 6e 22 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  n".#ifndef SQLIT
5960: 45 5f 4f 4d 49 54 5f 4c 4f 41 44 5f 45 58 54 45  E_OMIT_LOAD_EXTE
5970: 4e 53 49 4f 4e 0a 20 20 22 2e 6c 6f 61 64 20 46  NSION.  ".load F
5980: 49 4c 45 20 3f 45 4e 54 52 59 3f 20 20 20 20 20  ILE ?ENTRY?     
5990: 4c 6f 61 64 20 61 6e 20 65 78 74 65 6e 73 69 6f  Load an extensio
59a0: 6e 20 6c 69 62 72 61 72 79 5c 6e 22 0a 23 65 6e  n library\n".#en
59b0: 64 69 66 0a 20 20 22 2e 6d 6f 64 65 20 4d 4f 44  dif.  ".mode MOD
59c0: 45 20 3f 54 41 42 4c 45 3f 20 20 20 20 20 53 65  E ?TABLE?     Se
59d0: 74 20 6f 75 74 70 75 74 20 6d 6f 64 65 20 77 68  t output mode wh
59e0: 65 72 65 20 4d 4f 44 45 20 69 73 20 6f 6e 65 20  ere MODE is one 
59f0: 6f 66 3a 5c 6e 22 0a 20 20 22 20 20 20 20 20 20  of:\n".  "      
5a00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5a10: 20 20 20 63 73 76 20 20 20 20 20 20 43 6f 6d 6d     csv      Comm
5a20: 61 2d 73 65 70 61 72 61 74 65 64 20 76 61 6c 75  a-separated valu
5a30: 65 73 5c 6e 22 0a 20 20 22 20 20 20 20 20 20 20  es\n".  "       
5a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5a50: 20 20 63 6f 6c 75 6d 6e 20 20 20 4c 65 66 74 2d    column   Left-
5a60: 61 6c 69 67 6e 65 64 20 63 6f 6c 75 6d 6e 73 2e  aligned columns.
5a70: 20 20 28 53 65 65 20 2e 77 69 64 74 68 29 5c 6e    (See .width)\n
5a80: 22 0a 20 20 22 20 20 20 20 20 20 20 20 20 20 20  ".  "           
5a90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 68 74                ht
5aa0: 6d 6c 20 20 20 20 20 48 54 4d 4c 20 3c 74 61 62  ml     HTML <tab
5ab0: 6c 65 3e 20 63 6f 64 65 5c 6e 22 0a 20 20 22 20  le> code\n".  " 
5ac0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5ad0: 20 20 20 20 20 20 20 20 69 6e 73 65 72 74 20 20          insert  
5ae0: 20 53 51 4c 20 69 6e 73 65 72 74 20 73 74 61 74   SQL insert stat
5af0: 65 6d 65 6e 74 73 20 66 6f 72 20 54 41 42 4c 45  ements for TABLE
5b00: 5c 6e 22 0a 20 20 22 20 20 20 20 20 20 20 20 20  \n".  "         
5b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5b20: 6c 69 6e 65 20 20 20 20 20 4f 6e 65 20 76 61 6c  line     One val
5b30: 75 65 20 70 65 72 20 6c 69 6e 65 5c 6e 22 0a 20  ue per line\n". 
5b40: 20 22 20 20 20 20 20 20 20 20 20 20 20 20 20 20   "              
5b50: 20 20 20 20 20 20 20 20 20 20 20 6c 69 73 74 20             list 
5b60: 20 20 20 20 56 61 6c 75 65 73 20 64 65 6c 69 6d      Values delim
5b70: 69 74 65 64 20 62 79 20 2e 73 65 70 61 72 61 74  ited by .separat
5b80: 6f 72 20 73 74 72 69 6e 67 5c 6e 22 0a 20 20 22  or string\n".  "
5b90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5ba0: 20 20 20 20 20 20 20 20 20 74 61 62 73 20 20 20           tabs   
5bb0: 20 20 54 61 62 2d 73 65 70 61 72 61 74 65 64 20    Tab-separated 
5bc0: 76 61 6c 75 65 73 5c 6e 22 0a 20 20 22 20 20 20  values\n".  "   
5bd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5be0: 20 20 20 20 20 20 74 63 6c 20 20 20 20 20 20 54        tcl      T
5bf0: 43 4c 20 6c 69 73 74 20 65 6c 65 6d 65 6e 74 73  CL list elements
5c00: 5c 6e 22 0a 20 20 22 2e 6e 75 6c 6c 76 61 6c 75  \n".  ".nullvalu
5c10: 65 20 53 54 52 49 4e 47 20 20 20 20 20 20 50 72  e STRING      Pr
5c20: 69 6e 74 20 53 54 52 49 4e 47 20 69 6e 20 70 6c  int STRING in pl
5c30: 61 63 65 20 6f 66 20 4e 55 4c 4c 20 76 61 6c 75  ace of NULL valu
5c40: 65 73 5c 6e 22 0a 20 20 22 2e 6f 75 74 70 75 74  es\n".  ".output
5c50: 20 46 49 4c 45 4e 41 4d 45 20 20 20 20 20 20 20   FILENAME       
5c60: 53 65 6e 64 20 6f 75 74 70 75 74 20 74 6f 20 46  Send output to F
5c70: 49 4c 45 4e 41 4d 45 5c 6e 22 0a 20 20 22 2e 6f  ILENAME\n".  ".o
5c80: 75 74 70 75 74 20 73 74 64 6f 75 74 20 20 20 20  utput stdout    
5c90: 20 20 20 20 20 53 65 6e 64 20 6f 75 74 70 75 74       Send output
5ca0: 20 74 6f 20 74 68 65 20 73 63 72 65 65 6e 5c 6e   to the screen\n
5cb0: 22 0a 20 20 22 2e 70 72 6f 6d 70 74 20 4d 41 49  ".  ".prompt MAI
5cc0: 4e 20 43 4f 4e 54 49 4e 55 45 20 20 52 65 70 6c  N CONTINUE  Repl
5cd0: 61 63 65 20 74 68 65 20 73 74 61 6e 64 61 72 64  ace the standard
5ce0: 20 70 72 6f 6d 70 74 73 5c 6e 22 0a 20 20 22 2e   prompts\n".  ".
5cf0: 71 75 69 74 20 20 20 20 20 20 20 20 20 20 20 20  quit            
5d00: 20 20 20 20 20 20 45 78 69 74 20 74 68 69 73 20        Exit this 
5d10: 70 72 6f 67 72 61 6d 5c 6e 22 0a 20 20 22 2e 72  program\n".  ".r
5d20: 65 61 64 20 46 49 4c 45 4e 41 4d 45 20 20 20 20  ead FILENAME    
5d30: 20 20 20 20 20 45 78 65 63 75 74 65 20 53 51 4c       Execute SQL
5d40: 20 69 6e 20 46 49 4c 45 4e 41 4d 45 5c 6e 22 0a   in FILENAME\n".
5d50: 20 20 22 2e 73 63 68 65 6d 61 20 3f 54 41 42 4c    ".schema ?TABL
5d60: 45 3f 20 20 20 20 20 20 20 20 53 68 6f 77 20 74  E?        Show t
5d70: 68 65 20 43 52 45 41 54 45 20 73 74 61 74 65 6d  he CREATE statem
5d80: 65 6e 74 73 5c 6e 22 0a 20 20 22 2e 73 65 70 61  ents\n".  ".sepa
5d90: 72 61 74 6f 72 20 53 54 52 49 4e 47 20 20 20 20  rator STRING    
5da0: 20 20 43 68 61 6e 67 65 20 73 65 70 61 72 61 74    Change separat
5db0: 6f 72 20 75 73 65 64 20 62 79 20 6f 75 74 70 75  or used by outpu
5dc0: 74 20 6d 6f 64 65 20 61 6e 64 20 2e 69 6d 70 6f  t mode and .impo
5dd0: 72 74 5c 6e 22 0a 20 20 22 2e 73 68 6f 77 20 20  rt\n".  ".show  
5de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5df0: 53 68 6f 77 20 74 68 65 20 63 75 72 72 65 6e 74  Show the current
5e00: 20 76 61 6c 75 65 73 20 66 6f 72 20 76 61 72 69   values for vari
5e10: 6f 75 73 20 73 65 74 74 69 6e 67 73 5c 6e 22 0a  ous settings\n".
5e20: 20 20 22 2e 74 61 62 6c 65 73 20 3f 50 41 54 54    ".tables ?PATT
5e30: 45 52 4e 3f 20 20 20 20 20 20 4c 69 73 74 20 6e  ERN?      List n
5e40: 61 6d 65 73 20 6f 66 20 74 61 62 6c 65 73 20 6d  ames of tables m
5e50: 61 74 63 68 69 6e 67 20 61 20 4c 49 4b 45 20 70  atching a LIKE p
5e60: 61 74 74 65 72 6e 5c 6e 22 0a 20 20 22 2e 74 69  attern\n".  ".ti
5e70: 6d 65 6f 75 74 20 4d 53 20 20 20 20 20 20 20 20  meout MS        
5e80: 20 20 20 20 54 72 79 20 6f 70 65 6e 69 6e 67 20      Try opening 
5e90: 6c 6f 63 6b 65 64 20 74 61 62 6c 65 73 20 66 6f  locked tables fo
5ea0: 72 20 4d 53 20 6d 69 6c 6c 69 73 65 63 6f 6e 64  r MS millisecond
5eb0: 73 5c 6e 22 0a 20 20 22 2e 77 69 64 74 68 20 4e  s\n".  ".width N
5ec0: 55 4d 20 4e 55 4d 20 2e 2e 2e 20 20 20 20 20 53  UM NUM ...     S
5ed0: 65 74 20 63 6f 6c 75 6d 6e 20 77 69 64 74 68 73  et column widths
5ee0: 20 66 6f 72 20 5c 22 63 6f 6c 75 6d 6e 5c 22 20   for \"column\" 
5ef0: 6d 6f 64 65 5c 6e 22 0a 3b 0a 0a 2f 2a 20 46 6f  mode\n".;../* Fo
5f00: 72 77 61 72 64 20 72 65 66 65 72 65 6e 63 65 20  rward reference 
5f10: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 70 72  */.static int pr
5f20: 6f 63 65 73 73 5f 69 6e 70 75 74 28 73 74 72 75  ocess_input(stru
5f30: 63 74 20 63 61 6c 6c 62 61 63 6b 5f 64 61 74 61  ct callback_data
5f40: 20 2a 70 2c 20 46 49 4c 45 20 2a 69 6e 29 3b 0a   *p, FILE *in);.
5f50: 0a 2f 2a 0a 2a 2a 20 4d 61 6b 65 20 73 75 72 65  ./*.** Make sure
5f60: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 69 73   the database is
5f70: 20 6f 70 65 6e 2e 20 20 49 66 20 69 74 20 69 73   open.  If it is
5f80: 20 6e 6f 74 2c 20 74 68 65 6e 20 6f 70 65 6e 20   not, then open 
5f90: 69 74 2e 20 20 49 66 0a 2a 2a 20 74 68 65 20 64  it.  If.** the d
5fa0: 61 74 61 62 61 73 65 20 66 61 69 6c 73 20 74 6f  atabase fails to
5fb0: 20 6f 70 65 6e 2c 20 70 72 69 6e 74 20 61 6e 20   open, print an 
5fc0: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 61 6e  error message an
5fd0: 64 20 65 78 69 74 2e 0a 2a 2f 0a 73 74 61 74 69  d exit..*/.stati
5fe0: 63 20 76 6f 69 64 20 6f 70 65 6e 5f 64 62 28 73  c void open_db(s
5ff0: 74 72 75 63 74 20 63 61 6c 6c 62 61 63 6b 5f 64  truct callback_d
6000: 61 74 61 20 2a 70 29 7b 0a 20 20 69 66 28 20 70  ata *p){.  if( p
6010: 2d 3e 64 62 3d 3d 30 20 29 7b 0a 20 20 20 20 73  ->db==0 ){.    s
6020: 71 6c 69 74 65 33 5f 6f 70 65 6e 28 70 2d 3e 7a  qlite3_open(p->z
6030: 44 62 46 69 6c 65 6e 61 6d 65 2c 20 26 70 2d 3e  DbFilename, &p->
6040: 64 62 29 3b 0a 20 20 20 20 64 62 20 3d 20 70 2d  db);.    db = p-
6050: 3e 64 62 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  >db;.    sqlite3
6060: 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e  _create_function
6070: 28 64 62 2c 20 22 73 68 65 6c 6c 73 74 61 74 69  (db, "shellstati
6080: 63 22 2c 20 30 2c 20 53 51 4c 49 54 45 5f 55 54  c", 0, SQLITE_UT
6090: 46 38 2c 20 30 2c 0a 20 20 20 20 20 20 20 20 73  F8, 0,.        s
60a0: 68 65 6c 6c 73 74 61 74 69 63 46 75 6e 63 2c 20  hellstaticFunc, 
60b0: 30 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20 53  0, 0);.    if( S
60c0: 51 4c 49 54 45 5f 4f 4b 21 3d 73 71 6c 69 74 65  QLITE_OK!=sqlite
60d0: 33 5f 65 72 72 63 6f 64 65 28 64 62 29 20 29 7b  3_errcode(db) ){
60e0: 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 73  .      fprintf(s
60f0: 74 64 65 72 72 2c 22 55 6e 61 62 6c 65 20 74 6f  tderr,"Unable to
6100: 20 6f 70 65 6e 20 64 61 74 61 62 61 73 65 20 5c   open database \
6110: 22 25 73 5c 22 3a 20 25 73 5c 6e 22 2c 20 0a 20  "%s\": %s\n", . 
6120: 20 20 20 20 20 20 20 20 20 70 2d 3e 7a 44 62 46           p->zDbF
6130: 69 6c 65 6e 61 6d 65 2c 20 73 71 6c 69 74 65 33  ilename, sqlite3
6140: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
6150: 20 20 20 20 65 78 69 74 28 31 29 3b 0a 20 20 20      exit(1);.   
6160: 20 7d 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54   }.#ifndef SQLIT
6170: 45 5f 4f 4d 49 54 5f 4c 4f 41 44 5f 45 58 54 45  E_OMIT_LOAD_EXTE
6180: 4e 53 49 4f 4e 0a 20 20 20 20 73 71 6c 69 74 65  NSION.    sqlite
6190: 33 5f 65 6e 61 62 6c 65 5f 6c 6f 61 64 5f 65 78  3_enable_load_ex
61a0: 74 65 6e 73 69 6f 6e 28 70 2d 3e 64 62 2c 20 31  tension(p->db, 1
61b0: 29 3b 0a 23 65 6e 64 69 66 0a 20 20 7d 0a 7d 0a  );.#endif.  }.}.
61c0: 0a 2f 2a 0a 2a 2a 20 44 6f 20 43 2d 6c 61 6e 67  ./*.** Do C-lang
61d0: 75 61 67 65 20 73 74 79 6c 65 20 64 65 71 75 6f  uage style dequo
61e0: 74 69 6e 67 2e 0a 2a 2a 0a 2a 2a 20 20 20 20 5c  ting..**.**    \
61f0: 74 20 20 20 20 2d 3e 20 74 61 62 0a 2a 2a 20 20  t    -> tab.**  
6200: 20 20 5c 6e 20 20 20 20 2d 3e 20 6e 65 77 6c 69    \n    -> newli
6210: 6e 65 0a 2a 2a 20 20 20 20 5c 72 20 20 20 20 2d  ne.**    \r    -
6220: 3e 20 63 61 72 72 69 61 67 65 20 72 65 74 75 72  > carriage retur
6230: 6e 0a 2a 2a 20 20 20 20 5c 4e 4e 4e 20 20 2d 3e  n.**    \NNN  ->
6240: 20 61 73 63 69 69 20 63 68 61 72 61 63 74 65 72   ascii character
6250: 20 4e 4e 4e 20 69 6e 20 6f 63 74 61 6c 0a 2a 2a   NNN in octal.**
6260: 20 20 20 20 5c 5c 20 20 20 20 2d 3e 20 62 61 63      \\    -> bac
6270: 6b 73 6c 61 73 68 0a 2a 2f 0a 73 74 61 74 69 63  kslash.*/.static
6280: 20 76 6f 69 64 20 72 65 73 6f 6c 76 65 5f 62 61   void resolve_ba
6290: 63 6b 73 6c 61 73 68 65 73 28 63 68 61 72 20 2a  ckslashes(char *
62a0: 7a 29 7b 0a 20 20 69 6e 74 20 69 2c 20 6a 2c 20  z){.  int i, j, 
62b0: 63 3b 0a 20 20 66 6f 72 28 69 3d 6a 3d 30 3b 20  c;.  for(i=j=0; 
62c0: 28 63 20 3d 20 7a 5b 69 5d 29 21 3d 30 3b 20 69  (c = z[i])!=0; i
62d0: 2b 2b 2c 20 6a 2b 2b 29 7b 0a 20 20 20 20 69 66  ++, j++){.    if
62e0: 28 20 63 3d 3d 27 5c 5c 27 20 29 7b 0a 20 20 20  ( c=='\\' ){.   
62f0: 20 20 20 63 20 3d 20 7a 5b 2b 2b 69 5d 3b 0a 20     c = z[++i];. 
6300: 20 20 20 20 20 69 66 28 20 63 3d 3d 27 6e 27 20       if( c=='n' 
6310: 29 7b 0a 20 20 20 20 20 20 20 20 63 20 3d 20 27  ){.        c = '
6320: 5c 6e 27 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  \n';.      }else
6330: 20 69 66 28 20 63 3d 3d 27 74 27 20 29 7b 0a 20   if( c=='t' ){. 
6340: 20 20 20 20 20 20 20 63 20 3d 20 27 5c 74 27 3b         c = '\t';
6350: 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28  .      }else if(
6360: 20 63 3d 3d 27 72 27 20 29 7b 0a 20 20 20 20 20   c=='r' ){.     
6370: 20 20 20 63 20 3d 20 27 5c 72 27 3b 0a 20 20 20     c = '\r';.   
6380: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 63 3e 3d     }else if( c>=
6390: 27 30 27 20 26 26 20 63 3c 3d 27 37 27 20 29 7b  '0' && c<='7' ){
63a0: 0a 20 20 20 20 20 20 20 20 63 20 2d 3d 20 27 30  .        c -= '0
63b0: 27 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 7a  ';.        if( z
63c0: 5b 69 2b 31 5d 3e 3d 27 30 27 20 26 26 20 7a 5b  [i+1]>='0' && z[
63d0: 69 2b 31 5d 3c 3d 27 37 27 20 29 7b 0a 20 20 20  i+1]<='7' ){.   
63e0: 20 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20         i++;.    
63f0: 20 20 20 20 20 20 63 20 3d 20 28 63 3c 3c 33 29        c = (c<<3)
6400: 20 2b 20 7a 5b 69 5d 20 2d 20 27 30 27 3b 0a 20   + z[i] - '0';. 
6410: 20 20 20 20 20 20 20 20 20 69 66 28 20 7a 5b 69           if( z[i
6420: 2b 31 5d 3e 3d 27 30 27 20 26 26 20 7a 5b 69 2b  +1]>='0' && z[i+
6430: 31 5d 3c 3d 27 37 27 20 29 7b 0a 20 20 20 20 20  1]<='7' ){.     
6440: 20 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20         i++;.    
6450: 20 20 20 20 20 20 20 20 63 20 3d 20 28 63 3c 3c          c = (c<<
6460: 33 29 20 2b 20 7a 5b 69 5d 20 2d 20 27 30 27 3b  3) + z[i] - '0';
6470: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20  .          }.   
6480: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20       }.      }. 
6490: 20 20 20 7d 0a 20 20 20 20 7a 5b 6a 5d 20 3d 20     }.    z[j] = 
64a0: 63 3b 0a 20 20 7d 0a 20 20 7a 5b 6a 5d 20 3d 20  c;.  }.  z[j] = 
64b0: 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74 65  0;.}../*.** Inte
64c0: 72 70 72 65 74 20 7a 41 72 67 20 61 73 20 61 20  rpret zArg as a 
64d0: 62 6f 6f 6c 65 61 6e 20 76 61 6c 75 65 2e 20 20  boolean value.  
64e0: 52 65 74 75 72 6e 20 65 69 74 68 65 72 20 30 20  Return either 0 
64f0: 6f 72 20 31 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  or 1..*/.static 
6500: 69 6e 74 20 62 6f 6f 6c 65 61 6e 56 61 6c 75 65  int booleanValue
6510: 28 63 68 61 72 20 2a 7a 41 72 67 29 7b 0a 20 20  (char *zArg){.  
6520: 69 6e 74 20 76 61 6c 20 3d 20 61 74 6f 69 28 7a  int val = atoi(z
6530: 41 72 67 29 3b 0a 20 20 69 6e 74 20 6a 3b 0a 20  Arg);.  int j;. 
6540: 20 66 6f 72 28 6a 3d 30 3b 20 7a 41 72 67 5b 6a   for(j=0; zArg[j
6550: 5d 3b 20 6a 2b 2b 29 7b 0a 20 20 20 20 7a 41 72  ]; j++){.    zAr
6560: 67 5b 6a 5d 20 3d 20 74 6f 6c 6f 77 65 72 28 7a  g[j] = tolower(z
6570: 41 72 67 5b 6a 5d 29 3b 0a 20 20 7d 0a 20 20 69  Arg[j]);.  }.  i
6580: 66 28 20 73 74 72 63 6d 70 28 7a 41 72 67 2c 22  f( strcmp(zArg,"
6590: 6f 6e 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 76  on")==0 ){.    v
65a0: 61 6c 20 3d 20 31 3b 0a 20 20 7d 65 6c 73 65 20  al = 1;.  }else 
65b0: 69 66 28 20 73 74 72 63 6d 70 28 7a 41 72 67 2c  if( strcmp(zArg,
65c0: 22 79 65 73 22 29 3d 3d 30 20 29 7b 0a 20 20 20  "yes")==0 ){.   
65d0: 20 76 61 6c 20 3d 20 31 3b 0a 20 20 7d 0a 20 20   val = 1;.  }.  
65e0: 72 65 74 75 72 6e 20 76 61 6c 3b 0a 7d 0a 0a 2f  return val;.}../
65f0: 2a 0a 2a 2a 20 49 66 20 61 6e 20 69 6e 70 75 74  *.** If an input
6600: 20 6c 69 6e 65 20 62 65 67 69 6e 73 20 77 69 74   line begins wit
6610: 68 20 22 2e 22 20 74 68 65 6e 20 69 6e 76 6f 6b  h "." then invok
6620: 65 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 74  e this routine t
6630: 6f 0a 2a 2a 20 70 72 6f 63 65 73 73 20 74 68 61  o.** process tha
6640: 74 20 6c 69 6e 65 2e 0a 2a 2a 0a 2a 2a 20 52 65  t line..**.** Re
6650: 74 75 72 6e 20 31 20 6f 6e 20 65 72 72 6f 72 2c  turn 1 on error,
6660: 20 32 20 74 6f 20 65 78 69 74 2c 20 61 6e 64 20   2 to exit, and 
6670: 30 20 6f 74 68 65 72 77 69 73 65 2e 0a 2a 2f 0a  0 otherwise..*/.
6680: 73 74 61 74 69 63 20 69 6e 74 20 64 6f 5f 6d 65  static int do_me
6690: 74 61 5f 63 6f 6d 6d 61 6e 64 28 63 68 61 72 20  ta_command(char 
66a0: 2a 7a 4c 69 6e 65 2c 20 73 74 72 75 63 74 20 63  *zLine, struct c
66b0: 61 6c 6c 62 61 63 6b 5f 64 61 74 61 20 2a 70 29  allback_data *p)
66c0: 7b 0a 20 20 69 6e 74 20 69 20 3d 20 31 3b 0a 20  {.  int i = 1;. 
66d0: 20 69 6e 74 20 6e 41 72 67 20 3d 20 30 3b 0a 20   int nArg = 0;. 
66e0: 20 69 6e 74 20 6e 2c 20 63 3b 0a 20 20 69 6e 74   int n, c;.  int
66f0: 20 72 63 20 3d 20 30 3b 0a 20 20 63 68 61 72 20   rc = 0;.  char 
6700: 2a 61 7a 41 72 67 5b 35 30 5d 3b 0a 0a 20 20 2f  *azArg[50];..  /
6710: 2a 20 50 61 72 73 65 20 74 68 65 20 69 6e 70 75  * Parse the inpu
6720: 74 20 6c 69 6e 65 20 69 6e 74 6f 20 74 6f 6b 65  t line into toke
6730: 6e 73 2e 0a 20 20 2a 2f 0a 20 20 77 68 69 6c 65  ns..  */.  while
6740: 28 20 7a 4c 69 6e 65 5b 69 5d 20 26 26 20 6e 41  ( zLine[i] && nA
6750: 72 67 3c 41 72 72 61 79 53 69 7a 65 28 61 7a 41  rg<ArraySize(azA
6760: 72 67 29 20 29 7b 0a 20 20 20 20 77 68 69 6c 65  rg) ){.    while
6770: 28 20 69 73 73 70 61 63 65 28 28 75 6e 73 69 67  ( isspace((unsig
6780: 6e 65 64 20 63 68 61 72 29 7a 4c 69 6e 65 5b 69  ned char)zLine[i
6790: 5d 29 20 29 7b 20 69 2b 2b 3b 20 7d 0a 20 20 20  ]) ){ i++; }.   
67a0: 20 69 66 28 20 7a 4c 69 6e 65 5b 69 5d 3d 3d 30   if( zLine[i]==0
67b0: 20 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 69 66   ) break;.    if
67c0: 28 20 7a 4c 69 6e 65 5b 69 5d 3d 3d 27 5c 27 27  ( zLine[i]=='\''
67d0: 20 7c 7c 20 7a 4c 69 6e 65 5b 69 5d 3d 3d 27 22   || zLine[i]=='"
67e0: 27 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 64  ' ){.      int d
67f0: 65 6c 69 6d 20 3d 20 7a 4c 69 6e 65 5b 69 2b 2b  elim = zLine[i++
6800: 5d 3b 0a 20 20 20 20 20 20 61 7a 41 72 67 5b 6e  ];.      azArg[n
6810: 41 72 67 2b 2b 5d 20 3d 20 26 7a 4c 69 6e 65 5b  Arg++] = &zLine[
6820: 69 5d 3b 0a 20 20 20 20 20 20 77 68 69 6c 65 28  i];.      while(
6830: 20 7a 4c 69 6e 65 5b 69 5d 20 26 26 20 7a 4c 69   zLine[i] && zLi
6840: 6e 65 5b 69 5d 21 3d 64 65 6c 69 6d 20 29 7b 20  ne[i]!=delim ){ 
6850: 69 2b 2b 3b 20 7d 0a 20 20 20 20 20 20 69 66 28  i++; }.      if(
6860: 20 7a 4c 69 6e 65 5b 69 5d 3d 3d 64 65 6c 69 6d   zLine[i]==delim
6870: 20 29 7b 0a 20 20 20 20 20 20 20 20 7a 4c 69 6e   ){.        zLin
6880: 65 5b 69 2b 2b 5d 20 3d 20 30 3b 0a 20 20 20 20  e[i++] = 0;.    
6890: 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20 64 65    }.      if( de
68a0: 6c 69 6d 3d 3d 27 22 27 20 29 20 72 65 73 6f 6c  lim=='"' ) resol
68b0: 76 65 5f 62 61 63 6b 73 6c 61 73 68 65 73 28 61  ve_backslashes(a
68c0: 7a 41 72 67 5b 6e 41 72 67 2d 31 5d 29 3b 0a 20  zArg[nArg-1]);. 
68d0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
68e0: 61 7a 41 72 67 5b 6e 41 72 67 2b 2b 5d 20 3d 20  azArg[nArg++] = 
68f0: 26 7a 4c 69 6e 65 5b 69 5d 3b 0a 20 20 20 20 20  &zLine[i];.     
6900: 20 77 68 69 6c 65 28 20 7a 4c 69 6e 65 5b 69 5d   while( zLine[i]
6910: 20 26 26 20 21 69 73 73 70 61 63 65 28 28 75 6e   && !isspace((un
6920: 73 69 67 6e 65 64 20 63 68 61 72 29 7a 4c 69 6e  signed char)zLin
6930: 65 5b 69 5d 29 20 29 7b 20 69 2b 2b 3b 20 7d 0a  e[i]) ){ i++; }.
6940: 20 20 20 20 20 20 69 66 28 20 7a 4c 69 6e 65 5b        if( zLine[
6950: 69 5d 20 29 20 7a 4c 69 6e 65 5b 69 2b 2b 5d 20  i] ) zLine[i++] 
6960: 3d 20 30 3b 0a 20 20 20 20 20 20 72 65 73 6f 6c  = 0;.      resol
6970: 76 65 5f 62 61 63 6b 73 6c 61 73 68 65 73 28 61  ve_backslashes(a
6980: 7a 41 72 67 5b 6e 41 72 67 2d 31 5d 29 3b 0a 20  zArg[nArg-1]);. 
6990: 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20 50     }.  }..  /* P
69a0: 72 6f 63 65 73 73 20 74 68 65 20 69 6e 70 75 74  rocess the input
69b0: 20 6c 69 6e 65 2e 0a 20 20 2a 2f 0a 20 20 69 66   line..  */.  if
69c0: 28 20 6e 41 72 67 3d 3d 30 20 29 20 72 65 74 75  ( nArg==0 ) retu
69d0: 72 6e 20 72 63 3b 0a 20 20 6e 20 3d 20 73 74 72  rn rc;.  n = str
69e0: 6c 65 6e 28 61 7a 41 72 67 5b 30 5d 29 3b 0a 20  len(azArg[0]);. 
69f0: 20 63 20 3d 20 61 7a 41 72 67 5b 30 5d 5b 30 5d   c = azArg[0][0]
6a00: 3b 0a 20 20 69 66 28 20 63 3d 3d 27 62 27 20 26  ;.  if( c=='b' &
6a10: 26 20 6e 3e 31 20 26 26 20 73 74 72 6e 63 6d 70  & n>1 && strncmp
6a20: 28 61 7a 41 72 67 5b 30 5d 2c 20 22 62 61 69 6c  (azArg[0], "bail
6a30: 22 2c 20 6e 29 3d 3d 30 20 26 26 20 6e 41 72 67  ", n)==0 && nArg
6a40: 3e 31 20 29 7b 0a 20 20 20 20 62 61 69 6c 5f 6f  >1 ){.    bail_o
6a50: 6e 5f 65 72 72 6f 72 20 3d 20 62 6f 6f 6c 65 61  n_error = boolea
6a60: 6e 56 61 6c 75 65 28 61 7a 41 72 67 5b 31 5d 29  nValue(azArg[1])
6a70: 3b 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66 28  ;.  }else..  if(
6a80: 20 63 3d 3d 27 64 27 20 26 26 20 6e 3e 31 20 26   c=='d' && n>1 &
6a90: 26 20 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b  & strncmp(azArg[
6aa0: 30 5d 2c 20 22 64 61 74 61 62 61 73 65 73 22 2c  0], "databases",
6ab0: 20 6e 29 3d 3d 30 20 29 7b 0a 20 20 20 20 73 74   n)==0 ){.    st
6ac0: 72 75 63 74 20 63 61 6c 6c 62 61 63 6b 5f 64 61  ruct callback_da
6ad0: 74 61 20 64 61 74 61 3b 0a 20 20 20 20 63 68 61  ta data;.    cha
6ae0: 72 20 2a 7a 45 72 72 4d 73 67 20 3d 20 30 3b 0a  r *zErrMsg = 0;.
6af0: 20 20 20 20 6f 70 65 6e 5f 64 62 28 70 29 3b 0a      open_db(p);.
6b00: 20 20 20 20 6d 65 6d 63 70 79 28 26 64 61 74 61      memcpy(&data
6b10: 2c 20 70 2c 20 73 69 7a 65 6f 66 28 64 61 74 61  , p, sizeof(data
6b20: 29 29 3b 0a 20 20 20 20 64 61 74 61 2e 73 68 6f  ));.    data.sho
6b30: 77 48 65 61 64 65 72 20 3d 20 31 3b 0a 20 20 20  wHeader = 1;.   
6b40: 20 64 61 74 61 2e 6d 6f 64 65 20 3d 20 4d 4f 44   data.mode = MOD
6b50: 45 5f 43 6f 6c 75 6d 6e 3b 0a 20 20 20 20 64 61  E_Column;.    da
6b60: 74 61 2e 63 6f 6c 57 69 64 74 68 5b 30 5d 20 3d  ta.colWidth[0] =
6b70: 20 33 3b 0a 20 20 20 20 64 61 74 61 2e 63 6f 6c   3;.    data.col
6b80: 57 69 64 74 68 5b 31 5d 20 3d 20 31 35 3b 0a 20  Width[1] = 15;. 
6b90: 20 20 20 64 61 74 61 2e 63 6f 6c 57 69 64 74 68     data.colWidth
6ba0: 5b 32 5d 20 3d 20 35 38 3b 0a 20 20 20 20 64 61  [2] = 58;.    da
6bb0: 74 61 2e 63 6e 74 20 3d 20 30 3b 0a 20 20 20 20  ta.cnt = 0;.    
6bc0: 73 71 6c 69 74 65 33 5f 65 78 65 63 28 70 2d 3e  sqlite3_exec(p->
6bd0: 64 62 2c 20 22 50 52 41 47 4d 41 20 64 61 74 61  db, "PRAGMA data
6be0: 62 61 73 65 5f 6c 69 73 74 3b 20 22 2c 20 63 61  base_list; ", ca
6bf0: 6c 6c 62 61 63 6b 2c 20 26 64 61 74 61 2c 20 26  llback, &data, &
6c00: 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 69 66  zErrMsg);.    if
6c10: 28 20 7a 45 72 72 4d 73 67 20 29 7b 0a 20 20 20  ( zErrMsg ){.   
6c20: 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72     fprintf(stder
6c30: 72 2c 22 45 72 72 6f 72 3a 20 25 73 5c 6e 22 2c  r,"Error: %s\n",
6c40: 20 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20   zErrMsg);.     
6c50: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 45   sqlite3_free(zE
6c60: 72 72 4d 73 67 29 3b 0a 20 20 20 20 7d 0a 20 20  rrMsg);.    }.  
6c70: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d  }else..  if( c==
6c80: 27 64 27 20 26 26 20 73 74 72 6e 63 6d 70 28 61  'd' && strncmp(a
6c90: 7a 41 72 67 5b 30 5d 2c 20 22 64 75 6d 70 22 2c  zArg[0], "dump",
6ca0: 20 6e 29 3d 3d 30 20 29 7b 0a 20 20 20 20 63 68   n)==0 ){.    ch
6cb0: 61 72 20 2a 7a 45 72 72 4d 73 67 20 3d 20 30 3b  ar *zErrMsg = 0;
6cc0: 0a 20 20 20 20 6f 70 65 6e 5f 64 62 28 70 29 3b  .    open_db(p);
6cd0: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e  .    fprintf(p->
6ce0: 6f 75 74 2c 20 22 42 45 47 49 4e 20 54 52 41 4e  out, "BEGIN TRAN
6cf0: 53 41 43 54 49 4f 4e 3b 5c 6e 22 29 3b 0a 20 20  SACTION;\n");.  
6d00: 20 20 70 2d 3e 77 72 69 74 61 62 6c 65 53 63 68    p->writableSch
6d10: 65 6d 61 20 3d 20 30 3b 0a 20 20 20 20 69 66 28  ema = 0;.    if(
6d20: 20 6e 41 72 67 3d 3d 31 20 29 7b 0a 20 20 20 20   nArg==1 ){.    
6d30: 20 20 72 75 6e 5f 73 63 68 65 6d 61 5f 64 75 6d    run_schema_dum
6d40: 70 5f 71 75 65 72 79 28 70 2c 20 0a 20 20 20 20  p_query(p, .    
6d50: 20 20 20 20 22 53 45 4c 45 43 54 20 6e 61 6d 65      "SELECT name
6d60: 2c 20 74 79 70 65 2c 20 73 71 6c 20 46 52 4f 4d  , type, sql FROM
6d70: 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 22   sqlite_master "
6d80: 0a 20 20 20 20 20 20 20 20 22 57 48 45 52 45 20  .        "WHERE 
6d90: 73 71 6c 20 4e 4f 54 20 4e 55 4c 4c 20 41 4e 44  sql NOT NULL AND
6da0: 20 74 79 70 65 3d 3d 27 74 61 62 6c 65 27 22 2c   type=='table'",
6db0: 20 30 0a 20 20 20 20 20 20 29 3b 0a 20 20 20 20   0.      );.    
6dc0: 20 20 72 75 6e 5f 74 61 62 6c 65 5f 64 75 6d 70    run_table_dump
6dd0: 5f 71 75 65 72 79 28 70 2d 3e 6f 75 74 2c 20 70  _query(p->out, p
6de0: 2d 3e 64 62 2c 0a 20 20 20 20 20 20 20 20 22 53  ->db,.        "S
6df0: 45 4c 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 73  ELECT sql FROM s
6e00: 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 22 0a 20  qlite_master ". 
6e10: 20 20 20 20 20 20 20 22 57 48 45 52 45 20 73 71         "WHERE sq
6e20: 6c 20 4e 4f 54 20 4e 55 4c 4c 20 41 4e 44 20 74  l NOT NULL AND t
6e30: 79 70 65 20 49 4e 20 28 27 69 6e 64 65 78 27 2c  ype IN ('index',
6e40: 27 74 72 69 67 67 65 72 27 2c 27 76 69 65 77 27  'trigger','view'
6e50: 29 22 0a 20 20 20 20 20 20 29 3b 0a 20 20 20 20  )".      );.    
6e60: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74  }else{.      int
6e70: 20 69 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d   i;.      for(i=
6e80: 31 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b  1; i<nArg; i++){
6e90: 0a 20 20 20 20 20 20 20 20 7a 53 68 65 6c 6c 53  .        zShellS
6ea0: 74 61 74 69 63 20 3d 20 61 7a 41 72 67 5b 69 5d  tatic = azArg[i]
6eb0: 3b 0a 20 20 20 20 20 20 20 20 72 75 6e 5f 73 63  ;.        run_sc
6ec0: 68 65 6d 61 5f 64 75 6d 70 5f 71 75 65 72 79 28  hema_dump_query(
6ed0: 70 2c 0a 20 20 20 20 20 20 20 20 20 20 22 53 45  p,.          "SE
6ee0: 4c 45 43 54 20 6e 61 6d 65 2c 20 74 79 70 65 2c  LECT name, type,
6ef0: 20 73 71 6c 20 46 52 4f 4d 20 73 71 6c 69 74 65   sql FROM sqlite
6f00: 5f 6d 61 73 74 65 72 20 22 0a 20 20 20 20 20 20  _master ".      
6f10: 20 20 20 20 22 57 48 45 52 45 20 74 62 6c 5f 6e      "WHERE tbl_n
6f20: 61 6d 65 20 4c 49 4b 45 20 73 68 65 6c 6c 73 74  ame LIKE shellst
6f30: 61 74 69 63 28 29 20 41 4e 44 20 74 79 70 65 3d  atic() AND type=
6f40: 3d 27 74 61 62 6c 65 27 22 0a 20 20 20 20 20 20  ='table'".      
6f50: 20 20 20 20 22 20 20 41 4e 44 20 73 71 6c 20 4e      "  AND sql N
6f60: 4f 54 20 4e 55 4c 4c 22 2c 20 30 29 3b 0a 20 20  OT NULL", 0);.  
6f70: 20 20 20 20 20 20 72 75 6e 5f 74 61 62 6c 65 5f        run_table_
6f80: 64 75 6d 70 5f 71 75 65 72 79 28 70 2d 3e 6f 75  dump_query(p->ou
6f90: 74 2c 20 70 2d 3e 64 62 2c 0a 20 20 20 20 20 20  t, p->db,.      
6fa0: 20 20 20 20 22 53 45 4c 45 43 54 20 73 71 6c 20      "SELECT sql 
6fb0: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61 73 74  FROM sqlite_mast
6fc0: 65 72 20 22 0a 20 20 20 20 20 20 20 20 20 20 22  er ".          "
6fd0: 57 48 45 52 45 20 73 71 6c 20 4e 4f 54 20 4e 55  WHERE sql NOT NU
6fe0: 4c 4c 22 0a 20 20 20 20 20 20 20 20 20 20 22 20  LL".          " 
6ff0: 20 41 4e 44 20 74 79 70 65 20 49 4e 20 28 27 69   AND type IN ('i
7000: 6e 64 65 78 27 2c 27 74 72 69 67 67 65 72 27 2c  ndex','trigger',
7010: 27 76 69 65 77 27 29 22 0a 20 20 20 20 20 20 20  'view')".       
7020: 20 20 20 22 20 20 41 4e 44 20 74 62 6c 5f 6e 61     "  AND tbl_na
7030: 6d 65 20 4c 49 4b 45 20 73 68 65 6c 6c 73 74 61  me LIKE shellsta
7040: 74 69 63 28 29 22 0a 20 20 20 20 20 20 20 20 29  tic()".        )
7050: 3b 0a 20 20 20 20 20 20 20 20 7a 53 68 65 6c 6c  ;.        zShell
7060: 53 74 61 74 69 63 20 3d 20 30 3b 0a 20 20 20 20  Static = 0;.    
7070: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 69 66    }.    }.    if
7080: 28 20 70 2d 3e 77 72 69 74 61 62 6c 65 53 63 68  ( p->writableSch
7090: 65 6d 61 20 29 7b 0a 20 20 20 20 20 20 66 70 72  ema ){.      fpr
70a0: 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 20 22 50 52  intf(p->out, "PR
70b0: 41 47 4d 41 20 77 72 69 74 61 62 6c 65 5f 73 63  AGMA writable_sc
70c0: 68 65 6d 61 3d 4f 46 46 3b 5c 6e 22 29 3b 0a 20  hema=OFF;\n");. 
70d0: 20 20 20 20 20 70 2d 3e 77 72 69 74 61 62 6c 65       p->writable
70e0: 53 63 68 65 6d 61 20 3d 20 30 3b 0a 20 20 20 20  Schema = 0;.    
70f0: 7d 0a 20 20 20 20 69 66 28 20 7a 45 72 72 4d 73  }.    if( zErrMs
7100: 67 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e  g ){.      fprin
7110: 74 66 28 73 74 64 65 72 72 2c 22 45 72 72 6f 72  tf(stderr,"Error
7120: 3a 20 25 73 5c 6e 22 2c 20 7a 45 72 72 4d 73 67  : %s\n", zErrMsg
7130: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
7140: 5f 66 72 65 65 28 7a 45 72 72 4d 73 67 29 3b 0a  _free(zErrMsg);.
7150: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
7160: 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c   fprintf(p->out,
7170: 20 22 43 4f 4d 4d 49 54 3b 5c 6e 22 29 3b 0a 20   "COMMIT;\n");. 
7180: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20     }.  }else..  
7190: 69 66 28 20 63 3d 3d 27 65 27 20 26 26 20 73 74  if( c=='e' && st
71a0: 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20  rncmp(azArg[0], 
71b0: 22 65 63 68 6f 22 2c 20 6e 29 3d 3d 30 20 26 26  "echo", n)==0 &&
71c0: 20 6e 41 72 67 3e 31 20 29 7b 0a 20 20 20 20 70   nArg>1 ){.    p
71d0: 2d 3e 65 63 68 6f 4f 6e 20 3d 20 62 6f 6f 6c 65  ->echoOn = boole
71e0: 61 6e 56 61 6c 75 65 28 61 7a 41 72 67 5b 31 5d  anValue(azArg[1]
71f0: 29 3b 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66  );.  }else..  if
7200: 28 20 63 3d 3d 27 65 27 20 26 26 20 73 74 72 6e  ( c=='e' && strn
7210: 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22 65  cmp(azArg[0], "e
7220: 78 69 74 22 2c 20 6e 29 3d 3d 30 20 29 7b 0a 20  xit", n)==0 ){. 
7230: 20 20 20 72 63 20 3d 20 32 3b 0a 20 20 7d 65 6c     rc = 2;.  }el
7240: 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d 27 65 27  se..  if( c=='e'
7250: 20 26 26 20 73 74 72 6e 63 6d 70 28 61 7a 41 72   && strncmp(azAr
7260: 67 5b 30 5d 2c 20 22 65 78 70 6c 61 69 6e 22 2c  g[0], "explain",
7270: 20 6e 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69 6e   n)==0 ){.    in
7280: 74 20 76 61 6c 20 3d 20 6e 41 72 67 3e 3d 32 20  t val = nArg>=2 
7290: 3f 20 62 6f 6f 6c 65 61 6e 56 61 6c 75 65 28 61  ? booleanValue(a
72a0: 7a 41 72 67 5b 31 5d 29 20 3a 20 31 3b 0a 20 20  zArg[1]) : 1;.  
72b0: 20 20 69 66 28 76 61 6c 20 3d 3d 20 31 29 20 7b    if(val == 1) {
72c0: 0a 20 20 20 20 20 20 69 66 28 21 70 2d 3e 65 78  .      if(!p->ex
72d0: 70 6c 61 69 6e 50 72 65 76 2e 76 61 6c 69 64 29  plainPrev.valid)
72e0: 20 7b 0a 20 20 20 20 20 20 20 20 70 2d 3e 65 78   {.        p->ex
72f0: 70 6c 61 69 6e 50 72 65 76 2e 76 61 6c 69 64 20  plainPrev.valid 
7300: 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 70 2d 3e  = 1;.        p->
7310: 65 78 70 6c 61 69 6e 50 72 65 76 2e 6d 6f 64 65  explainPrev.mode
7320: 20 3d 20 70 2d 3e 6d 6f 64 65 3b 0a 20 20 20 20   = p->mode;.    
7330: 20 20 20 20 70 2d 3e 65 78 70 6c 61 69 6e 50 72      p->explainPr
7340: 65 76 2e 73 68 6f 77 48 65 61 64 65 72 20 3d 20  ev.showHeader = 
7350: 70 2d 3e 73 68 6f 77 48 65 61 64 65 72 3b 0a 20  p->showHeader;. 
7360: 20 20 20 20 20 20 20 6d 65 6d 63 70 79 28 70 2d         memcpy(p-
7370: 3e 65 78 70 6c 61 69 6e 50 72 65 76 2e 63 6f 6c  >explainPrev.col
7380: 57 69 64 74 68 2c 70 2d 3e 63 6f 6c 57 69 64 74  Width,p->colWidt
7390: 68 2c 73 69 7a 65 6f 66 28 70 2d 3e 63 6f 6c 57  h,sizeof(p->colW
73a0: 69 64 74 68 29 29 3b 0a 20 20 20 20 20 20 7d 0a  idth));.      }.
73b0: 20 20 20 20 20 20 2f 2a 20 57 65 20 63 6f 75 6c        /* We coul
73c0: 64 20 70 75 74 20 74 68 69 73 20 63 6f 64 65 20  d put this code 
73d0: 75 6e 64 65 72 20 74 68 65 20 21 70 2d 3e 65 78  under the !p->ex
73e0: 70 6c 61 69 6e 56 61 6c 69 64 0a 20 20 20 20 20  plainValid.     
73f0: 20 2a 2a 20 63 6f 6e 64 69 74 69 6f 6e 20 73 6f   ** condition so
7400: 20 74 68 61 74 20 69 74 20 64 6f 65 73 20 6e 6f   that it does no
7410: 74 20 65 78 65 63 75 74 65 20 69 66 20 77 65 20  t execute if we 
7420: 61 72 65 20 61 6c 72 65 61 64 79 20 69 6e 0a 20  are already in. 
7430: 20 20 20 20 20 2a 2a 20 65 78 70 6c 61 69 6e 20       ** explain 
7440: 6d 6f 64 65 2e 20 48 6f 77 65 76 65 72 2c 20 61  mode. However, a
7450: 6c 77 61 79 73 20 65 78 65 63 75 74 69 6e 67 20  lways executing 
7460: 69 74 20 61 6c 6c 6f 77 73 20 75 73 20 61 6e 20  it allows us an 
7470: 65 61 73 79 0a 20 20 20 20 20 20 2a 2a 20 77 61  easy.      ** wa
7480: 73 20 74 6f 20 72 65 73 65 74 20 74 6f 20 65 78  s to reset to ex
7490: 70 6c 61 69 6e 20 6d 6f 64 65 20 69 6e 20 63 61  plain mode in ca
74a0: 73 65 20 74 68 65 20 75 73 65 72 20 70 72 65 76  se the user prev
74b0: 69 6f 75 73 6c 79 0a 20 20 20 20 20 20 2a 2a 20  iously.      ** 
74c0: 64 69 64 20 61 6e 20 2e 65 78 70 6c 61 69 6e 20  did an .explain 
74d0: 66 6f 6c 6c 6f 77 65 64 20 62 79 20 61 20 2e 77  followed by a .w
74e0: 69 64 74 68 2c 20 2e 6d 6f 64 65 20 6f 72 20 2e  idth, .mode or .
74f0: 68 65 61 64 65 72 0a 20 20 20 20 20 20 2a 2a 20  header.      ** 
7500: 63 6f 6d 6d 61 6e 64 2e 0a 20 20 20 20 20 20 2a  command..      *
7510: 2f 0a 20 20 20 20 20 20 70 2d 3e 6d 6f 64 65 20  /.      p->mode 
7520: 3d 20 4d 4f 44 45 5f 43 6f 6c 75 6d 6e 3b 0a 20  = MODE_Column;. 
7530: 20 20 20 20 20 70 2d 3e 73 68 6f 77 48 65 61 64       p->showHead
7540: 65 72 20 3d 20 31 3b 0a 20 20 20 20 20 20 6d 65  er = 1;.      me
7550: 6d 73 65 74 28 70 2d 3e 63 6f 6c 57 69 64 74 68  mset(p->colWidth
7560: 2c 30 2c 41 72 72 61 79 53 69 7a 65 28 70 2d 3e  ,0,ArraySize(p->
7570: 63 6f 6c 57 69 64 74 68 29 29 3b 0a 20 20 20 20  colWidth));.    
7580: 20 20 70 2d 3e 63 6f 6c 57 69 64 74 68 5b 30 5d    p->colWidth[0]
7590: 20 3d 20 34 3b 0a 20 20 20 20 20 20 70 2d 3e 63   = 4;.      p->c
75a0: 6f 6c 57 69 64 74 68 5b 31 5d 20 3d 20 31 34 3b  olWidth[1] = 14;
75b0: 0a 20 20 20 20 20 20 70 2d 3e 63 6f 6c 57 69 64  .      p->colWid
75c0: 74 68 5b 32 5d 20 3d 20 31 30 3b 0a 20 20 20 20  th[2] = 10;.    
75d0: 20 20 70 2d 3e 63 6f 6c 57 69 64 74 68 5b 33 5d    p->colWidth[3]
75e0: 20 3d 20 31 30 3b 0a 20 20 20 20 20 20 70 2d 3e   = 10;.      p->
75f0: 63 6f 6c 57 69 64 74 68 5b 34 5d 20 3d 20 33 33  colWidth[4] = 33
7600: 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 20 28  ;.    }else if (
7610: 70 2d 3e 65 78 70 6c 61 69 6e 50 72 65 76 2e 76  p->explainPrev.v
7620: 61 6c 69 64 29 20 7b 0a 20 20 20 20 20 20 70 2d  alid) {.      p-
7630: 3e 65 78 70 6c 61 69 6e 50 72 65 76 2e 76 61 6c  >explainPrev.val
7640: 69 64 20 3d 20 30 3b 0a 20 20 20 20 20 20 70 2d  id = 0;.      p-
7650: 3e 6d 6f 64 65 20 3d 20 70 2d 3e 65 78 70 6c 61  >mode = p->expla
7660: 69 6e 50 72 65 76 2e 6d 6f 64 65 3b 0a 20 20 20  inPrev.mode;.   
7670: 20 20 20 70 2d 3e 73 68 6f 77 48 65 61 64 65 72     p->showHeader
7680: 20 3d 20 70 2d 3e 65 78 70 6c 61 69 6e 50 72 65   = p->explainPre
7690: 76 2e 73 68 6f 77 48 65 61 64 65 72 3b 0a 20 20  v.showHeader;.  
76a0: 20 20 20 20 6d 65 6d 63 70 79 28 70 2d 3e 63 6f      memcpy(p->co
76b0: 6c 57 69 64 74 68 2c 70 2d 3e 65 78 70 6c 61 69  lWidth,p->explai
76c0: 6e 50 72 65 76 2e 63 6f 6c 57 69 64 74 68 2c 73  nPrev.colWidth,s
76d0: 69 7a 65 6f 66 28 70 2d 3e 63 6f 6c 57 69 64 74  izeof(p->colWidt
76e0: 68 29 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c  h));.    }.  }el
76f0: 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d 27 68 27  se..  if( c=='h'
7700: 20 26 26 20 28 73 74 72 6e 63 6d 70 28 61 7a 41   && (strncmp(azA
7710: 72 67 5b 30 5d 2c 20 22 68 65 61 64 65 72 22 2c  rg[0], "header",
7720: 20 6e 29 3d 3d 30 20 7c 7c 0a 20 20 20 20 20 20   n)==0 ||.      
7730: 20 20 20 20 20 20 20 20 20 20 20 73 74 72 6e 63             strnc
7740: 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22 68 65  mp(azArg[0], "he
7750: 61 64 65 72 73 22 2c 20 6e 29 3d 3d 30 20 29 26  aders", n)==0 )&
7760: 26 20 6e 41 72 67 3e 31 20 29 7b 0a 20 20 20 20  & nArg>1 ){.    
7770: 70 2d 3e 73 68 6f 77 48 65 61 64 65 72 20 3d 20  p->showHeader = 
7780: 62 6f 6f 6c 65 61 6e 56 61 6c 75 65 28 61 7a 41  booleanValue(azA
7790: 72 67 5b 31 5d 29 3b 0a 20 20 7d 65 6c 73 65 0a  rg[1]);.  }else.
77a0: 0a 20 20 69 66 28 20 63 3d 3d 27 68 27 20 26 26  .  if( c=='h' &&
77b0: 20 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30   strncmp(azArg[0
77c0: 5d 2c 20 22 68 65 6c 70 22 2c 20 6e 29 3d 3d 30  ], "help", n)==0
77d0: 20 29 7b 0a 20 20 20 20 66 70 72 69 6e 74 66 28   ){.    fprintf(
77e0: 73 74 64 65 72 72 2c 7a 48 65 6c 70 29 3b 0a 20  stderr,zHelp);. 
77f0: 20 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d   }else..  if( c=
7800: 3d 27 69 27 20 26 26 20 73 74 72 6e 63 6d 70 28  ='i' && strncmp(
7810: 61 7a 41 72 67 5b 30 5d 2c 20 22 69 6d 70 6f 72  azArg[0], "impor
7820: 74 22 2c 20 6e 29 3d 3d 30 20 26 26 20 6e 41 72  t", n)==0 && nAr
7830: 67 3e 3d 33 20 29 7b 0a 20 20 20 20 63 68 61 72  g>=3 ){.    char
7840: 20 2a 7a 54 61 62 6c 65 20 3d 20 61 7a 41 72 67   *zTable = azArg
7850: 5b 32 5d 3b 20 20 20 20 2f 2a 20 49 6e 73 65 72  [2];    /* Inser
7860: 74 20 64 61 74 61 20 69 6e 74 6f 20 74 68 69 73  t data into this
7870: 20 74 61 62 6c 65 20 2a 2f 0a 20 20 20 20 63 68   table */.    ch
7880: 61 72 20 2a 7a 46 69 6c 65 20 3d 20 61 7a 41 72  ar *zFile = azAr
7890: 67 5b 31 5d 3b 20 20 20 20 20 2f 2a 20 54 68 65  g[1];     /* The
78a0: 20 66 69 6c 65 20 66 72 6f 6d 20 77 68 69 63 68   file from which
78b0: 20 74 6f 20 65 78 74 72 61 63 74 20 64 61 74 61   to extract data
78c0: 20 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 5f   */.    sqlite3_
78d0: 73 74 6d 74 20 2a 70 53 74 6d 74 3b 20 20 20 20  stmt *pStmt;    
78e0: 20 20 20 20 2f 2a 20 41 20 73 74 61 74 65 6d 65      /* A stateme
78f0: 6e 74 20 2a 2f 0a 20 20 20 20 69 6e 74 20 72 63  nt */.    int rc
7900: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
7910: 20 20 20 20 20 20 2f 2a 20 52 65 73 75 6c 74 20        /* Result 
7920: 63 6f 64 65 20 2a 2f 0a 20 20 20 20 69 6e 74 20  code */.    int 
7930: 6e 43 6f 6c 3b 20 20 20 20 20 20 20 20 20 20 20  nCol;           
7940: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
7950: 72 20 6f 66 20 63 6f 6c 75 6d 6e 73 20 69 6e 20  r of columns in 
7960: 74 68 65 20 74 61 62 6c 65 20 2a 2f 0a 20 20 20  the table */.   
7970: 20 69 6e 74 20 6e 42 79 74 65 3b 20 20 20 20 20   int nByte;     
7980: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
7990: 4e 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20  Number of bytes 
79a0: 69 6e 20 61 6e 20 53 51 4c 20 73 74 72 69 6e 67  in an SQL string
79b0: 20 2a 2f 0a 20 20 20 20 69 6e 74 20 69 2c 20 6a   */.    int i, j
79c0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
79d0: 20 20 20 20 2f 2a 20 4c 6f 6f 70 20 63 6f 75 6e      /* Loop coun
79e0: 74 65 72 73 20 2a 2f 0a 20 20 20 20 69 6e 74 20  ters */.    int 
79f0: 6e 53 65 70 3b 20 20 20 20 20 20 20 20 20 20 20  nSep;           
7a00: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
7a10: 72 20 6f 66 20 62 79 74 65 73 20 69 6e 20 70 2d  r of bytes in p-
7a20: 3e 73 65 70 61 72 61 74 6f 72 5b 5d 20 2a 2f 0a  >separator[] */.
7a30: 20 20 20 20 63 68 61 72 20 2a 7a 53 71 6c 3b 20      char *zSql; 
7a40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7a50: 2f 2a 20 41 6e 20 53 51 4c 20 73 74 61 74 65 6d  /* An SQL statem
7a60: 65 6e 74 20 2a 2f 0a 20 20 20 20 63 68 61 72 20  ent */.    char 
7a70: 2a 7a 4c 69 6e 65 3b 20 20 20 20 20 20 20 20 20  *zLine;         
7a80: 20 20 20 20 20 20 20 2f 2a 20 41 20 73 69 6e 67         /* A sing
7a90: 6c 65 20 6c 69 6e 65 20 6f 66 20 69 6e 70 75 74  le line of input
7aa0: 20 66 72 6f 6d 20 74 68 65 20 66 69 6c 65 20 2a   from the file *
7ab0: 2f 0a 20 20 20 20 63 68 61 72 20 2a 2a 61 7a 43  /.    char **azC
7ac0: 6f 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  ol;             
7ad0: 20 20 2f 2a 20 7a 4c 69 6e 65 5b 5d 20 62 72 6f    /* zLine[] bro
7ae0: 6b 65 6e 20 75 70 20 69 6e 74 6f 20 63 6f 6c 75  ken up into colu
7af0: 6d 6e 73 20 2a 2f 0a 20 20 20 20 63 68 61 72 20  mns */.    char 
7b00: 2a 7a 43 6f 6d 6d 69 74 3b 20 20 20 20 20 20 20  *zCommit;       
7b10: 20 20 20 20 20 20 20 2f 2a 20 48 6f 77 20 74 6f         /* How to
7b20: 20 63 6f 6d 6d 69 74 20 63 68 61 6e 67 65 73 20   commit changes 
7b30: 2a 2f 20 20 20 0a 20 20 20 20 46 49 4c 45 20 2a  */   .    FILE *
7b40: 69 6e 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  in;             
7b50: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 69 6e 70        /* The inp
7b60: 75 74 20 66 69 6c 65 20 2a 2f 0a 20 20 20 20 69  ut file */.    i
7b70: 6e 74 20 6c 69 6e 65 6e 6f 20 3d 20 30 3b 20 20  nt lineno = 0;  
7b80: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4c 69             /* Li
7b90: 6e 65 20 6e 75 6d 62 65 72 20 6f 66 20 69 6e 70  ne number of inp
7ba0: 75 74 20 66 69 6c 65 20 2a 2f 0a 0a 20 20 20 20  ut file */..    
7bb0: 6f 70 65 6e 5f 64 62 28 70 29 3b 0a 20 20 20 20  open_db(p);.    
7bc0: 6e 53 65 70 20 3d 20 73 74 72 6c 65 6e 28 70 2d  nSep = strlen(p-
7bd0: 3e 73 65 70 61 72 61 74 6f 72 29 3b 0a 20 20 20  >separator);.   
7be0: 20 69 66 28 20 6e 53 65 70 3d 3d 30 20 29 7b 0a   if( nSep==0 ){.
7bf0: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 73 74        fprintf(st
7c00: 64 65 72 72 2c 20 22 6e 6f 6e 2d 6e 75 6c 6c 20  derr, "non-null 
7c10: 73 65 70 61 72 61 74 6f 72 20 72 65 71 75 69 72  separator requir
7c20: 65 64 20 66 6f 72 20 69 6d 70 6f 72 74 5c 6e 22  ed for import\n"
7c30: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20  );.      return 
7c40: 30 3b 0a 20 20 20 20 7d 0a 20 20 20 20 7a 53 71  0;.    }.    zSq
7c50: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69  l = sqlite3_mpri
7c60: 6e 74 66 28 22 53 45 4c 45 43 54 20 2a 20 46 52  ntf("SELECT * FR
7c70: 4f 4d 20 27 25 71 27 22 2c 20 7a 54 61 62 6c 65  OM '%q'", zTable
7c80: 29 3b 0a 20 20 20 20 69 66 28 20 7a 53 71 6c 3d  );.    if( zSql=
7c90: 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  =0 ) return 0;. 
7ca0: 20 20 20 6e 42 79 74 65 20 3d 20 73 74 72 6c 65     nByte = strle
7cb0: 6e 28 7a 53 71 6c 29 3b 0a 20 20 20 20 72 63 20  n(zSql);.    rc 
7cc0: 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  = sqlite3_prepar
7cd0: 65 28 70 2d 3e 64 62 2c 20 7a 53 71 6c 2c 20 2d  e(p->db, zSql, -
7ce0: 31 2c 20 26 70 53 74 6d 74 2c 20 30 29 3b 0a 20  1, &pStmt, 0);. 
7cf0: 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28     sqlite3_free(
7d00: 7a 53 71 6c 29 3b 0a 20 20 20 20 69 66 28 20 72  zSql);.    if( r
7d10: 63 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e  c ){.      fprin
7d20: 74 66 28 73 74 64 65 72 72 2c 22 45 72 72 6f 72  tf(stderr,"Error
7d30: 3a 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33  : %s\n", sqlite3
7d40: 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a 20 20  _errmsg(db));.  
7d50: 20 20 20 20 6e 43 6f 6c 20 3d 20 30 3b 0a 20 20      nCol = 0;.  
7d60: 20 20 20 20 72 63 20 3d 20 31 3b 0a 20 20 20 20      rc = 1;.    
7d70: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 6e 43 6f  }else{.      nCo
7d80: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  l = sqlite3_colu
7d90: 6d 6e 5f 63 6f 75 6e 74 28 70 53 74 6d 74 29 3b  mn_count(pStmt);
7da0: 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74  .    }.    sqlit
7db0: 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53 74 6d  e3_finalize(pStm
7dc0: 74 29 3b 0a 20 20 20 20 69 66 28 20 6e 43 6f 6c  t);.    if( nCol
7dd0: 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 30 3b 0a  ==0 ) return 0;.
7de0: 20 20 20 20 7a 53 71 6c 20 3d 20 6d 61 6c 6c 6f      zSql = mallo
7df0: 63 28 20 6e 42 79 74 65 20 2b 20 32 30 20 2b 20  c( nByte + 20 + 
7e00: 6e 43 6f 6c 2a 32 20 29 3b 0a 20 20 20 20 69 66  nCol*2 );.    if
7e10: 28 20 7a 53 71 6c 3d 3d 30 20 29 20 72 65 74 75  ( zSql==0 ) retu
7e20: 72 6e 20 30 3b 0a 20 20 20 20 73 71 6c 69 74 65  rn 0;.    sqlite
7e30: 33 5f 73 6e 70 72 69 6e 74 66 28 6e 42 79 74 65  3_snprintf(nByte
7e40: 2b 32 30 2c 20 7a 53 71 6c 2c 20 22 49 4e 53 45  +20, zSql, "INSE
7e50: 52 54 20 49 4e 54 4f 20 27 25 71 27 20 56 41 4c  RT INTO '%q' VAL
7e60: 55 45 53 28 3f 22 2c 20 7a 54 61 62 6c 65 29 3b  UES(?", zTable);
7e70: 0a 20 20 20 20 6a 20 3d 20 73 74 72 6c 65 6e 28  .    j = strlen(
7e80: 7a 53 71 6c 29 3b 0a 20 20 20 20 66 6f 72 28 69  zSql);.    for(i
7e90: 3d 31 3b 20 69 3c 6e 43 6f 6c 3b 20 69 2b 2b 29  =1; i<nCol; i++)
7ea0: 7b 0a 20 20 20 20 20 20 7a 53 71 6c 5b 6a 2b 2b  {.      zSql[j++
7eb0: 5d 20 3d 20 27 2c 27 3b 0a 20 20 20 20 20 20 7a  ] = ',';.      z
7ec0: 53 71 6c 5b 6a 2b 2b 5d 20 3d 20 27 3f 27 3b 0a  Sql[j++] = '?';.
7ed0: 20 20 20 20 7d 0a 20 20 20 20 7a 53 71 6c 5b 6a      }.    zSql[j
7ee0: 2b 2b 5d 20 3d 20 27 29 27 3b 0a 20 20 20 20 7a  ++] = ')';.    z
7ef0: 53 71 6c 5b 6a 5d 20 3d 20 30 3b 0a 20 20 20 20  Sql[j] = 0;.    
7f00: 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65  rc = sqlite3_pre
7f10: 70 61 72 65 28 70 2d 3e 64 62 2c 20 7a 53 71 6c  pare(p->db, zSql
7f20: 2c 20 2d 31 2c 20 26 70 53 74 6d 74 2c 20 30 29  , -1, &pStmt, 0)
7f30: 3b 0a 20 20 20 20 66 72 65 65 28 7a 53 71 6c 29  ;.    free(zSql)
7f40: 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29 7b 0a  ;.    if( rc ){.
7f50: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 73 74        fprintf(st
7f60: 64 65 72 72 2c 20 22 45 72 72 6f 72 3a 20 25 73  derr, "Error: %s
7f70: 5c 6e 22 2c 20 73 71 6c 69 74 65 33 5f 65 72 72  \n", sqlite3_err
7f80: 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20 20  msg(db));.      
7f90: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
7fa0: 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 20 20 72  (pStmt);.      r
7fb0: 65 74 75 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 20  eturn 1;.    }. 
7fc0: 20 20 20 69 6e 20 3d 20 66 6f 70 65 6e 28 7a 46     in = fopen(zF
7fd0: 69 6c 65 2c 20 22 72 62 22 29 3b 0a 20 20 20 20  ile, "rb");.    
7fe0: 69 66 28 20 69 6e 3d 3d 30 20 29 7b 0a 20 20 20  if( in==0 ){.   
7ff0: 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72     fprintf(stder
8000: 72 2c 20 22 63 61 6e 6e 6f 74 20 6f 70 65 6e 20  r, "cannot open 
8010: 66 69 6c 65 3a 20 25 73 5c 6e 22 2c 20 7a 46 69  file: %s\n", zFi
8020: 6c 65 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  le);.      sqlit
8030: 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53 74 6d  e3_finalize(pStm
8040: 74 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  t);.      return
8050: 20 30 3b 0a 20 20 20 20 7d 0a 20 20 20 20 61 7a   0;.    }.    az
8060: 43 6f 6c 20 3d 20 6d 61 6c 6c 6f 63 28 20 73 69  Col = malloc( si
8070: 7a 65 6f 66 28 61 7a 43 6f 6c 5b 30 5d 29 2a 28  zeof(azCol[0])*(
8080: 6e 43 6f 6c 2b 31 29 20 29 3b 0a 20 20 20 20 69  nCol+1) );.    i
8090: 66 28 20 61 7a 43 6f 6c 3d 3d 30 20 29 7b 0a 20  f( azCol==0 ){. 
80a0: 20 20 20 20 20 66 63 6c 6f 73 65 28 69 6e 29 3b       fclose(in);
80b0: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b  .      return 0;
80c0: 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74  .    }.    sqlit
80d0: 65 33 5f 65 78 65 63 28 70 2d 3e 64 62 2c 20 22  e3_exec(p->db, "
80e0: 42 45 47 49 4e 22 2c 20 30 2c 20 30 2c 20 30 29  BEGIN", 0, 0, 0)
80f0: 3b 0a 20 20 20 20 7a 43 6f 6d 6d 69 74 20 3d 20  ;.    zCommit = 
8100: 22 43 4f 4d 4d 49 54 22 3b 0a 20 20 20 20 77 68  "COMMIT";.    wh
8110: 69 6c 65 28 20 28 7a 4c 69 6e 65 20 3d 20 6c 6f  ile( (zLine = lo
8120: 63 61 6c 5f 67 65 74 6c 69 6e 65 28 30 2c 20 69  cal_getline(0, i
8130: 6e 29 29 21 3d 30 20 29 7b 0a 20 20 20 20 20 20  n))!=0 ){.      
8140: 63 68 61 72 20 2a 7a 3b 0a 20 20 20 20 20 20 69  char *z;.      i
8150: 20 3d 20 30 3b 0a 20 20 20 20 20 20 6c 69 6e 65   = 0;.      line
8160: 6e 6f 2b 2b 3b 0a 20 20 20 20 20 20 61 7a 43 6f  no++;.      azCo
8170: 6c 5b 30 5d 20 3d 20 7a 4c 69 6e 65 3b 0a 20 20  l[0] = zLine;.  
8180: 20 20 20 20 66 6f 72 28 69 3d 30 2c 20 7a 3d 7a      for(i=0, z=z
8190: 4c 69 6e 65 3b 20 2a 7a 20 26 26 20 2a 7a 21 3d  Line; *z && *z!=
81a0: 27 5c 6e 27 20 26 26 20 2a 7a 21 3d 27 5c 72 27  '\n' && *z!='\r'
81b0: 3b 20 7a 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  ; z++){.        
81c0: 69 66 28 20 2a 7a 3d 3d 70 2d 3e 73 65 70 61 72  if( *z==p->separ
81d0: 61 74 6f 72 5b 30 5d 20 26 26 20 73 74 72 6e 63  ator[0] && strnc
81e0: 6d 70 28 7a 2c 20 70 2d 3e 73 65 70 61 72 61 74  mp(z, p->separat
81f0: 6f 72 2c 20 6e 53 65 70 29 3d 3d 30 20 29 7b 0a  or, nSep)==0 ){.
8200: 20 20 20 20 20 20 20 20 20 20 2a 7a 20 3d 20 30            *z = 0
8210: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 2b 2b 3b  ;.          i++;
8220: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 69  .          if( i
8230: 3c 6e 43 6f 6c 20 29 7b 0a 20 20 20 20 20 20 20  <nCol ){.       
8240: 20 20 20 20 20 61 7a 43 6f 6c 5b 69 5d 20 3d 20       azCol[i] = 
8250: 26 7a 5b 6e 53 65 70 5d 3b 0a 20 20 20 20 20 20  &z[nSep];.      
8260: 20 20 20 20 20 20 7a 20 2b 3d 20 6e 53 65 70 2d        z += nSep-
8270: 31 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  1;.          }. 
8280: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
8290: 0a 20 20 20 20 20 20 2a 7a 20 3d 20 30 3b 0a 20  .      *z = 0;. 
82a0: 20 20 20 20 20 69 66 28 20 69 2b 31 21 3d 6e 43       if( i+1!=nC
82b0: 6f 6c 20 29 7b 0a 20 20 20 20 20 20 20 20 66 70  ol ){.        fp
82c0: 72 69 6e 74 66 28 73 74 64 65 72 72 2c 22 25 73  rintf(stderr,"%s
82d0: 20 6c 69 6e 65 20 25 64 3a 20 65 78 70 65 63 74   line %d: expect
82e0: 65 64 20 25 64 20 63 6f 6c 75 6d 6e 73 20 6f 66  ed %d columns of
82f0: 20 64 61 74 61 20 62 75 74 20 66 6f 75 6e 64 20   data but found 
8300: 25 64 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20  %d\n",.         
8310: 20 20 7a 46 69 6c 65 2c 20 6c 69 6e 65 6e 6f 2c    zFile, lineno,
8320: 20 6e 43 6f 6c 2c 20 69 2b 31 29 3b 0a 20 20 20   nCol, i+1);.   
8330: 20 20 20 20 20 7a 43 6f 6d 6d 69 74 20 3d 20 22       zCommit = "
8340: 52 4f 4c 4c 42 41 43 4b 22 3b 0a 20 20 20 20 20  ROLLBACK";.     
8350: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
8360: 7d 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b  }.      for(i=0;
8370: 20 69 3c 6e 43 6f 6c 3b 20 69 2b 2b 29 7b 0a 20   i<nCol; i++){. 
8380: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 62         sqlite3_b
8390: 69 6e 64 5f 74 65 78 74 28 70 53 74 6d 74 2c 20  ind_text(pStmt, 
83a0: 69 2b 31 2c 20 61 7a 43 6f 6c 5b 69 5d 2c 20 2d  i+1, azCol[i], -
83b0: 31 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  1, SQLITE_STATIC
83c0: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  );.      }.     
83d0: 20 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53   sqlite3_step(pS
83e0: 74 6d 74 29 3b 0a 20 20 20 20 20 20 72 63 20 3d  tmt);.      rc =
83f0: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70   sqlite3_reset(p
8400: 53 74 6d 74 29 3b 0a 20 20 20 20 20 20 66 72 65  Stmt);.      fre
8410: 65 28 7a 4c 69 6e 65 29 3b 0a 20 20 20 20 20 20  e(zLine);.      
8420: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f  if( rc!=SQLITE_O
8430: 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 66 70 72  K ){.        fpr
8440: 69 6e 74 66 28 73 74 64 65 72 72 2c 22 45 72 72  intf(stderr,"Err
8450: 6f 72 3a 20 25 73 5c 6e 22 2c 20 73 71 6c 69 74  or: %s\n", sqlit
8460: 65 33 5f 65 72 72 6d 73 67 28 64 62 29 29 3b 0a  e3_errmsg(db));.
8470: 20 20 20 20 20 20 20 20 7a 43 6f 6d 6d 69 74 20          zCommit 
8480: 3d 20 22 52 4f 4c 4c 42 41 43 4b 22 3b 0a 20 20  = "ROLLBACK";.  
8490: 20 20 20 20 20 20 72 63 20 3d 20 31 3b 0a 20 20        rc = 1;.  
84a0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
84b0: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 66     }.    }.    f
84c0: 72 65 65 28 61 7a 43 6f 6c 29 3b 0a 20 20 20 20  ree(azCol);.    
84d0: 66 63 6c 6f 73 65 28 69 6e 29 3b 0a 20 20 20 20  fclose(in);.    
84e0: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
84f0: 28 70 53 74 6d 74 29 3b 0a 20 20 20 20 73 71 6c  (pStmt);.    sql
8500: 69 74 65 33 5f 65 78 65 63 28 70 2d 3e 64 62 2c  ite3_exec(p->db,
8510: 20 7a 43 6f 6d 6d 69 74 2c 20 30 2c 20 30 2c 20   zCommit, 0, 0, 
8520: 30 29 3b 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69  0);.  }else..  i
8530: 66 28 20 63 3d 3d 27 69 27 20 26 26 20 73 74 72  f( c=='i' && str
8540: 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22  ncmp(azArg[0], "
8550: 69 6e 64 69 63 65 73 22 2c 20 6e 29 3d 3d 30 20  indices", n)==0 
8560: 26 26 20 6e 41 72 67 3e 31 20 29 7b 0a 20 20 20  && nArg>1 ){.   
8570: 20 73 74 72 75 63 74 20 63 61 6c 6c 62 61 63 6b   struct callback
8580: 5f 64 61 74 61 20 64 61 74 61 3b 0a 20 20 20 20  _data data;.    
8590: 63 68 61 72 20 2a 7a 45 72 72 4d 73 67 20 3d 20  char *zErrMsg = 
85a0: 30 3b 0a 20 20 20 20 6f 70 65 6e 5f 64 62 28 70  0;.    open_db(p
85b0: 29 3b 0a 20 20 20 20 6d 65 6d 63 70 79 28 26 64  );.    memcpy(&d
85c0: 61 74 61 2c 20 70 2c 20 73 69 7a 65 6f 66 28 64  ata, p, sizeof(d
85d0: 61 74 61 29 29 3b 0a 20 20 20 20 64 61 74 61 2e  ata));.    data.
85e0: 73 68 6f 77 48 65 61 64 65 72 20 3d 20 30 3b 0a  showHeader = 0;.
85f0: 20 20 20 20 64 61 74 61 2e 6d 6f 64 65 20 3d 20      data.mode = 
8600: 4d 4f 44 45 5f 4c 69 73 74 3b 0a 20 20 20 20 7a  MODE_List;.    z
8610: 53 68 65 6c 6c 53 74 61 74 69 63 20 3d 20 61 7a  ShellStatic = az
8620: 41 72 67 5b 31 5d 3b 0a 20 20 20 20 73 71 6c 69  Arg[1];.    sqli
8630: 74 65 33 5f 65 78 65 63 28 70 2d 3e 64 62 2c 0a  te3_exec(p->db,.
8640: 20 20 20 20 20 20 22 53 45 4c 45 43 54 20 6e 61        "SELECT na
8650: 6d 65 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d  me FROM sqlite_m
8660: 61 73 74 65 72 20 22 0a 20 20 20 20 20 20 22 57  aster ".      "W
8670: 48 45 52 45 20 74 79 70 65 3d 27 69 6e 64 65 78  HERE type='index
8680: 27 20 41 4e 44 20 74 62 6c 5f 6e 61 6d 65 20 4c  ' AND tbl_name L
8690: 49 4b 45 20 73 68 65 6c 6c 73 74 61 74 69 63 28  IKE shellstatic(
86a0: 29 20 22 0a 20 20 20 20 20 20 22 55 4e 49 4f 4e  ) ".      "UNION
86b0: 20 41 4c 4c 20 22 0a 20 20 20 20 20 20 22 53 45   ALL ".      "SE
86c0: 4c 45 43 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73  LECT name FROM s
86d0: 71 6c 69 74 65 5f 74 65 6d 70 5f 6d 61 73 74 65  qlite_temp_maste
86e0: 72 20 22 0a 20 20 20 20 20 20 22 57 48 45 52 45  r ".      "WHERE
86f0: 20 74 79 70 65 3d 27 69 6e 64 65 78 27 20 41 4e   type='index' AN
8700: 44 20 74 62 6c 5f 6e 61 6d 65 20 4c 49 4b 45 20  D tbl_name LIKE 
8710: 73 68 65 6c 6c 73 74 61 74 69 63 28 29 20 22 0a  shellstatic() ".
8720: 20 20 20 20 20 20 22 4f 52 44 45 52 20 42 59 20        "ORDER BY 
8730: 31 22 2c 0a 20 20 20 20 20 20 63 61 6c 6c 62 61  1",.      callba
8740: 63 6b 2c 20 26 64 61 74 61 2c 20 26 7a 45 72 72  ck, &data, &zErr
8750: 4d 73 67 0a 20 20 20 20 29 3b 0a 20 20 20 20 7a  Msg.    );.    z
8760: 53 68 65 6c 6c 53 74 61 74 69 63 20 3d 20 30 3b  ShellStatic = 0;
8770: 0a 20 20 20 20 69 66 28 20 7a 45 72 72 4d 73 67  .    if( zErrMsg
8780: 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74   ){.      fprint
8790: 66 28 73 74 64 65 72 72 2c 22 45 72 72 6f 72 3a  f(stderr,"Error:
87a0: 20 25 73 5c 6e 22 2c 20 7a 45 72 72 4d 73 67 29   %s\n", zErrMsg)
87b0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  ;.      sqlite3_
87c0: 66 72 65 65 28 7a 45 72 72 4d 73 67 29 3b 0a 20  free(zErrMsg);. 
87d0: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 23 69     }.  }else..#i
87e0: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  fndef SQLITE_OMI
87f0: 54 5f 4c 4f 41 44 5f 45 58 54 45 4e 53 49 4f 4e  T_LOAD_EXTENSION
8800: 0a 20 20 69 66 28 20 63 3d 3d 27 6c 27 20 26 26  .  if( c=='l' &&
8810: 20 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30   strncmp(azArg[0
8820: 5d 2c 20 22 6c 6f 61 64 22 2c 20 6e 29 3d 3d 30  ], "load", n)==0
8830: 20 26 26 20 6e 41 72 67 3e 3d 32 20 29 7b 0a 20   && nArg>=2 ){. 
8840: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
8850: 46 69 6c 65 2c 20 2a 7a 50 72 6f 63 3b 0a 20 20  File, *zProc;.  
8860: 20 20 63 68 61 72 20 2a 7a 45 72 72 4d 73 67 20    char *zErrMsg 
8870: 3d 20 30 3b 0a 20 20 20 20 69 6e 74 20 72 63 3b  = 0;.    int rc;
8880: 0a 20 20 20 20 7a 46 69 6c 65 20 3d 20 61 7a 41  .    zFile = azA
8890: 72 67 5b 31 5d 3b 0a 20 20 20 20 7a 50 72 6f 63  rg[1];.    zProc
88a0: 20 3d 20 6e 41 72 67 3e 3d 33 20 3f 20 61 7a 41   = nArg>=3 ? azA
88b0: 72 67 5b 32 5d 20 3a 20 30 3b 0a 20 20 20 20 6f  rg[2] : 0;.    o
88c0: 70 65 6e 5f 64 62 28 70 29 3b 0a 20 20 20 20 72  pen_db(p);.    r
88d0: 63 20 3d 20 73 71 6c 69 74 65 33 5f 6c 6f 61 64  c = sqlite3_load
88e0: 5f 65 78 74 65 6e 73 69 6f 6e 28 70 2d 3e 64 62  _extension(p->db
88f0: 2c 20 7a 46 69 6c 65 2c 20 7a 50 72 6f 63 2c 20  , zFile, zProc, 
8900: 26 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 69  &zErrMsg);.    i
8910: 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc!=SQLITE_OK
8920: 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74   ){.      fprint
8930: 66 28 73 74 64 65 72 72 2c 20 22 25 73 5c 6e 22  f(stderr, "%s\n"
8940: 2c 20 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20  , zErrMsg);.    
8950: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a    sqlite3_free(z
8960: 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 72  ErrMsg);.      r
8970: 63 20 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d  c = 1;.    }.  }
8980: 65 6c 73 65 0a 23 65 6e 64 69 66 0a 0a 20 20 69  else.#endif..  i
8990: 66 28 20 63 3d 3d 27 6d 27 20 26 26 20 73 74 72  f( c=='m' && str
89a0: 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22  ncmp(azArg[0], "
89b0: 6d 6f 64 65 22 2c 20 6e 29 3d 3d 30 20 26 26 20  mode", n)==0 && 
89c0: 6e 41 72 67 3e 3d 32 20 29 7b 0a 20 20 20 20 69  nArg>=2 ){.    i
89d0: 6e 74 20 6e 32 20 3d 20 73 74 72 6c 65 6e 28 61  nt n2 = strlen(a
89e0: 7a 41 72 67 5b 31 5d 29 3b 0a 20 20 20 20 69 66  zArg[1]);.    if
89f0: 28 20 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b  ( strncmp(azArg[
8a00: 31 5d 2c 22 6c 69 6e 65 22 2c 6e 32 29 3d 3d 30  1],"line",n2)==0
8a10: 0a 20 20 20 20 20 20 20 20 7c 7c 0a 20 20 20 20  .        ||.    
8a20: 20 20 20 20 73 74 72 6e 63 6d 70 28 61 7a 41 72      strncmp(azAr
8a30: 67 5b 31 5d 2c 22 6c 69 6e 65 73 22 2c 6e 32 29  g[1],"lines",n2)
8a40: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e  ==0 ){.      p->
8a50: 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f 4c 69 6e 65  mode = MODE_Line
8a60: 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20  ;.    }else if( 
8a70: 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 31 5d  strncmp(azArg[1]
8a80: 2c 22 63 6f 6c 75 6d 6e 22 2c 6e 32 29 3d 3d 30  ,"column",n2)==0
8a90: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7c  .              |
8aa0: 7c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  |.              
8ab0: 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 31 5d  strncmp(azArg[1]
8ac0: 2c 22 63 6f 6c 75 6d 6e 73 22 2c 6e 32 29 3d 3d  ,"columns",n2)==
8ad0: 30 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 6d 6f  0 ){.      p->mo
8ae0: 64 65 20 3d 20 4d 4f 44 45 5f 43 6f 6c 75 6d 6e  de = MODE_Column
8af0: 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20  ;.    }else if( 
8b00: 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 31 5d  strncmp(azArg[1]
8b10: 2c 22 6c 69 73 74 22 2c 6e 32 29 3d 3d 30 20 29  ,"list",n2)==0 )
8b20: 7b 0a 20 20 20 20 20 20 70 2d 3e 6d 6f 64 65 20  {.      p->mode 
8b30: 3d 20 4d 4f 44 45 5f 4c 69 73 74 3b 0a 20 20 20  = MODE_List;.   
8b40: 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 6e 63   }else if( strnc
8b50: 6d 70 28 61 7a 41 72 67 5b 31 5d 2c 22 68 74 6d  mp(azArg[1],"htm
8b60: 6c 22 2c 6e 32 29 3d 3d 30 20 29 7b 0a 20 20 20  l",n2)==0 ){.   
8b70: 20 20 20 70 2d 3e 6d 6f 64 65 20 3d 20 4d 4f 44     p->mode = MOD
8b80: 45 5f 48 74 6d 6c 3b 0a 20 20 20 20 7d 65 6c 73  E_Html;.    }els
8b90: 65 20 69 66 28 20 73 74 72 6e 63 6d 70 28 61 7a  e if( strncmp(az
8ba0: 41 72 67 5b 31 5d 2c 22 74 63 6c 22 2c 6e 32 29  Arg[1],"tcl",n2)
8bb0: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e  ==0 ){.      p->
8bc0: 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f 54 63 6c 3b  mode = MODE_Tcl;
8bd0: 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73  .    }else if( s
8be0: 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 31 5d 2c  trncmp(azArg[1],
8bf0: 22 63 73 76 22 2c 6e 32 29 3d 3d 30 20 29 7b 0a  "csv",n2)==0 ){.
8c00: 20 20 20 20 20 20 70 2d 3e 6d 6f 64 65 20 3d 20        p->mode = 
8c10: 4d 4f 44 45 5f 43 73 76 3b 0a 20 20 20 20 20 20  MODE_Csv;.      
8c20: 73 74 72 63 70 79 28 70 2d 3e 73 65 70 61 72 61  strcpy(p->separa
8c30: 74 6f 72 2c 20 22 2c 22 29 3b 0a 20 20 20 20 7d  tor, ",");.    }
8c40: 65 6c 73 65 20 69 66 28 20 73 74 72 6e 63 6d 70  else if( strncmp
8c50: 28 61 7a 41 72 67 5b 31 5d 2c 22 74 61 62 73 22  (azArg[1],"tabs"
8c60: 2c 6e 32 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  ,n2)==0 ){.     
8c70: 20 70 2d 3e 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f   p->mode = MODE_
8c80: 4c 69 73 74 3b 0a 20 20 20 20 20 20 73 74 72 63  List;.      strc
8c90: 70 79 28 70 2d 3e 73 65 70 61 72 61 74 6f 72 2c  py(p->separator,
8ca0: 20 22 5c 74 22 29 3b 0a 20 20 20 20 7d 65 6c 73   "\t");.    }els
8cb0: 65 20 69 66 28 20 73 74 72 6e 63 6d 70 28 61 7a  e if( strncmp(az
8cc0: 41 72 67 5b 31 5d 2c 22 69 6e 73 65 72 74 22 2c  Arg[1],"insert",
8cd0: 6e 32 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  n2)==0 ){.      
8ce0: 70 2d 3e 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f 49  p->mode = MODE_I
8cf0: 6e 73 65 72 74 3b 0a 20 20 20 20 20 20 69 66 28  nsert;.      if(
8d00: 20 6e 41 72 67 3e 3d 33 20 29 7b 0a 20 20 20 20   nArg>=3 ){.    
8d10: 20 20 20 20 73 65 74 5f 74 61 62 6c 65 5f 6e 61      set_table_na
8d20: 6d 65 28 70 2c 20 61 7a 41 72 67 5b 32 5d 29 3b  me(p, azArg[2]);
8d30: 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  .      }else{.  
8d40: 20 20 20 20 20 20 73 65 74 5f 74 61 62 6c 65 5f        set_table_
8d50: 6e 61 6d 65 28 70 2c 20 22 74 61 62 6c 65 22 29  name(p, "table")
8d60: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 65  ;.      }.    }e
8d70: 6c 73 65 20 7b 0a 20 20 20 20 20 20 66 70 72 69  lse {.      fpri
8d80: 6e 74 66 28 73 74 64 65 72 72 2c 22 6d 6f 64 65  ntf(stderr,"mode
8d90: 20 73 68 6f 75 6c 64 20 62 65 20 6f 6e 65 20 6f   should be one o
8da0: 66 3a 20 22 0a 20 20 20 20 20 20 20 20 20 22 63  f: ".         "c
8db0: 6f 6c 75 6d 6e 20 63 73 76 20 68 74 6d 6c 20 69  olumn csv html i
8dc0: 6e 73 65 72 74 20 6c 69 6e 65 20 6c 69 73 74 20  nsert line list 
8dd0: 74 61 62 73 20 74 63 6c 5c 6e 22 29 3b 0a 20 20  tabs tcl\n");.  
8de0: 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 69    }.  }else..  i
8df0: 66 28 20 63 3d 3d 27 6e 27 20 26 26 20 73 74 72  f( c=='n' && str
8e00: 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22  ncmp(azArg[0], "
8e10: 6e 75 6c 6c 76 61 6c 75 65 22 2c 20 6e 29 3d 3d  nullvalue", n)==
8e20: 30 20 26 26 20 6e 41 72 67 3d 3d 32 20 29 20 7b  0 && nArg==2 ) {
8e30: 0a 20 20 20 20 73 70 72 69 6e 74 66 28 70 2d 3e  .    sprintf(p->
8e40: 6e 75 6c 6c 76 61 6c 75 65 2c 20 22 25 2e 2a 73  nullvalue, "%.*s
8e50: 22 2c 20 28 69 6e 74 29 41 72 72 61 79 53 69 7a  ", (int)ArraySiz
8e60: 65 28 70 2d 3e 6e 75 6c 6c 76 61 6c 75 65 29 2d  e(p->nullvalue)-
8e70: 31 2c 20 61 7a 41 72 67 5b 31 5d 29 3b 0a 20 20  1, azArg[1]);.  
8e80: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d  }else..  if( c==
8e90: 27 6f 27 20 26 26 20 73 74 72 6e 63 6d 70 28 61  'o' && strncmp(a
8ea0: 7a 41 72 67 5b 30 5d 2c 20 22 6f 75 74 70 75 74  zArg[0], "output
8eb0: 22 2c 20 6e 29 3d 3d 30 20 26 26 20 6e 41 72 67  ", n)==0 && nArg
8ec0: 3d 3d 32 20 29 7b 0a 20 20 20 20 69 66 28 20 70  ==2 ){.    if( p
8ed0: 2d 3e 6f 75 74 21 3d 73 74 64 6f 75 74 20 29 7b  ->out!=stdout ){
8ee0: 0a 20 20 20 20 20 20 66 63 6c 6f 73 65 28 70 2d  .      fclose(p-
8ef0: 3e 6f 75 74 29 3b 0a 20 20 20 20 7d 0a 20 20 20  >out);.    }.   
8f00: 20 69 66 28 20 73 74 72 63 6d 70 28 61 7a 41 72   if( strcmp(azAr
8f10: 67 5b 31 5d 2c 22 73 74 64 6f 75 74 22 29 3d 3d  g[1],"stdout")==
8f20: 30 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 6f 75  0 ){.      p->ou
8f30: 74 20 3d 20 73 74 64 6f 75 74 3b 0a 20 20 20 20  t = stdout;.    
8f40: 20 20 73 74 72 63 70 79 28 70 2d 3e 6f 75 74 66    strcpy(p->outf
8f50: 69 6c 65 2c 22 73 74 64 6f 75 74 22 29 3b 0a 20  ile,"stdout");. 
8f60: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
8f70: 70 2d 3e 6f 75 74 20 3d 20 66 6f 70 65 6e 28 61  p->out = fopen(a
8f80: 7a 41 72 67 5b 31 5d 2c 20 22 77 62 22 29 3b 0a  zArg[1], "wb");.
8f90: 20 20 20 20 20 20 69 66 28 20 70 2d 3e 6f 75 74        if( p->out
8fa0: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 66  ==0 ){.        f
8fb0: 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 22 63  printf(stderr,"c
8fc0: 61 6e 27 74 20 77 72 69 74 65 20 74 6f 20 5c 22  an't write to \"
8fd0: 25 73 5c 22 5c 6e 22 2c 20 61 7a 41 72 67 5b 31  %s\"\n", azArg[1
8fe0: 5d 29 3b 0a 20 20 20 20 20 20 20 20 70 2d 3e 6f  ]);.        p->o
8ff0: 75 74 20 3d 20 73 74 64 6f 75 74 3b 0a 20 20 20  ut = stdout;.   
9000: 20 20 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20     } else {.    
9010: 20 20 20 20 20 73 74 72 63 70 79 28 70 2d 3e 6f       strcpy(p->o
9020: 75 74 66 69 6c 65 2c 61 7a 41 72 67 5b 31 5d 29  utfile,azArg[1])
9030: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  ;.      }.    }.
9040: 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63    }else..  if( c
9050: 3d 3d 27 70 27 20 26 26 20 73 74 72 6e 63 6d 70  =='p' && strncmp
9060: 28 61 7a 41 72 67 5b 30 5d 2c 20 22 70 72 6f 6d  (azArg[0], "prom
9070: 70 74 22 2c 20 6e 29 3d 3d 30 20 26 26 20 28 6e  pt", n)==0 && (n
9080: 41 72 67 3d 3d 32 20 7c 7c 20 6e 41 72 67 3d 3d  Arg==2 || nArg==
9090: 33 29 29 7b 0a 20 20 20 20 69 66 28 20 6e 41 72  3)){.    if( nAr
90a0: 67 20 3e 3d 20 32 29 20 7b 0a 20 20 20 20 20 20  g >= 2) {.      
90b0: 73 74 72 6e 63 70 79 28 6d 61 69 6e 50 72 6f 6d  strncpy(mainProm
90c0: 70 74 2c 61 7a 41 72 67 5b 31 5d 2c 28 69 6e 74  pt,azArg[1],(int
90d0: 29 41 72 72 61 79 53 69 7a 65 28 6d 61 69 6e 50  )ArraySize(mainP
90e0: 72 6f 6d 70 74 29 2d 31 29 3b 0a 20 20 20 20 7d  rompt)-1);.    }
90f0: 0a 20 20 20 20 69 66 28 20 6e 41 72 67 20 3e 3d  .    if( nArg >=
9100: 20 33 29 20 7b 0a 20 20 20 20 20 20 73 74 72 6e   3) {.      strn
9110: 63 70 79 28 63 6f 6e 74 69 6e 75 65 50 72 6f 6d  cpy(continueProm
9120: 70 74 2c 61 7a 41 72 67 5b 32 5d 2c 28 69 6e 74  pt,azArg[2],(int
9130: 29 41 72 72 61 79 53 69 7a 65 28 63 6f 6e 74 69  )ArraySize(conti
9140: 6e 75 65 50 72 6f 6d 70 74 29 2d 31 29 3b 0a 20  nuePrompt)-1);. 
9150: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20     }.  }else..  
9160: 69 66 28 20 63 3d 3d 27 71 27 20 26 26 20 73 74  if( c=='q' && st
9170: 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20  rncmp(azArg[0], 
9180: 22 71 75 69 74 22 2c 20 6e 29 3d 3d 30 20 29 7b  "quit", n)==0 ){
9190: 0a 20 20 20 20 72 63 20 3d 20 32 3b 0a 20 20 7d  .    rc = 2;.  }
91a0: 65 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d 27  else..  if( c=='
91b0: 72 27 20 26 26 20 73 74 72 6e 63 6d 70 28 61 7a  r' && strncmp(az
91c0: 41 72 67 5b 30 5d 2c 20 22 72 65 61 64 22 2c 20  Arg[0], "read", 
91d0: 6e 29 3d 3d 30 20 26 26 20 6e 41 72 67 3d 3d 32  n)==0 && nArg==2
91e0: 20 29 7b 0a 20 20 20 20 46 49 4c 45 20 2a 61 6c   ){.    FILE *al
91f0: 74 20 3d 20 66 6f 70 65 6e 28 61 7a 41 72 67 5b  t = fopen(azArg[
9200: 31 5d 2c 20 22 72 62 22 29 3b 0a 20 20 20 20 69  1], "rb");.    i
9210: 66 28 20 61 6c 74 3d 3d 30 20 29 7b 0a 20 20 20  f( alt==0 ){.   
9220: 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72     fprintf(stder
9230: 72 2c 22 63 61 6e 27 74 20 6f 70 65 6e 20 5c 22  r,"can't open \"
9240: 25 73 5c 22 5c 6e 22 2c 20 61 7a 41 72 67 5b 31  %s\"\n", azArg[1
9250: 5d 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20  ]);.    }else{. 
9260: 20 20 20 20 20 70 72 6f 63 65 73 73 5f 69 6e 70       process_inp
9270: 75 74 28 70 2c 20 61 6c 74 29 3b 0a 20 20 20 20  ut(p, alt);.    
9280: 20 20 66 63 6c 6f 73 65 28 61 6c 74 29 3b 0a 20    fclose(alt);. 
9290: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20     }.  }else..  
92a0: 69 66 28 20 63 3d 3d 27 73 27 20 26 26 20 73 74  if( c=='s' && st
92b0: 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20  rncmp(azArg[0], 
92c0: 22 73 63 68 65 6d 61 22 2c 20 6e 29 3d 3d 30 20  "schema", n)==0 
92d0: 29 7b 0a 20 20 20 20 73 74 72 75 63 74 20 63 61  ){.    struct ca
92e0: 6c 6c 62 61 63 6b 5f 64 61 74 61 20 64 61 74 61  llback_data data
92f0: 3b 0a 20 20 20 20 63 68 61 72 20 2a 7a 45 72 72  ;.    char *zErr
9300: 4d 73 67 20 3d 20 30 3b 0a 20 20 20 20 6f 70 65  Msg = 0;.    ope
9310: 6e 5f 64 62 28 70 29 3b 0a 20 20 20 20 6d 65 6d  n_db(p);.    mem
9320: 63 70 79 28 26 64 61 74 61 2c 20 70 2c 20 73 69  cpy(&data, p, si
9330: 7a 65 6f 66 28 64 61 74 61 29 29 3b 0a 20 20 20  zeof(data));.   
9340: 20 64 61 74 61 2e 73 68 6f 77 48 65 61 64 65 72   data.showHeader
9350: 20 3d 20 30 3b 0a 20 20 20 20 64 61 74 61 2e 6d   = 0;.    data.m
9360: 6f 64 65 20 3d 20 4d 4f 44 45 5f 53 65 6d 69 3b  ode = MODE_Semi;
9370: 0a 20 20 20 20 69 66 28 20 6e 41 72 67 3e 31 20  .    if( nArg>1 
9380: 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 3b 0a  ){.      int i;.
9390: 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 61        for(i=0; a
93a0: 7a 41 72 67 5b 31 5d 5b 69 5d 3b 20 69 2b 2b 29  zArg[1][i]; i++)
93b0: 20 61 7a 41 72 67 5b 31 5d 5b 69 5d 20 3d 20 74   azArg[1][i] = t
93c0: 6f 6c 6f 77 65 72 28 61 7a 41 72 67 5b 31 5d 5b  olower(azArg[1][
93d0: 69 5d 29 3b 0a 20 20 20 20 20 20 69 66 28 20 73  i]);.      if( s
93e0: 74 72 63 6d 70 28 61 7a 41 72 67 5b 31 5d 2c 22  trcmp(azArg[1],"
93f0: 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 22 29 3d  sqlite_master")=
9400: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 63 68  =0 ){.        ch
9410: 61 72 20 2a 6e 65 77 5f 61 72 67 76 5b 32 5d 2c  ar *new_argv[2],
9420: 20 2a 6e 65 77 5f 63 6f 6c 76 5b 32 5d 3b 0a 20   *new_colv[2];. 
9430: 20 20 20 20 20 20 20 6e 65 77 5f 61 72 67 76 5b         new_argv[
9440: 30 5d 20 3d 20 22 43 52 45 41 54 45 20 54 41 42  0] = "CREATE TAB
9450: 4c 45 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  LE sqlite_master
9460: 20 28 5c 6e 22 0a 20 20 20 20 20 20 20 20 20 20   (\n".          
9470: 20 20 20 20 20 20 20 20 20 20 20 20 22 20 20 74              "  t
9480: 79 70 65 20 74 65 78 74 2c 5c 6e 22 0a 20 20 20  ype text,\n".   
9490: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
94a0: 20 20 20 22 20 20 6e 61 6d 65 20 74 65 78 74 2c     "  name text,
94b0: 5c 6e 22 0a 20 20 20 20 20 20 20 20 20 20 20 20  \n".            
94c0: 20 20 20 20 20 20 20 20 20 20 22 20 20 74 62 6c            "  tbl
94d0: 5f 6e 61 6d 65 20 74 65 78 74 2c 5c 6e 22 0a 20  _name text,\n". 
94e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
94f0: 20 20 20 20 20 22 20 20 72 6f 6f 74 70 61 67 65       "  rootpage
9500: 20 69 6e 74 65 67 65 72 2c 5c 6e 22 0a 20 20 20   integer,\n".   
9510: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9520: 20 20 20 22 20 20 73 71 6c 20 74 65 78 74 5c 6e     "  sql text\n
9530: 22 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ".              
9540: 20 20 20 20 20 20 20 20 22 29 22 3b 0a 20 20 20          ")";.   
9550: 20 20 20 20 20 6e 65 77 5f 61 72 67 76 5b 31 5d       new_argv[1]
9560: 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 6e 65   = 0;.        ne
9570: 77 5f 63 6f 6c 76 5b 30 5d 20 3d 20 22 73 71 6c  w_colv[0] = "sql
9580: 22 3b 0a 20 20 20 20 20 20 20 20 6e 65 77 5f 63  ";.        new_c
9590: 6f 6c 76 5b 31 5d 20 3d 20 30 3b 0a 20 20 20 20  olv[1] = 0;.    
95a0: 20 20 20 20 63 61 6c 6c 62 61 63 6b 28 26 64 61      callback(&da
95b0: 74 61 2c 20 31 2c 20 6e 65 77 5f 61 72 67 76 2c  ta, 1, new_argv,
95c0: 20 6e 65 77 5f 63 6f 6c 76 29 3b 0a 20 20 20 20   new_colv);.    
95d0: 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63    }else if( strc
95e0: 6d 70 28 61 7a 41 72 67 5b 31 5d 2c 22 73 71 6c  mp(azArg[1],"sql
95f0: 69 74 65 5f 74 65 6d 70 5f 6d 61 73 74 65 72 22  ite_temp_master"
9600: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20  )==0 ){.        
9610: 63 68 61 72 20 2a 6e 65 77 5f 61 72 67 76 5b 32  char *new_argv[2
9620: 5d 2c 20 2a 6e 65 77 5f 63 6f 6c 76 5b 32 5d 3b  ], *new_colv[2];
9630: 0a 20 20 20 20 20 20 20 20 6e 65 77 5f 61 72 67  .        new_arg
9640: 76 5b 30 5d 20 3d 20 22 43 52 45 41 54 45 20 54  v[0] = "CREATE T
9650: 45 4d 50 20 54 41 42 4c 45 20 73 71 6c 69 74 65  EMP TABLE sqlite
9660: 5f 74 65 6d 70 5f 6d 61 73 74 65 72 20 28 5c 6e  _temp_master (\n
9670: 22 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ".              
9680: 20 20 20 20 20 20 20 20 22 20 20 74 79 70 65 20          "  type 
9690: 74 65 78 74 2c 5c 6e 22 0a 20 20 20 20 20 20 20  text,\n".       
96a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
96b0: 20 20 6e 61 6d 65 20 74 65 78 74 2c 5c 6e 22 0a    name text,\n".
96c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
96d0: 20 20 20 20 20 20 22 20 20 74 62 6c 5f 6e 61 6d        "  tbl_nam
96e0: 65 20 74 65 78 74 2c 5c 6e 22 0a 20 20 20 20 20  e text,\n".     
96f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9700: 20 22 20 20 72 6f 6f 74 70 61 67 65 20 69 6e 74   "  rootpage int
9710: 65 67 65 72 2c 5c 6e 22 0a 20 20 20 20 20 20 20  eger,\n".       
9720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
9730: 20 20 73 71 6c 20 74 65 78 74 5c 6e 22 0a 20 20    sql text\n".  
9740: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9750: 20 20 20 20 22 29 22 3b 0a 20 20 20 20 20 20 20      ")";.       
9760: 20 6e 65 77 5f 61 72 67 76 5b 31 5d 20 3d 20 30   new_argv[1] = 0
9770: 3b 0a 20 20 20 20 20 20 20 20 6e 65 77 5f 63 6f  ;.        new_co
9780: 6c 76 5b 30 5d 20 3d 20 22 73 71 6c 22 3b 0a 20  lv[0] = "sql";. 
9790: 20 20 20 20 20 20 20 6e 65 77 5f 63 6f 6c 76 5b         new_colv[
97a0: 31 5d 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  1] = 0;.        
97b0: 63 61 6c 6c 62 61 63 6b 28 26 64 61 74 61 2c 20  callback(&data, 
97c0: 31 2c 20 6e 65 77 5f 61 72 67 76 2c 20 6e 65 77  1, new_argv, new
97d0: 5f 63 6f 6c 76 29 3b 0a 20 20 20 20 20 20 7d 65  _colv);.      }e
97e0: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 7a 53 68  lse{.        zSh
97f0: 65 6c 6c 53 74 61 74 69 63 20 3d 20 61 7a 41 72  ellStatic = azAr
9800: 67 5b 31 5d 3b 0a 20 20 20 20 20 20 20 20 73 71  g[1];.        sq
9810: 6c 69 74 65 33 5f 65 78 65 63 28 70 2d 3e 64 62  lite3_exec(p->db
9820: 2c 0a 20 20 20 20 20 20 20 20 20 20 22 53 45 4c  ,.          "SEL
9830: 45 43 54 20 73 71 6c 20 46 52 4f 4d 20 22 0a 20  ECT sql FROM ". 
9840: 20 20 20 20 20 20 20 20 20 22 20 20 28 53 45 4c           "  (SEL
9850: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
9860: 65 5f 6d 61 73 74 65 72 20 55 4e 49 4f 4e 20 41  e_master UNION A
9870: 4c 4c 22 0a 20 20 20 20 20 20 20 20 20 20 22 20  LL".          " 
9880: 20 20 53 45 4c 45 43 54 20 2a 20 46 52 4f 4d 20    SELECT * FROM 
9890: 73 71 6c 69 74 65 5f 74 65 6d 70 5f 6d 61 73 74  sqlite_temp_mast
98a0: 65 72 29 20 22 0a 20 20 20 20 20 20 20 20 20 20  er) ".          
98b0: 22 57 48 45 52 45 20 74 62 6c 5f 6e 61 6d 65 20  "WHERE tbl_name 
98c0: 4c 49 4b 45 20 73 68 65 6c 6c 73 74 61 74 69 63  LIKE shellstatic
98d0: 28 29 20 41 4e 44 20 74 79 70 65 21 3d 27 6d 65  () AND type!='me
98e0: 74 61 27 20 41 4e 44 20 73 71 6c 20 4e 4f 54 4e  ta' AND sql NOTN
98f0: 55 4c 4c 20 22 0a 20 20 20 20 20 20 20 20 20 20  ULL ".          
9900: 22 4f 52 44 45 52 20 42 59 20 73 75 62 73 74 72  "ORDER BY substr
9910: 28 74 79 70 65 2c 32 2c 31 29 2c 20 6e 61 6d 65  (type,2,1), name
9920: 22 2c 0a 20 20 20 20 20 20 20 20 20 20 63 61 6c  ",.          cal
9930: 6c 62 61 63 6b 2c 20 26 64 61 74 61 2c 20 26 7a  lback, &data, &z
9940: 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 20  ErrMsg);.       
9950: 20 7a 53 68 65 6c 6c 53 74 61 74 69 63 20 3d 20   zShellStatic = 
9960: 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  0;.      }.    }
9970: 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69  else{.      sqli
9980: 74 65 33 5f 65 78 65 63 28 70 2d 3e 64 62 2c 0a  te3_exec(p->db,.
9990: 20 20 20 20 20 20 20 20 20 22 53 45 4c 45 43 54           "SELECT
99a0: 20 73 71 6c 20 46 52 4f 4d 20 22 0a 20 20 20 20   sql FROM ".    
99b0: 20 20 20 20 20 22 20 20 28 53 45 4c 45 43 54 20       "  (SELECT 
99c0: 2a 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 6d 61  * FROM sqlite_ma
99d0: 73 74 65 72 20 55 4e 49 4f 4e 20 41 4c 4c 22 0a  ster UNION ALL".
99e0: 20 20 20 20 20 20 20 20 20 22 20 20 20 53 45 4c           "   SEL
99f0: 45 43 54 20 2a 20 46 52 4f 4d 20 73 71 6c 69 74  ECT * FROM sqlit
9a00: 65 5f 74 65 6d 70 5f 6d 61 73 74 65 72 29 20 22  e_temp_master) "
9a10: 0a 20 20 20 20 20 20 20 20 20 22 57 48 45 52 45  .         "WHERE
9a20: 20 74 79 70 65 21 3d 27 6d 65 74 61 27 20 41 4e   type!='meta' AN
9a30: 44 20 73 71 6c 20 4e 4f 54 4e 55 4c 4c 20 41 4e  D sql NOTNULL AN
9a40: 44 20 6e 61 6d 65 20 4e 4f 54 20 4c 49 4b 45 20  D name NOT LIKE 
9a50: 27 73 71 6c 69 74 65 5f 25 27 22 0a 20 20 20 20  'sqlite_%'".    
9a60: 20 20 20 20 20 22 4f 52 44 45 52 20 42 59 20 73       "ORDER BY s
9a70: 75 62 73 74 72 28 74 79 70 65 2c 32 2c 31 29 2c  ubstr(type,2,1),
9a80: 20 6e 61 6d 65 22 2c 0a 20 20 20 20 20 20 20 20   name",.        
9a90: 20 63 61 6c 6c 62 61 63 6b 2c 20 26 64 61 74 61   callback, &data
9aa0: 2c 20 26 7a 45 72 72 4d 73 67 0a 20 20 20 20 20  , &zErrMsg.     
9ab0: 20 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66   );.    }.    if
9ac0: 28 20 7a 45 72 72 4d 73 67 20 29 7b 0a 20 20 20  ( zErrMsg ){.   
9ad0: 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72     fprintf(stder
9ae0: 72 2c 22 45 72 72 6f 72 3a 20 25 73 5c 6e 22 2c  r,"Error: %s\n",
9af0: 20 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20   zErrMsg);.     
9b00: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 45   sqlite3_free(zE
9b10: 72 72 4d 73 67 29 3b 0a 20 20 20 20 7d 0a 20 20  rrMsg);.    }.  
9b20: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d  }else..  if( c==
9b30: 27 73 27 20 26 26 20 73 74 72 6e 63 6d 70 28 61  's' && strncmp(a
9b40: 7a 41 72 67 5b 30 5d 2c 20 22 73 65 70 61 72 61  zArg[0], "separa
9b50: 74 6f 72 22 2c 20 6e 29 3d 3d 30 20 26 26 20 6e  tor", n)==0 && n
9b60: 41 72 67 3d 3d 32 20 29 7b 0a 20 20 20 20 73 70  Arg==2 ){.    sp
9b70: 72 69 6e 74 66 28 70 2d 3e 73 65 70 61 72 61 74  rintf(p->separat
9b80: 6f 72 2c 20 22 25 2e 2a 73 22 2c 20 28 69 6e 74  or, "%.*s", (int
9b90: 29 41 72 72 61 79 53 69 7a 65 28 70 2d 3e 73 65  )ArraySize(p->se
9ba0: 70 61 72 61 74 6f 72 29 2d 31 2c 20 61 7a 41 72  parator)-1, azAr
9bb0: 67 5b 31 5d 29 3b 0a 20 20 7d 65 6c 73 65 0a 0a  g[1]);.  }else..
9bc0: 20 20 69 66 28 20 63 3d 3d 27 73 27 20 26 26 20    if( c=='s' && 
9bd0: 73 74 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d  strncmp(azArg[0]
9be0: 2c 20 22 73 68 6f 77 22 2c 20 6e 29 3d 3d 30 29  , "show", n)==0)
9bf0: 7b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20  {.    int i;.   
9c00: 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c   fprintf(p->out,
9c10: 22 25 39 2e 39 73 3a 20 25 73 5c 6e 22 2c 22 65  "%9.9s: %s\n","e
9c20: 63 68 6f 22 2c 20 70 2d 3e 65 63 68 6f 4f 6e 20  cho", p->echoOn 
9c30: 3f 20 22 6f 6e 22 20 3a 20 22 6f 66 66 22 29 3b  ? "on" : "off");
9c40: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e  .    fprintf(p->
9c50: 6f 75 74 2c 22 25 39 2e 39 73 3a 20 25 73 5c 6e  out,"%9.9s: %s\n
9c60: 22 2c 22 65 78 70 6c 61 69 6e 22 2c 20 70 2d 3e  ","explain", p->
9c70: 65 78 70 6c 61 69 6e 50 72 65 76 2e 76 61 6c 69  explainPrev.vali
9c80: 64 20 3f 20 22 6f 6e 22 20 3a 22 6f 66 66 22 29  d ? "on" :"off")
9c90: 3b 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d  ;.    fprintf(p-
9ca0: 3e 6f 75 74 2c 22 25 39 2e 39 73 3a 20 25 73 5c  >out,"%9.9s: %s\
9cb0: 6e 22 2c 22 68 65 61 64 65 72 73 22 2c 20 70 2d  n","headers", p-
9cc0: 3e 73 68 6f 77 48 65 61 64 65 72 20 3f 20 22 6f  >showHeader ? "o
9cd0: 6e 22 20 3a 20 22 6f 66 66 22 29 3b 0a 20 20 20  n" : "off");.   
9ce0: 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c   fprintf(p->out,
9cf0: 22 25 39 2e 39 73 3a 20 25 73 5c 6e 22 2c 22 6d  "%9.9s: %s\n","m
9d00: 6f 64 65 22 2c 20 6d 6f 64 65 44 65 73 63 72 5b  ode", modeDescr[
9d10: 70 2d 3e 6d 6f 64 65 5d 29 3b 0a 20 20 20 20 66  p->mode]);.    f
9d20: 70 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22 25  printf(p->out,"%
9d30: 39 2e 39 73 3a 20 22 2c 20 22 6e 75 6c 6c 76 61  9.9s: ", "nullva
9d40: 6c 75 65 22 29 3b 0a 20 20 20 20 20 20 6f 75 74  lue");.      out
9d50: 70 75 74 5f 63 5f 73 74 72 69 6e 67 28 70 2d 3e  put_c_string(p->
9d60: 6f 75 74 2c 20 70 2d 3e 6e 75 6c 6c 76 61 6c 75  out, p->nullvalu
9d70: 65 29 3b 0a 20 20 20 20 20 20 66 70 72 69 6e 74  e);.      fprint
9d80: 66 28 70 2d 3e 6f 75 74 2c 20 22 5c 6e 22 29 3b  f(p->out, "\n");
9d90: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e  .    fprintf(p->
9da0: 6f 75 74 2c 22 25 39 2e 39 73 3a 20 25 73 5c 6e  out,"%9.9s: %s\n
9db0: 22 2c 22 6f 75 74 70 75 74 22 2c 0a 20 20 20 20  ","output",.    
9dc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9dd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 74 72               str
9de0: 6c 65 6e 28 70 2d 3e 6f 75 74 66 69 6c 65 29 20  len(p->outfile) 
9df0: 3f 20 70 2d 3e 6f 75 74 66 69 6c 65 20 3a 20 22  ? p->outfile : "
9e00: 73 74 64 6f 75 74 22 29 3b 0a 20 20 20 20 66 70  stdout");.    fp
9e10: 72 69 6e 74 66 28 70 2d 3e 6f 75 74 2c 22 25 39  rintf(p->out,"%9
9e20: 2e 39 73 3a 20 22 2c 20 22 73 65 70 61 72 61 74  .9s: ", "separat
9e30: 6f 72 22 29 3b 0a 20 20 20 20 20 20 6f 75 74 70  or");.      outp
9e40: 75 74 5f 63 5f 73 74 72 69 6e 67 28 70 2d 3e 6f  ut_c_string(p->o
9e50: 75 74 2c 20 70 2d 3e 73 65 70 61 72 61 74 6f 72  ut, p->separator
9e60: 29 3b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66  );.      fprintf
9e70: 28 70 2d 3e 6f 75 74 2c 20 22 5c 6e 22 29 3b 0a  (p->out, "\n");.
9e80: 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d 3e 6f      fprintf(p->o
9e90: 75 74 2c 22 25 39 2e 39 73 3a 20 22 2c 22 77 69  ut,"%9.9s: ","wi
9ea0: 64 74 68 22 29 3b 0a 20 20 20 20 66 6f 72 20 28  dth");.    for (
9eb0: 69 3d 30 3b 69 3c 28 69 6e 74 29 41 72 72 61 79  i=0;i<(int)Array
9ec0: 53 69 7a 65 28 70 2d 3e 63 6f 6c 57 69 64 74 68  Size(p->colWidth
9ed0: 29 20 26 26 20 70 2d 3e 63 6f 6c 57 69 64 74 68  ) && p->colWidth
9ee0: 5b 69 5d 20 21 3d 20 30 3b 69 2b 2b 29 20 7b 0a  [i] != 0;i++) {.
9ef0: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d        fprintf(p-
9f00: 3e 6f 75 74 2c 22 25 64 20 22 2c 70 2d 3e 63 6f  >out,"%d ",p->co
9f10: 6c 57 69 64 74 68 5b 69 5d 29 3b 0a 20 20 20 20  lWidth[i]);.    
9f20: 7d 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 2d  }.    fprintf(p-
9f30: 3e 6f 75 74 2c 22 5c 6e 22 29 3b 0a 20 20 7d 65  >out,"\n");.  }e
9f40: 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d 27 74  lse..  if( c=='t
9f50: 27 20 26 26 20 6e 3e 31 20 26 26 20 73 74 72 6e  ' && n>1 && strn
9f60: 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22 74  cmp(azArg[0], "t
9f70: 61 62 6c 65 73 22 2c 20 6e 29 3d 3d 30 20 29 7b  ables", n)==0 ){
9f80: 0a 20 20 20 20 63 68 61 72 20 2a 2a 61 7a 52 65  .    char **azRe
9f90: 73 75 6c 74 3b 0a 20 20 20 20 69 6e 74 20 6e 52  sult;.    int nR
9fa0: 6f 77 2c 20 72 63 3b 0a 20 20 20 20 63 68 61 72  ow, rc;.    char
9fb0: 20 2a 7a 45 72 72 4d 73 67 3b 0a 20 20 20 20 6f   *zErrMsg;.    o
9fc0: 70 65 6e 5f 64 62 28 70 29 3b 0a 20 20 20 20 69  pen_db(p);.    i
9fd0: 66 28 20 6e 41 72 67 3d 3d 31 20 29 7b 0a 20 20  f( nArg==1 ){.  
9fe0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
9ff0: 5f 67 65 74 5f 74 61 62 6c 65 28 70 2d 3e 64 62  _get_table(p->db
a000: 2c 0a 20 20 20 20 20 20 20 20 22 53 45 4c 45 43  ,.        "SELEC
a010: 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69  T name FROM sqli
a020: 74 65 5f 6d 61 73 74 65 72 20 22 0a 20 20 20 20  te_master ".    
a030: 20 20 20 20 22 57 48 45 52 45 20 74 79 70 65 20      "WHERE type 
a040: 49 4e 20 28 27 74 61 62 6c 65 27 2c 27 76 69 65  IN ('table','vie
a050: 77 27 29 20 41 4e 44 20 6e 61 6d 65 20 4e 4f 54  w') AND name NOT
a060: 20 4c 49 4b 45 20 27 73 71 6c 69 74 65 5f 25 27   LIKE 'sqlite_%'
a070: 22 0a 20 20 20 20 20 20 20 20 22 55 4e 49 4f 4e  ".        "UNION
a080: 20 41 4c 4c 20 22 0a 20 20 20 20 20 20 20 20 22   ALL ".        "
a090: 53 45 4c 45 43 54 20 6e 61 6d 65 20 46 52 4f 4d  SELECT name FROM
a0a0: 20 73 71 6c 69 74 65 5f 74 65 6d 70 5f 6d 61 73   sqlite_temp_mas
a0b0: 74 65 72 20 22 0a 20 20 20 20 20 20 20 20 22 57  ter ".        "W
a0c0: 48 45 52 45 20 74 79 70 65 20 49 4e 20 28 27 74  HERE type IN ('t
a0d0: 61 62 6c 65 27 2c 27 76 69 65 77 27 29 20 22 0a  able','view') ".
a0e0: 20 20 20 20 20 20 20 20 22 4f 52 44 45 52 20 42          "ORDER B
a0f0: 59 20 31 22 2c 0a 20 20 20 20 20 20 20 20 26 61  Y 1",.        &a
a100: 7a 52 65 73 75 6c 74 2c 20 26 6e 52 6f 77 2c 20  zResult, &nRow, 
a110: 30 2c 20 26 7a 45 72 72 4d 73 67 0a 20 20 20 20  0, &zErrMsg.    
a120: 20 20 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a    );.    }else{.
a130: 20 20 20 20 20 20 7a 53 68 65 6c 6c 53 74 61 74        zShellStat
a140: 69 63 20 3d 20 61 7a 41 72 67 5b 31 5d 3b 0a 20  ic = azArg[1];. 
a150: 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65       rc = sqlite
a160: 33 5f 67 65 74 5f 74 61 62 6c 65 28 70 2d 3e 64  3_get_table(p->d
a170: 62 2c 0a 20 20 20 20 20 20 20 20 22 53 45 4c 45  b,.        "SELE
a180: 43 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c  CT name FROM sql
a190: 69 74 65 5f 6d 61 73 74 65 72 20 22 0a 20 20 20  ite_master ".   
a1a0: 20 20 20 20 20 22 57 48 45 52 45 20 74 79 70 65       "WHERE type
a1b0: 20 49 4e 20 28 27 74 61 62 6c 65 27 2c 27 76 69   IN ('table','vi
a1c0: 65 77 27 29 20 41 4e 44 20 6e 61 6d 65 20 4c 49  ew') AND name LI
a1d0: 4b 45 20 27 25 27 7c 7c 73 68 65 6c 6c 73 74 61  KE '%'||shellsta
a1e0: 74 69 63 28 29 7c 7c 27 25 27 20 22 0a 20 20 20  tic()||'%' ".   
a1f0: 20 20 20 20 20 22 55 4e 49 4f 4e 20 41 4c 4c 20       "UNION ALL 
a200: 22 0a 20 20 20 20 20 20 20 20 22 53 45 4c 45 43  ".        "SELEC
a210: 54 20 6e 61 6d 65 20 46 52 4f 4d 20 73 71 6c 69  T name FROM sqli
a220: 74 65 5f 74 65 6d 70 5f 6d 61 73 74 65 72 20 22  te_temp_master "
a230: 0a 20 20 20 20 20 20 20 20 22 57 48 45 52 45 20  .        "WHERE 
a240: 74 79 70 65 20 49 4e 20 28 27 74 61 62 6c 65 27  type IN ('table'
a250: 2c 27 76 69 65 77 27 29 20 41 4e 44 20 6e 61 6d  ,'view') AND nam
a260: 65 20 4c 49 4b 45 20 27 25 27 7c 7c 73 68 65 6c  e LIKE '%'||shel
a270: 6c 73 74 61 74 69 63 28 29 7c 7c 27 25 27 20 22  lstatic()||'%' "
a280: 0a 20 20 20 20 20 20 20 20 22 4f 52 44 45 52 20  .        "ORDER 
a290: 42 59 20 31 22 2c 0a 20 20 20 20 20 20 20 20 26  BY 1",.        &
a2a0: 61 7a 52 65 73 75 6c 74 2c 20 26 6e 52 6f 77 2c  azResult, &nRow,
a2b0: 20 30 2c 20 26 7a 45 72 72 4d 73 67 0a 20 20 20   0, &zErrMsg.   
a2c0: 20 20 20 29 3b 0a 20 20 20 20 20 20 7a 53 68 65     );.      zShe
a2d0: 6c 6c 53 74 61 74 69 63 20 3d 20 30 3b 0a 20 20  llStatic = 0;.  
a2e0: 20 20 7d 0a 20 20 20 20 69 66 28 20 7a 45 72 72    }.    if( zErr
a2f0: 4d 73 67 20 29 7b 0a 20 20 20 20 20 20 66 70 72  Msg ){.      fpr
a300: 69 6e 74 66 28 73 74 64 65 72 72 2c 22 45 72 72  intf(stderr,"Err
a310: 6f 72 3a 20 25 73 5c 6e 22 2c 20 7a 45 72 72 4d  or: %s\n", zErrM
a320: 73 67 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  sg);.      sqlit
a330: 65 33 5f 66 72 65 65 28 7a 45 72 72 4d 73 67 29  e3_free(zErrMsg)
a340: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20  ;.    }.    if( 
a350: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b  rc==SQLITE_OK ){
a360: 0a 20 20 20 20 20 20 69 6e 74 20 6c 65 6e 2c 20  .      int len, 
a370: 6d 61 78 6c 65 6e 20 3d 20 30 3b 0a 20 20 20 20  maxlen = 0;.    
a380: 20 20 69 6e 74 20 69 2c 20 6a 3b 0a 20 20 20 20    int i, j;.    
a390: 20 20 69 6e 74 20 6e 50 72 69 6e 74 43 6f 6c 2c    int nPrintCol,
a3a0: 20 6e 50 72 69 6e 74 52 6f 77 3b 0a 20 20 20 20   nPrintRow;.    
a3b0: 20 20 66 6f 72 28 69 3d 31 3b 20 69 3c 3d 6e 52    for(i=1; i<=nR
a3c0: 6f 77 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  ow; i++){.      
a3d0: 20 20 69 66 28 20 61 7a 52 65 73 75 6c 74 5b 69    if( azResult[i
a3e0: 5d 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65 3b  ]==0 ) continue;
a3f0: 0a 20 20 20 20 20 20 20 20 6c 65 6e 20 3d 20 73  .        len = s
a400: 74 72 6c 65 6e 28 61 7a 52 65 73 75 6c 74 5b 69  trlen(azResult[i
a410: 5d 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20  ]);.        if( 
a420: 6c 65 6e 3e 6d 61 78 6c 65 6e 20 29 20 6d 61 78  len>maxlen ) max
a430: 6c 65 6e 20 3d 20 6c 65 6e 3b 0a 20 20 20 20 20  len = len;.     
a440: 20 7d 0a 20 20 20 20 20 20 6e 50 72 69 6e 74 43   }.      nPrintC
a450: 6f 6c 20 3d 20 38 30 2f 28 6d 61 78 6c 65 6e 2b  ol = 80/(maxlen+
a460: 32 29 3b 0a 20 20 20 20 20 20 69 66 28 20 6e 50  2);.      if( nP
a470: 72 69 6e 74 43 6f 6c 3c 31 20 29 20 6e 50 72 69  rintCol<1 ) nPri
a480: 6e 74 43 6f 6c 20 3d 20 31 3b 0a 20 20 20 20 20  ntCol = 1;.     
a490: 20 6e 50 72 69 6e 74 52 6f 77 20 3d 20 28 6e 52   nPrintRow = (nR
a4a0: 6f 77 20 2b 20 6e 50 72 69 6e 74 43 6f 6c 20 2d  ow + nPrintCol -
a4b0: 20 31 29 2f 6e 50 72 69 6e 74 43 6f 6c 3b 0a 20   1)/nPrintCol;. 
a4c0: 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c       for(i=0; i<
a4d0: 6e 50 72 69 6e 74 52 6f 77 3b 20 69 2b 2b 29 7b  nPrintRow; i++){
a4e0: 0a 20 20 20 20 20 20 20 20 66 6f 72 28 6a 3d 69  .        for(j=i
a4f0: 2b 31 3b 20 6a 3c 3d 6e 52 6f 77 3b 20 6a 2b 3d  +1; j<=nRow; j+=
a500: 6e 50 72 69 6e 74 52 6f 77 29 7b 0a 20 20 20 20  nPrintRow){.    
a510: 20 20 20 20 20 20 63 68 61 72 20 2a 7a 53 70 20        char *zSp 
a520: 3d 20 6a 3c 3d 6e 50 72 69 6e 74 52 6f 77 20 3f  = j<=nPrintRow ?
a530: 20 22 22 20 3a 20 22 20 20 22 3b 0a 20 20 20 20   "" : "  ";.    
a540: 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 25 73        printf("%s
a550: 25 2d 2a 73 22 2c 20 7a 53 70 2c 20 6d 61 78 6c  %-*s", zSp, maxl
a560: 65 6e 2c 20 61 7a 52 65 73 75 6c 74 5b 6a 5d 20  en, azResult[j] 
a570: 3f 20 61 7a 52 65 73 75 6c 74 5b 6a 5d 20 3a 20  ? azResult[j] : 
a580: 22 22 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  "");.        }. 
a590: 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 5c         printf("\
a5a0: 6e 22 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n");.      }.   
a5b0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 72 63   }else{.      rc
a5c0: 20 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 20 20   = 1;.    }.    
a5d0: 73 71 6c 69 74 65 33 5f 66 72 65 65 5f 74 61 62  sqlite3_free_tab
a5e0: 6c 65 28 61 7a 52 65 73 75 6c 74 29 3b 0a 20 20  le(azResult);.  
a5f0: 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63 3d 3d  }else..  if( c==
a600: 27 74 27 20 26 26 20 6e 3e 31 20 26 26 20 73 74  't' && n>1 && st
a610: 72 6e 63 6d 70 28 61 7a 41 72 67 5b 30 5d 2c 20  rncmp(azArg[0], 
a620: 22 74 69 6d 65 6f 75 74 22 2c 20 6e 29 3d 3d 30  "timeout", n)==0
a630: 20 26 26 20 6e 41 72 67 3e 3d 32 20 29 7b 0a 20   && nArg>=2 ){. 
a640: 20 20 20 6f 70 65 6e 5f 64 62 28 70 29 3b 0a 20     open_db(p);. 
a650: 20 20 20 73 71 6c 69 74 65 33 5f 62 75 73 79 5f     sqlite3_busy_
a660: 74 69 6d 65 6f 75 74 28 70 2d 3e 64 62 2c 20 61  timeout(p->db, a
a670: 74 6f 69 28 61 7a 41 72 67 5b 31 5d 29 29 3b 0a  toi(azArg[1]));.
a680: 20 20 7d 65 6c 73 65 0a 0a 20 20 69 66 28 20 63    }else..  if( c
a690: 3d 3d 27 77 27 20 26 26 20 73 74 72 6e 63 6d 70  =='w' && strncmp
a6a0: 28 61 7a 41 72 67 5b 30 5d 2c 20 22 77 69 64 74  (azArg[0], "widt
a6b0: 68 22 2c 20 6e 29 3d 3d 30 20 29 7b 0a 20 20 20  h", n)==0 ){.   
a6c0: 20 69 6e 74 20 6a 3b 0a 20 20 20 20 61 73 73 65   int j;.    asse
a6d0: 72 74 28 20 6e 41 72 67 3c 3d 41 72 72 61 79 53  rt( nArg<=ArrayS
a6e0: 69 7a 65 28 61 7a 41 72 67 29 20 29 3b 0a 20 20  ize(azArg) );.  
a6f0: 20 20 66 6f 72 28 6a 3d 31 3b 20 6a 3c 6e 41 72    for(j=1; j<nAr
a700: 67 20 26 26 20 6a 3c 41 72 72 61 79 53 69 7a 65  g && j<ArraySize
a710: 28 70 2d 3e 63 6f 6c 57 69 64 74 68 29 3b 20 6a  (p->colWidth); j
a720: 2b 2b 29 7b 0a 20 20 20 20 20 20 70 2d 3e 63 6f  ++){.      p->co
a730: 6c 57 69 64 74 68 5b 6a 2d 31 5d 20 3d 20 61 74  lWidth[j-1] = at
a740: 6f 69 28 61 7a 41 72 67 5b 6a 5d 29 3b 0a 20 20  oi(azArg[j]);.  
a750: 20 20 7d 0a 20 20 7d 65 6c 73 65 0a 0a 20 20 7b    }.  }else..  {
a760: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64  .    fprintf(std
a770: 65 72 72 2c 20 22 75 6e 6b 6e 6f 77 6e 20 63 6f  err, "unknown co
a780: 6d 6d 61 6e 64 20 6f 72 20 69 6e 76 61 6c 69 64  mmand or invalid
a790: 20 61 72 67 75 6d 65 6e 74 73 3a 20 22 0a 20 20   arguments: ".  
a7a0: 20 20 20 20 22 20 5c 22 25 73 5c 22 2e 20 45 6e      " \"%s\". En
a7b0: 74 65 72 20 5c 22 2e 68 65 6c 70 5c 22 20 66 6f  ter \".help\" fo
a7c0: 72 20 68 65 6c 70 5c 6e 22 2c 20 61 7a 41 72 67  r help\n", azArg
a7d0: 5b 30 5d 29 3b 0a 20 20 7d 0a 0a 20 20 72 65 74  [0]);.  }..  ret
a7e0: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  urn rc;.}../*.**
a7f0: 20 52 65 74 75 72 6e 20 54 52 55 45 20 69 66 20   Return TRUE if 
a800: 74 68 65 20 6c 61 73 74 20 6e 6f 6e 2d 77 68 69  the last non-whi
a810: 74 65 73 70 61 63 65 20 63 68 61 72 61 63 74 65  tespace characte
a820: 72 20 69 6e 20 7a 5b 5d 20 69 73 20 61 20 73 65  r in z[] is a se
a830: 6d 69 63 6f 6c 6f 6e 2e 0a 2a 2a 20 7a 5b 5d 20  micolon..** z[] 
a840: 69 73 20 4e 20 63 68 61 72 61 63 74 65 72 73 20  is N characters 
a850: 6c 6f 6e 67 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  long..*/.static 
a860: 69 6e 74 20 5f 65 6e 64 73 5f 77 69 74 68 5f 73  int _ends_with_s
a870: 65 6d 69 63 6f 6c 6f 6e 28 63 6f 6e 73 74 20 63  emicolon(const c
a880: 68 61 72 20 2a 7a 2c 20 69 6e 74 20 4e 29 7b 0a  har *z, int N){.
a890: 20 20 77 68 69 6c 65 28 20 4e 3e 30 20 26 26 20    while( N>0 && 
a8a0: 69 73 73 70 61 63 65 28 28 75 6e 73 69 67 6e 65  isspace((unsigne
a8b0: 64 20 63 68 61 72 29 7a 5b 4e 2d 31 5d 29 20 29  d char)z[N-1]) )
a8c0: 7b 20 4e 2d 2d 3b 20 7d 0a 20 20 72 65 74 75 72  { N--; }.  retur
a8d0: 6e 20 4e 3e 30 20 26 26 20 7a 5b 4e 2d 31 5d 3d  n N>0 && z[N-1]=
a8e0: 3d 27 3b 27 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54  =';';.}../*.** T
a8f0: 65 73 74 20 74 6f 20 73 65 65 20 69 66 20 61 20  est to see if a 
a900: 6c 69 6e 65 20 63 6f 6e 73 69 73 74 73 20 65 6e  line consists en
a910: 74 69 72 65 6c 79 20 6f 66 20 77 68 69 74 65 73  tirely of whites
a920: 70 61 63 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  pace..*/.static 
a930: 69 6e 74 20 5f 61 6c 6c 5f 77 68 69 74 65 73 70  int _all_whitesp
a940: 61 63 65 28 63 6f 6e 73 74 20 63 68 61 72 20 2a  ace(const char *
a950: 7a 29 7b 0a 20 20 66 6f 72 28 3b 20 2a 7a 3b 20  z){.  for(; *z; 
a960: 7a 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 69 73  z++){.    if( is
a970: 73 70 61 63 65 28 2a 28 75 6e 73 69 67 6e 65 64  space(*(unsigned
a980: 20 63 68 61 72 2a 29 7a 29 20 29 20 63 6f 6e 74   char*)z) ) cont
a990: 69 6e 75 65 3b 0a 20 20 20 20 69 66 28 20 2a 7a  inue;.    if( *z
a9a0: 3d 3d 27 2f 27 20 26 26 20 7a 5b 31 5d 3d 3d 27  =='/' && z[1]=='
a9b0: 2a 27 20 29 7b 0a 20 20 20 20 20 20 7a 20 2b 3d  *' ){.      z +=
a9c0: 20 32 3b 0a 20 20 20 20 20 20 77 68 69 6c 65 28   2;.      while(
a9d0: 20 2a 7a 20 26 26 20 28 2a 7a 21 3d 27 2a 27 20   *z && (*z!='*' 
a9e0: 7c 7c 20 7a 5b 31 5d 21 3d 27 2f 27 29 20 29 7b  || z[1]!='/') ){
a9f0: 20 7a 2b 2b 3b 20 7d 0a 20 20 20 20 20 20 69 66   z++; }.      if
aa00: 28 20 2a 7a 3d 3d 30 20 29 20 72 65 74 75 72 6e  ( *z==0 ) return
aa10: 20 30 3b 0a 20 20 20 20 20 20 7a 2b 2b 3b 0a 20   0;.      z++;. 
aa20: 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a 20       continue;. 
aa30: 20 20 20 7d 0a 20 20 20 20 69 66 28 20 2a 7a 3d     }.    if( *z=
aa40: 3d 27 2d 27 20 26 26 20 7a 5b 31 5d 3d 3d 27 2d  ='-' && z[1]=='-
aa50: 27 20 29 7b 0a 20 20 20 20 20 20 7a 20 2b 3d 20  ' ){.      z += 
aa60: 32 3b 0a 20 20 20 20 20 20 77 68 69 6c 65 28 20  2;.      while( 
aa70: 2a 7a 20 26 26 20 2a 7a 21 3d 27 5c 6e 27 20 29  *z && *z!='\n' )
aa80: 7b 20 7a 2b 2b 3b 20 7d 0a 20 20 20 20 20 20 69  { z++; }.      i
aa90: 66 28 20 2a 7a 3d 3d 30 20 29 20 72 65 74 75 72  f( *z==0 ) retur
aaa0: 6e 20 31 3b 0a 20 20 20 20 20 20 63 6f 6e 74 69  n 1;.      conti
aab0: 6e 75 65 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72  nue;.    }.    r
aac0: 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20 20 72  eturn 0;.  }.  r
aad0: 65 74 75 72 6e 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a  eturn 1;.}../*.*
aae0: 2a 20 52 65 74 75 72 6e 20 54 52 55 45 20 69 66  * Return TRUE if
aaf0: 20 74 68 65 20 6c 69 6e 65 20 74 79 70 65 64 20   the line typed 
ab00: 69 6e 20 69 73 20 61 6e 20 53 51 4c 20 63 6f 6d  in is an SQL com
ab10: 6d 61 6e 64 20 74 65 72 6d 69 6e 61 74 6f 72 20  mand terminator 
ab20: 6f 74 68 65 72 0a 2a 2a 20 74 68 61 6e 20 61 20  other.** than a 
ab30: 73 65 6d 69 2d 63 6f 6c 6f 6e 2e 20 20 54 68 65  semi-colon.  The
ab40: 20 53 51 4c 20 53 65 72 76 65 72 20 73 74 79 6c   SQL Server styl
ab50: 65 20 22 67 6f 22 20 63 6f 6d 6d 61 6e 64 20 69  e "go" command i
ab60: 73 20 75 6e 64 65 72 73 74 6f 6f 64 0a 2a 2a 20  s understood.** 
ab70: 61 73 20 69 73 20 74 68 65 20 4f 72 61 63 6c 65  as is the Oracle
ab80: 20 22 2f 22 2e 0a 2a 2f 0a 73 74 61 74 69 63 20   "/"..*/.static 
ab90: 69 6e 74 20 5f 69 73 5f 63 6f 6d 6d 61 6e 64 5f  int _is_command_
aba0: 74 65 72 6d 69 6e 61 74 6f 72 28 63 6f 6e 73 74  terminator(const
abb0: 20 63 68 61 72 20 2a 7a 4c 69 6e 65 29 7b 0a 20   char *zLine){. 
abc0: 20 77 68 69 6c 65 28 20 69 73 73 70 61 63 65 28   while( isspace(
abd0: 2a 28 75 6e 73 69 67 6e 65 64 20 63 68 61 72 2a  *(unsigned char*
abe0: 29 7a 4c 69 6e 65 29 20 29 7b 20 7a 4c 69 6e 65  )zLine) ){ zLine
abf0: 2b 2b 3b 20 7d 3b 0a 20 20 69 66 28 20 7a 4c 69  ++; };.  if( zLi
ac00: 6e 65 5b 30 5d 3d 3d 27 2f 27 20 26 26 20 5f 61  ne[0]=='/' && _a
ac10: 6c 6c 5f 77 68 69 74 65 73 70 61 63 65 28 26 7a  ll_whitespace(&z
ac20: 4c 69 6e 65 5b 31 5d 29 20 29 20 72 65 74 75 72  Line[1]) ) retur
ac30: 6e 20 31 3b 20 20 2f 2a 20 4f 72 61 63 6c 65 20  n 1;  /* Oracle 
ac40: 2a 2f 0a 20 20 69 66 28 20 74 6f 6c 6f 77 65 72  */.  if( tolower
ac50: 28 7a 4c 69 6e 65 5b 30 5d 29 3d 3d 27 67 27 20  (zLine[0])=='g' 
ac60: 26 26 20 74 6f 6c 6f 77 65 72 28 7a 4c 69 6e 65  && tolower(zLine
ac70: 5b 31 5d 29 3d 3d 27 6f 27 0a 20 20 20 20 20 20  [1])=='o'.      
ac80: 20 20 20 26 26 20 5f 61 6c 6c 5f 77 68 69 74 65     && _all_white
ac90: 73 70 61 63 65 28 26 7a 4c 69 6e 65 5b 32 5d 29  space(&zLine[2])
aca0: 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 31   ){.    return 1
acb0: 3b 20 20 2f 2a 20 53 51 4c 20 53 65 72 76 65 72  ;  /* SQL Server
acc0: 20 2a 2f 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e   */.  }.  return
acd0: 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 61   0;.}../*.** Rea
ace0: 64 20 69 6e 70 75 74 20 66 72 6f 6d 20 2a 69 6e  d input from *in
acf0: 20 61 6e 64 20 70 72 6f 63 65 73 73 20 69 74 2e   and process it.
ad00: 20 20 49 66 20 2a 69 6e 3d 3d 30 20 74 68 65 6e    If *in==0 then
ad10: 20 69 6e 70 75 74 0a 2a 2a 20 69 73 20 69 6e 74   input.** is int
ad20: 65 72 61 63 74 69 76 65 20 2d 20 74 68 65 20 75  eractive - the u
ad30: 73 65 72 20 69 73 20 74 79 70 69 6e 67 20 69 74  ser is typing it
ad40: 20 69 74 2e 20 20 4f 74 68 65 72 77 69 73 65 2c   it.  Otherwise,
ad50: 20 69 6e 70 75 74 0a 2a 2a 20 69 73 20 63 6f 6d   input.** is com
ad60: 69 6e 67 20 66 72 6f 6d 20 61 20 66 69 6c 65 20  ing from a file 
ad70: 6f 72 20 64 65 76 69 63 65 2e 20 20 41 20 70 72  or device.  A pr
ad80: 6f 6d 70 74 20 69 73 20 69 73 73 75 65 64 20 61  ompt is issued a
ad90: 6e 64 20 68 69 73 74 6f 72 79 0a 2a 2a 20 69 73  nd history.** is
ada0: 20 73 61 76 65 64 20 6f 6e 6c 79 20 69 66 20 69   saved only if i
adb0: 6e 70 75 74 20 69 73 20 69 6e 74 65 72 61 63 74  nput is interact
adc0: 69 76 65 2e 20 20 41 6e 20 69 6e 74 65 72 72 75  ive.  An interru
add0: 70 74 20 73 69 67 6e 61 6c 20 77 69 6c 6c 0a 2a  pt signal will.*
ade0: 2a 20 63 61 75 73 65 20 74 68 69 73 20 72 6f 75  * cause this rou
adf0: 74 69 6e 65 20 74 6f 20 65 78 69 74 20 69 6d 6d  tine to exit imm
ae00: 65 64 69 61 74 65 6c 79 2c 20 75 6e 6c 65 73 73  ediately, unless
ae10: 20 69 6e 70 75 74 20 69 73 20 69 6e 74 65 72 61   input is intera
ae20: 63 74 69 76 65 2e 0a 2a 2a 0a 2a 2a 20 52 65 74  ctive..**.** Ret
ae30: 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20 6f  urn the number o
ae40: 66 20 65 72 72 6f 72 73 2e 0a 2a 2f 0a 73 74 61  f errors..*/.sta
ae50: 74 69 63 20 69 6e 74 20 70 72 6f 63 65 73 73 5f  tic int process_
ae60: 69 6e 70 75 74 28 73 74 72 75 63 74 20 63 61 6c  input(struct cal
ae70: 6c 62 61 63 6b 5f 64 61 74 61 20 2a 70 2c 20 46  lback_data *p, F
ae80: 49 4c 45 20 2a 69 6e 29 7b 0a 20 20 63 68 61 72  ILE *in){.  char
ae90: 20 2a 7a 4c 69 6e 65 3b 0a 20 20 63 68 61 72 20   *zLine;.  char 
aea0: 2a 7a 53 71 6c 20 3d 20 30 3b 0a 20 20 69 6e 74  *zSql = 0;.  int
aeb0: 20 6e 53 71 6c 20 3d 20 30 3b 0a 20 20 63 68 61   nSql = 0;.  cha
aec0: 72 20 2a 7a 45 72 72 4d 73 67 3b 0a 20 20 69 6e  r *zErrMsg;.  in
aed0: 74 20 72 63 3b 0a 20 20 69 6e 74 20 65 72 72 43  t rc;.  int errC
aee0: 6e 74 20 3d 20 30 3b 0a 20 20 69 6e 74 20 6c 69  nt = 0;.  int li
aef0: 6e 65 6e 6f 20 3d 20 30 3b 0a 20 20 69 6e 74 20  neno = 0;.  int 
af00: 73 74 61 72 74 6c 69 6e 65 20 3d 20 30 3b 0a 0a  startline = 0;..
af10: 20 20 77 68 69 6c 65 28 20 65 72 72 43 6e 74 3d    while( errCnt=
af20: 3d 30 20 7c 7c 20 21 62 61 69 6c 5f 6f 6e 5f 65  =0 || !bail_on_e
af30: 72 72 6f 72 20 7c 7c 20 28 69 6e 3d 3d 30 20 26  rror || (in==0 &
af40: 26 20 73 74 64 69 6e 5f 69 73 5f 69 6e 74 65 72  & stdin_is_inter
af50: 61 63 74 69 76 65 29 20 29 7b 0a 20 20 20 20 66  active) ){.    f
af60: 66 6c 75 73 68 28 70 2d 3e 6f 75 74 29 3b 0a 20  flush(p->out);. 
af70: 20 20 20 7a 4c 69 6e 65 20 3d 20 6f 6e 65 5f 69     zLine = one_i
af80: 6e 70 75 74 5f 6c 69 6e 65 28 7a 53 71 6c 2c 20  nput_line(zSql, 
af90: 69 6e 29 3b 0a 20 20 20 20 69 66 28 20 7a 4c 69  in);.    if( zLi
afa0: 6e 65 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 62  ne==0 ){.      b
afb0: 72 65 61 6b 3b 20 20 2f 2a 20 57 65 20 68 61 76  reak;  /* We hav
afc0: 65 20 72 65 61 63 68 65 64 20 45 4f 46 20 2a 2f  e reached EOF */
afd0: 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20 73  .    }.    if( s
afe0: 65 65 6e 49 6e 74 65 72 72 75 70 74 20 29 7b 0a  eenInterrupt ){.
aff0: 20 20 20 20 20 20 69 66 28 20 69 6e 21 3d 30 20        if( in!=0 
b000: 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 73  ) break;.      s
b010: 65 65 6e 49 6e 74 65 72 72 75 70 74 20 3d 20 30  eenInterrupt = 0
b020: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 6c 69 6e 65  ;.    }.    line
b030: 6e 6f 2b 2b 3b 0a 20 20 20 20 69 66 28 20 70 2d  no++;.    if( p-
b040: 3e 65 63 68 6f 4f 6e 20 29 20 70 72 69 6e 74 66  >echoOn ) printf
b050: 28 22 25 73 5c 6e 22 2c 20 7a 4c 69 6e 65 29 3b  ("%s\n", zLine);
b060: 0a 20 20 20 20 69 66 28 20 28 7a 53 71 6c 3d 3d  .    if( (zSql==
b070: 30 20 7c 7c 20 7a 53 71 6c 5b 30 5d 3d 3d 30 29  0 || zSql[0]==0)
b080: 20 26 26 20 5f 61 6c 6c 5f 77 68 69 74 65 73 70   && _all_whitesp
b090: 61 63 65 28 7a 4c 69 6e 65 29 20 29 20 63 6f 6e  ace(zLine) ) con
b0a0: 74 69 6e 75 65 3b 0a 20 20 20 20 69 66 28 20 7a  tinue;.    if( z
b0b0: 4c 69 6e 65 20 26 26 20 7a 4c 69 6e 65 5b 30 5d  Line && zLine[0]
b0c0: 3d 3d 27 2e 27 20 26 26 20 6e 53 71 6c 3d 3d 30  =='.' && nSql==0
b0d0: 20 29 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 64   ){.      rc = d
b0e0: 6f 5f 6d 65 74 61 5f 63 6f 6d 6d 61 6e 64 28 7a  o_meta_command(z
b0f0: 4c 69 6e 65 2c 20 70 29 3b 0a 20 20 20 20 20 20  Line, p);.      
b100: 66 72 65 65 28 7a 4c 69 6e 65 29 3b 0a 20 20 20  free(zLine);.   
b110: 20 20 20 69 66 28 20 72 63 3d 3d 32 20 29 7b 0a     if( rc==2 ){.
b120: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
b130: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 72       }else if( r
b140: 63 20 29 7b 0a 20 20 20 20 20 20 20 20 65 72 72  c ){.        err
b150: 43 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 7d 0a 20  Cnt++;.      }. 
b160: 20 20 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a 20       continue;. 
b170: 20 20 20 7d 0a 20 20 20 20 69 66 28 20 5f 69 73     }.    if( _is
b180: 5f 63 6f 6d 6d 61 6e 64 5f 74 65 72 6d 69 6e 61  _command_termina
b190: 74 6f 72 28 7a 4c 69 6e 65 29 20 29 7b 0a 20 20  tor(zLine) ){.  
b1a0: 20 20 20 20 73 74 72 63 70 79 28 7a 4c 69 6e 65      strcpy(zLine
b1b0: 2c 22 3b 22 29 3b 0a 20 20 20 20 7d 0a 20 20 20  ,";");.    }.   
b1c0: 20 69 66 28 20 7a 53 71 6c 3d 3d 30 20 29 7b 0a   if( zSql==0 ){.
b1d0: 20 20 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20        int i;.   
b1e0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 7a 4c 69 6e     for(i=0; zLin
b1f0: 65 5b 69 5d 20 26 26 20 69 73 73 70 61 63 65 28  e[i] && isspace(
b200: 28 75 6e 73 69 67 6e 65 64 20 63 68 61 72 29 7a  (unsigned char)z
b210: 4c 69 6e 65 5b 69 5d 29 3b 20 69 2b 2b 29 7b 7d  Line[i]); i++){}
b220: 0a 20 20 20 20 20 20 69 66 28 20 7a 4c 69 6e 65  .      if( zLine
b230: 5b 69 5d 21 3d 30 20 29 7b 0a 20 20 20 20 20 20  [i]!=0 ){.      
b240: 20 20 6e 53 71 6c 20 3d 20 73 74 72 6c 65 6e 28    nSql = strlen(
b250: 7a 4c 69 6e 65 29 3b 0a 20 20 20 20 20 20 20 20  zLine);.        
b260: 7a 53 71 6c 20 3d 20 6d 61 6c 6c 6f 63 28 20 6e  zSql = malloc( n
b270: 53 71 6c 2b 31 20 29 3b 0a 20 20 20 20 20 20 20  Sql+1 );.       
b280: 20 69 66 28 20 7a 53 71 6c 3d 3d 30 20 29 7b 0a   if( zSql==0 ){.
b290: 20 20 20 20 20 20 20 20 20 20 66 70 72 69 6e 74            fprint
b2a0: 66 28 73 74 64 65 72 72 2c 20 22 6f 75 74 20 6f  f(stderr, "out o
b2b0: 66 20 6d 65 6d 6f 72 79 5c 6e 22 29 3b 0a 20 20  f memory\n");.  
b2c0: 20 20 20 20 20 20 20 20 65 78 69 74 28 31 29 3b          exit(1);
b2d0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
b2e0: 20 20 20 73 74 72 63 70 79 28 7a 53 71 6c 2c 20     strcpy(zSql, 
b2f0: 7a 4c 69 6e 65 29 3b 0a 20 20 20 20 20 20 20 20  zLine);.        
b300: 73 74 61 72 74 6c 69 6e 65 20 3d 20 6c 69 6e 65  startline = line
b310: 6e 6f 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  no;.      }.    
b320: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74  }else{.      int
b330: 20 6c 65 6e 20 3d 20 73 74 72 6c 65 6e 28 7a 4c   len = strlen(zL
b340: 69 6e 65 29 3b 0a 20 20 20 20 20 20 7a 53 71 6c  ine);.      zSql
b350: 20 3d 20 72 65 61 6c 6c 6f 63 28 20 7a 53 71 6c   = realloc( zSql
b360: 2c 20 6e 53 71 6c 20 2b 20 6c 65 6e 20 2b 20 32  , nSql + len + 2
b370: 20 29 3b 0a 20 20 20 20 20 20 69 66 28 20 7a 53   );.      if( zS
b380: 71 6c 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ql==0 ){.       
b390: 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c   fprintf(stderr,
b3a0: 22 25 73 3a 20 6f 75 74 20 6f 66 20 6d 65 6d 6f  "%s: out of memo
b3b0: 72 79 21 5c 6e 22 2c 20 41 72 67 76 30 29 3b 0a  ry!\n", Argv0);.
b3c0: 20 20 20 20 20 20 20 20 65 78 69 74 28 31 29 3b          exit(1);
b3d0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73  .      }.      s
b3e0: 74 72 63 70 79 28 26 7a 53 71 6c 5b 6e 53 71 6c  trcpy(&zSql[nSql
b3f0: 2b 2b 5d 2c 20 22 5c 6e 22 29 3b 0a 20 20 20 20  ++], "\n");.    
b400: 20 20 73 74 72 63 70 79 28 26 7a 53 71 6c 5b 6e    strcpy(&zSql[n
b410: 53 71 6c 5d 2c 20 7a 4c 69 6e 65 29 3b 0a 20 20  Sql], zLine);.  
b420: 20 20 20 20 6e 53 71 6c 20 2b 3d 20 6c 65 6e 3b      nSql += len;
b430: 0a 20 20 20 20 7d 0a 20 20 20 20 66 72 65 65 28  .    }.    free(
b440: 7a 4c 69 6e 65 29 3b 0a 20 20 20 20 69 66 28 20  zLine);.    if( 
b450: 7a 53 71 6c 20 26 26 20 5f 65 6e 64 73 5f 77 69  zSql && _ends_wi
b460: 74 68 5f 73 65 6d 69 63 6f 6c 6f 6e 28 7a 53 71  th_semicolon(zSq
b470: 6c 2c 20 6e 53 71 6c 29 20 26 26 20 73 71 6c 69  l, nSql) && sqli
b480: 74 65 33 5f 63 6f 6d 70 6c 65 74 65 28 7a 53 71  te3_complete(zSq
b490: 6c 29 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 63  l) ){.      p->c
b4a0: 6e 74 20 3d 20 30 3b 0a 20 20 20 20 20 20 6f 70  nt = 0;.      op
b4b0: 65 6e 5f 64 62 28 70 29 3b 0a 20 20 20 20 20 20  en_db(p);.      
b4c0: 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 65 78 65  rc = sqlite3_exe
b4d0: 63 28 70 2d 3e 64 62 2c 20 7a 53 71 6c 2c 20 63  c(p->db, zSql, c
b4e0: 61 6c 6c 62 61 63 6b 2c 20 70 2c 20 26 7a 45 72  allback, p, &zEr
b4f0: 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 69 66 28  rMsg);.      if(
b500: 20 72 63 20 7c 7c 20 7a 45 72 72 4d 73 67 20 29   rc || zErrMsg )
b510: 7b 0a 20 20 20 20 20 20 20 20 63 68 61 72 20 7a  {.        char z
b520: 50 72 65 66 69 78 5b 31 30 30 5d 3b 0a 20 20 20  Prefix[100];.   
b530: 20 20 20 20 20 69 66 28 20 69 6e 21 3d 30 20 7c       if( in!=0 |
b540: 7c 20 21 73 74 64 69 6e 5f 69 73 5f 69 6e 74 65  | !stdin_is_inte
b550: 72 61 63 74 69 76 65 20 29 7b 0a 20 20 20 20 20  ractive ){.     
b560: 20 20 20 20 20 73 70 72 69 6e 74 66 28 7a 50 72       sprintf(zPr
b570: 65 66 69 78 2c 20 22 53 51 4c 20 65 72 72 6f 72  efix, "SQL error
b580: 20 6e 65 61 72 20 6c 69 6e 65 20 25 64 3a 22 2c   near line %d:",
b590: 20 73 74 61 72 74 6c 69 6e 65 29 3b 0a 20 20 20   startline);.   
b5a0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
b5b0: 20 20 20 20 20 20 73 70 72 69 6e 74 66 28 7a 50        sprintf(zP
b5c0: 72 65 66 69 78 2c 20 22 53 51 4c 20 65 72 72 6f  refix, "SQL erro
b5d0: 72 3a 22 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  r:");.        }.
b5e0: 20 20 20 20 20 20 20 20 69 66 28 20 7a 45 72 72          if( zErr
b5f0: 4d 73 67 21 3d 30 20 29 7b 0a 20 20 20 20 20 20  Msg!=0 ){.      
b600: 20 20 20 20 70 72 69 6e 74 66 28 22 25 73 20 25      printf("%s %
b610: 73 5c 6e 22 2c 20 7a 50 72 65 66 69 78 2c 20 7a  s\n", zPrefix, z
b620: 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 20  ErrMsg);.       
b630: 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28     sqlite3_free(
b640: 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20  zErrMsg);.      
b650: 20 20 20 20 7a 45 72 72 4d 73 67 20 3d 20 30 3b      zErrMsg = 0;
b660: 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a  .        }else{.
b670: 20 20 20 20 20 20 20 20 20 20 70 72 69 6e 74 66            printf
b680: 28 22 25 73 20 25 73 5c 6e 22 2c 20 7a 50 72 65  ("%s %s\n", zPre
b690: 66 69 78 2c 20 73 71 6c 69 74 65 33 5f 65 72 72  fix, sqlite3_err
b6a0: 6d 73 67 28 70 2d 3e 64 62 29 29 3b 0a 20 20 20  msg(p->db));.   
b6b0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 65       }.        e
b6c0: 72 72 43 6e 74 2b 2b 3b 0a 20 20 20 20 20 20 7d  rrCnt++;.      }
b6d0: 0a 20 20 20 20 20 20 66 72 65 65 28 7a 53 71 6c  .      free(zSql
b6e0: 29 3b 0a 20 20 20 20 20 20 7a 53 71 6c 20 3d 20  );.      zSql = 
b6f0: 30 3b 0a 20 20 20 20 20 20 6e 53 71 6c 20 3d 20  0;.      nSql = 
b700: 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 69  0;.    }.  }.  i
b710: 66 28 20 7a 53 71 6c 20 29 7b 0a 20 20 20 20 69  f( zSql ){.    i
b720: 66 28 20 21 5f 61 6c 6c 5f 77 68 69 74 65 73 70  f( !_all_whitesp
b730: 61 63 65 28 7a 53 71 6c 29 20 29 20 70 72 69 6e  ace(zSql) ) prin
b740: 74 66 28 22 49 6e 63 6f 6d 70 6c 65 74 65 20 53  tf("Incomplete S
b750: 51 4c 3a 20 25 73 5c 6e 22 2c 20 7a 53 71 6c 29  QL: %s\n", zSql)
b760: 3b 0a 20 20 20 20 66 72 65 65 28 7a 53 71 6c 29  ;.    free(zSql)
b770: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 65  ;.  }.  return e
b780: 72 72 43 6e 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  rrCnt;.}../*.** 
b790: 52 65 74 75 72 6e 20 61 20 70 61 74 68 6e 61 6d  Return a pathnam
b7a0: 65 20 77 68 69 63 68 20 69 73 20 74 68 65 20 75  e which is the u
b7b0: 73 65 72 27 73 20 68 6f 6d 65 20 64 69 72 65 63  ser's home direc
b7c0: 74 6f 72 79 2e 20 20 41 0a 2a 2a 20 30 20 72 65  tory.  A.** 0 re
b7d0: 74 75 72 6e 20 69 6e 64 69 63 61 74 65 73 20 61  turn indicates a
b7e0: 6e 20 65 72 72 6f 72 20 6f 66 20 73 6f 6d 65 20  n error of some 
b7f0: 6b 69 6e 64 2e 20 20 53 70 61 63 65 20 74 6f 20  kind.  Space to 
b800: 68 6f 6c 64 20 74 68 65 0a 2a 2a 20 72 65 73 75  hold the.** resu
b810: 6c 74 69 6e 67 20 73 74 72 69 6e 67 20 69 73 20  lting string is 
b820: 6f 62 74 61 69 6e 65 64 20 66 72 6f 6d 20 6d 61  obtained from ma
b830: 6c 6c 6f 63 28 29 2e 20 20 54 68 65 20 63 61 6c  lloc().  The cal
b840: 6c 69 6e 67 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e  ling.** function
b850: 20 73 68 6f 75 6c 64 20 66 72 65 65 20 74 68 65   should free the
b860: 20 72 65 73 75 6c 74 2e 0a 2a 2f 0a 73 74 61 74   result..*/.stat
b870: 69 63 20 63 68 61 72 20 2a 66 69 6e 64 5f 68 6f  ic char *find_ho
b880: 6d 65 5f 64 69 72 28 76 6f 69 64 29 7b 0a 20 20  me_dir(void){.  
b890: 63 68 61 72 20 2a 68 6f 6d 65 5f 64 69 72 20 3d  char *home_dir =
b8a0: 20 4e 55 4c 4c 3b 0a 0a 23 69 66 20 21 64 65 66   NULL;..#if !def
b8b0: 69 6e 65 64 28 5f 57 49 4e 33 32 29 20 26 26 20  ined(_WIN32) && 
b8c0: 21 64 65 66 69 6e 65 64 28 57 49 4e 33 32 29 20  !defined(WIN32) 
b8d0: 26 26 20 21 64 65 66 69 6e 65 64 28 5f 5f 4d 41  && !defined(__MA
b8e0: 43 4f 53 5f 5f 29 20 26 26 20 21 64 65 66 69 6e  COS__) && !defin
b8f0: 65 64 28 5f 5f 4f 53 32 5f 5f 29 0a 20 20 73 74  ed(__OS2__).  st
b900: 72 75 63 74 20 70 61 73 73 77 64 20 2a 70 77 65  ruct passwd *pwe
b910: 6e 74 3b 0a 20 20 75 69 64 5f 74 20 75 69 64 20  nt;.  uid_t uid 
b920: 3d 20 67 65 74 75 69 64 28 29 3b 0a 20 20 69 66  = getuid();.  if
b930: 28 20 28 70 77 65 6e 74 3d 67 65 74 70 77 75 69  ( (pwent=getpwui
b940: 64 28 75 69 64 29 29 20 21 3d 20 4e 55 4c 4c 29  d(uid)) != NULL)
b950: 20 7b 0a 20 20 20 20 68 6f 6d 65 5f 64 69 72 20   {.    home_dir 
b960: 3d 20 70 77 65 6e 74 2d 3e 70 77 5f 64 69 72 3b  = pwent->pw_dir;
b970: 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 23 69 66  .  }.#endif..#if
b980: 64 65 66 20 5f 5f 4d 41 43 4f 53 5f 5f 0a 20 20  def __MACOS__.  
b990: 63 68 61 72 20 68 6f 6d 65 5f 70 61 74 68 5b 5f  char home_path[_
b9a0: 4d 41 58 5f 50 41 54 48 2b 31 5d 3b 0a 20 20 68  MAX_PATH+1];.  h
b9b0: 6f 6d 65 5f 64 69 72 20 3d 20 67 65 74 63 77 64  ome_dir = getcwd
b9c0: 28 68 6f 6d 65 5f 70 61 74 68 2c 20 5f 4d 41 58  (home_path, _MAX
b9d0: 5f 50 41 54 48 29 3b 0a 23 65 6e 64 69 66 0a 0a  _PATH);.#endif..
b9e0: 23 69 66 20 64 65 66 69 6e 65 64 28 5f 57 49 4e  #if defined(_WIN
b9f0: 33 32 29 20 7c 7c 20 64 65 66 69 6e 65 64 28 57  32) || defined(W
ba00: 49 4e 33 32 29 20 7c 7c 20 64 65 66 69 6e 65 64  IN32) || defined
ba10: 28 5f 5f 4f 53 32 5f 5f 29 0a 20 20 69 66 20 28  (__OS2__).  if (
ba20: 21 68 6f 6d 65 5f 64 69 72 29 20 7b 0a 20 20 20  !home_dir) {.   
ba30: 20 68 6f 6d 65 5f 64 69 72 20 3d 20 67 65 74 65   home_dir = gete
ba40: 6e 76 28 22 55 53 45 52 50 52 4f 46 49 4c 45 22  nv("USERPROFILE"
ba50: 29 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20  );.  }.#endif.. 
ba60: 20 69 66 20 28 21 68 6f 6d 65 5f 64 69 72 29 20   if (!home_dir) 
ba70: 7b 0a 20 20 20 20 68 6f 6d 65 5f 64 69 72 20 3d  {.    home_dir =
ba80: 20 67 65 74 65 6e 76 28 22 48 4f 4d 45 22 29 3b   getenv("HOME");
ba90: 0a 20 20 7d 0a 0a 23 69 66 20 64 65 66 69 6e 65  .  }..#if define
baa0: 64 28 5f 57 49 4e 33 32 29 20 7c 7c 20 64 65 66  d(_WIN32) || def
bab0: 69 6e 65 64 28 57 49 4e 33 32 29 20 7c 7c 20 64  ined(WIN32) || d
bac0: 65 66 69 6e 65 64 28 5f 5f 4f 53 32 5f 5f 29 0a  efined(__OS2__).
bad0: 20 20 69 66 20 28 21 68 6f 6d 65 5f 64 69 72 29    if (!home_dir)
bae0: 20 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 44 72   {.    char *zDr
baf0: 69 76 65 2c 20 2a 7a 50 61 74 68 3b 0a 20 20 20  ive, *zPath;.   
bb00: 20 69 6e 74 20 6e 3b 0a 20 20 20 20 7a 44 72 69   int n;.    zDri
bb10: 76 65 20 3d 20 67 65 74 65 6e 76 28 22 48 4f 4d  ve = getenv("HOM
bb20: 45 44 52 49 56 45 22 29 3b 0a 20 20 20 20 7a 50  EDRIVE");.    zP
bb30: 61 74 68 20 3d 20 67 65 74 65 6e 76 28 22 48 4f  ath = getenv("HO
bb40: 4d 45 50 41 54 48 22 29 3b 0a 20 20 20 20 69 66  MEPATH");.    if
bb50: 28 20 7a 44 72 69 76 65 20 26 26 20 7a 50 61 74  ( zDrive && zPat
bb60: 68 20 29 7b 0a 20 20 20 20 20 20 6e 20 3d 20 73  h ){.      n = s
bb70: 74 72 6c 65 6e 28 7a 44 72 69 76 65 29 20 2b 20  trlen(zDrive) + 
bb80: 73 74 72 6c 65 6e 28 7a 50 61 74 68 29 20 2b 20  strlen(zPath) + 
bb90: 31 3b 0a 20 20 20 20 20 20 68 6f 6d 65 5f 64 69  1;.      home_di
bba0: 72 20 3d 20 6d 61 6c 6c 6f 63 28 20 6e 20 29 3b  r = malloc( n );
bbb0: 0a 20 20 20 20 20 20 69 66 28 20 68 6f 6d 65 5f  .      if( home_
bbc0: 64 69 72 3d 3d 30 20 29 20 72 65 74 75 72 6e 20  dir==0 ) return 
bbd0: 30 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  0;.      sqlite3
bbe0: 5f 73 6e 70 72 69 6e 74 66 28 6e 2c 20 68 6f 6d  _snprintf(n, hom
bbf0: 65 5f 64 69 72 2c 20 22 25 73 25 73 22 2c 20 7a  e_dir, "%s%s", z
bc00: 44 72 69 76 65 2c 20 7a 50 61 74 68 29 3b 0a 20  Drive, zPath);. 
bc10: 20 20 20 20 20 72 65 74 75 72 6e 20 68 6f 6d 65       return home
bc20: 5f 64 69 72 3b 0a 20 20 20 20 7d 0a 20 20 20 20  _dir;.    }.    
bc30: 68 6f 6d 65 5f 64 69 72 20 3d 20 22 63 3a 5c 5c  home_dir = "c:\\
bc40: 22 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20  ";.  }.#endif.. 
bc50: 20 69 66 28 20 68 6f 6d 65 5f 64 69 72 20 29 7b   if( home_dir ){
bc60: 0a 20 20 20 20 63 68 61 72 20 2a 7a 20 3d 20 6d  .    char *z = m
bc70: 61 6c 6c 6f 63 28 20 73 74 72 6c 65 6e 28 68 6f  alloc( strlen(ho
bc80: 6d 65 5f 64 69 72 29 2b 31 20 29 3b 0a 20 20 20  me_dir)+1 );.   
bc90: 20 69 66 28 20 7a 20 29 20 73 74 72 63 70 79 28   if( z ) strcpy(
bca0: 7a 2c 20 68 6f 6d 65 5f 64 69 72 29 3b 0a 20 20  z, home_dir);.  
bcb0: 20 20 68 6f 6d 65 5f 64 69 72 20 3d 20 7a 3b 0a    home_dir = z;.
bcc0: 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20 68 6f    }..  return ho
bcd0: 6d 65 5f 64 69 72 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  me_dir;.}../*.**
bce0: 20 52 65 61 64 20 69 6e 70 75 74 20 66 72 6f 6d   Read input from
bcf0: 20 74 68 65 20 66 69 6c 65 20 67 69 76 65 6e 20   the file given 
bd00: 62 79 20 73 71 6c 69 74 65 72 63 5f 6f 76 65 72  by sqliterc_over
bd10: 72 69 64 65 2e 20 20 4f 72 20 69 66 20 74 68 61  ride.  Or if tha
bd20: 74 0a 2a 2a 20 70 61 72 61 6d 65 74 65 72 20 69  t.** parameter i
bd30: 73 20 4e 55 4c 4c 2c 20 74 61 6b 65 20 69 6e 70  s NULL, take inp
bd40: 75 74 20 66 72 6f 6d 20 7e 2f 2e 73 71 6c 69 74  ut from ~/.sqlit
bd50: 65 72 63 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  erc.*/.static vo
bd60: 69 64 20 70 72 6f 63 65 73 73 5f 73 71 6c 69 74  id process_sqlit
bd70: 65 72 63 28 0a 20 20 73 74 72 75 63 74 20 63 61  erc(.  struct ca
bd80: 6c 6c 62 61 63 6b 5f 64 61 74 61 20 2a 70 2c 20  llback_data *p, 
bd90: 20 20 20 20 20 20 20 2f 2a 20 43 6f 6e 66 69 67         /* Config
bda0: 75 72 61 74 69 6f 6e 20 64 61 74 61 20 2a 2f 0a  uration data */.
bdb0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 73 71    const char *sq
bdc0: 6c 69 74 65 72 63 5f 6f 76 65 72 72 69 64 65 20  literc_override 
bdd0: 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 63 6f 6e    /* Name of con
bde0: 66 69 67 20 66 69 6c 65 2e 20 4e 55 4c 4c 20 74  fig file. NULL t
bdf0: 6f 20 75 73 65 20 64 65 66 61 75 6c 74 20 2a 2f  o use default */
be00: 0a 29 7b 0a 20 20 63 68 61 72 20 2a 68 6f 6d 65  .){.  char *home
be10: 5f 64 69 72 20 3d 20 4e 55 4c 4c 3b 0a 20 20 63  _dir = NULL;.  c
be20: 6f 6e 73 74 20 63 68 61 72 20 2a 73 71 6c 69 74  onst char *sqlit
be30: 65 72 63 20 3d 20 73 71 6c 69 74 65 72 63 5f 6f  erc = sqliterc_o
be40: 76 65 72 72 69 64 65 3b 0a 20 20 63 68 61 72 20  verride;.  char 
be50: 2a 7a 42 75 66 20 3d 20 30 3b 0a 20 20 46 49 4c  *zBuf = 0;.  FIL
be60: 45 20 2a 69 6e 20 3d 20 4e 55 4c 4c 3b 0a 0a 20  E *in = NULL;.. 
be70: 20 69 66 20 28 73 71 6c 69 74 65 72 63 20 3d 3d   if (sqliterc ==
be80: 20 4e 55 4c 4c 29 20 7b 0a 20 20 20 20 68 6f 6d   NULL) {.    hom
be90: 65 5f 64 69 72 20 3d 20 66 69 6e 64 5f 68 6f 6d  e_dir = find_hom
bea0: 65 5f 64 69 72 28 29 3b 0a 20 20 20 20 69 66 28  e_dir();.    if(
beb0: 20 68 6f 6d 65 5f 64 69 72 3d 3d 30 20 29 7b 0a   home_dir==0 ){.
bec0: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 73 74        fprintf(st
bed0: 64 65 72 72 2c 22 25 73 3a 20 63 61 6e 6e 6f 74  derr,"%s: cannot
bee0: 20 6c 6f 63 61 74 65 20 79 6f 75 72 20 68 6f 6d   locate your hom
bef0: 65 20 64 69 72 65 63 74 6f 72 79 21 5c 6e 22 2c  e directory!\n",
bf00: 20 41 72 67 76 30 29 3b 0a 20 20 20 20 20 20 72   Argv0);.      r
bf10: 65 74 75 72 6e 3b 0a 20 20 20 20 7d 0a 20 20 20  eturn;.    }.   
bf20: 20 7a 42 75 66 20 3d 20 6d 61 6c 6c 6f 63 28 73   zBuf = malloc(s
bf30: 74 72 6c 65 6e 28 68 6f 6d 65 5f 64 69 72 29 20  trlen(home_dir) 
bf40: 2b 20 31 35 29 3b 0a 20 20 20 20 69 66 28 20 7a  + 15);.    if( z
bf50: 42 75 66 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  Buf==0 ){.      
bf60: 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c 22  fprintf(stderr,"
bf70: 25 73 3a 20 6f 75 74 20 6f 66 20 6d 65 6d 6f 72  %s: out of memor
bf80: 79 21 5c 6e 22 2c 20 41 72 67 76 30 29 3b 0a 20  y!\n", Argv0);. 
bf90: 20 20 20 20 20 65 78 69 74 28 31 29 3b 0a 20 20       exit(1);.  
bfa0: 20 20 7d 0a 20 20 20 20 73 70 72 69 6e 74 66 28    }.    sprintf(
bfb0: 7a 42 75 66 2c 22 25 73 2f 2e 73 71 6c 69 74 65  zBuf,"%s/.sqlite
bfc0: 72 63 22 2c 68 6f 6d 65 5f 64 69 72 29 3b 0a 20  rc",home_dir);. 
bfd0: 20 20 20 66 72 65 65 28 68 6f 6d 65 5f 64 69 72     free(home_dir
bfe0: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 72 63 20  );.    sqliterc 
bff0: 3d 20 28 63 6f 6e 73 74 20 63 68 61 72 2a 29 7a  = (const char*)z
c000: 42 75 66 3b 0a 20 20 7d 0a 20 20 69 6e 20 3d 20  Buf;.  }.  in = 
c010: 66 6f 70 65 6e 28 73 71 6c 69 74 65 72 63 2c 22  fopen(sqliterc,"
c020: 72 62 22 29 3b 0a 20 20 69 66 28 20 69 6e 20 29  rb");.  if( in )
c030: 7b 0a 20 20 20 20 69 66 28 20 73 74 64 69 6e 5f  {.    if( stdin_
c040: 69 73 5f 69 6e 74 65 72 61 63 74 69 76 65 20 29  is_interactive )
c050: 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66 28 22  {.      printf("
c060: 4c 6f 61 64 69 6e 67 20 72 65 73 6f 75 72 63 65  Loading resource
c070: 73 20 66 72 6f 6d 20 25 73 5c 6e 22 2c 73 71 6c  s from %s\n",sql
c080: 69 74 65 72 63 29 3b 0a 20 20 20 20 7d 0a 20 20  iterc);.    }.  
c090: 20 20 70 72 6f 63 65 73 73 5f 69 6e 70 75 74 28    process_input(
c0a0: 70 2c 69 6e 29 3b 0a 20 20 20 20 66 63 6c 6f 73  p,in);.    fclos
c0b0: 65 28 69 6e 29 3b 0a 20 20 7d 0a 20 20 66 72 65  e(in);.  }.  fre
c0c0: 65 28 7a 42 75 66 29 3b 0a 20 20 72 65 74 75 72  e(zBuf);.  retur
c0d0: 6e 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53 68 6f 77  n;.}../*.** Show
c0e0: 20 61 76 61 69 6c 61 62 6c 65 20 63 6f 6d 6d 61   available comma
c0f0: 6e 64 20 6c 69 6e 65 20 6f 70 74 69 6f 6e 73 0a  nd line options.
c100: 2a 2f 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20  */.static const 
c110: 63 68 61 72 20 7a 4f 70 74 69 6f 6e 73 5b 5d 20  char zOptions[] 
c120: 3d 20 0a 20 20 22 20 20 20 2d 69 6e 69 74 20 66  = .  "   -init f
c130: 69 6c 65 6e 61 6d 65 20 20 20 20 20 20 20 72 65  ilename       re
c140: 61 64 2f 70 72 6f 63 65 73 73 20 6e 61 6d 65 64  ad/process named
c150: 20 66 69 6c 65 5c 6e 22 0a 20 20 22 20 20 20 2d   file\n".  "   -
c160: 65 63 68 6f 20 20 20 20 20 20 20 20 20 20 20 20  echo            
c170: 20 20 20 20 70 72 69 6e 74 20 63 6f 6d 6d 61 6e      print comman
c180: 64 73 20 62 65 66 6f 72 65 20 65 78 65 63 75 74  ds before execut
c190: 69 6f 6e 5c 6e 22 0a 20 20 22 20 20 20 2d 5b 6e  ion\n".  "   -[n
c1a0: 6f 5d 68 65 61 64 65 72 20 20 20 20 20 20 20 20  o]header        
c1b0: 20 20 74 75 72 6e 20 68 65 61 64 65 72 73 20 6f    turn headers o
c1c0: 6e 20 6f 72 20 6f 66 66 5c 6e 22 0a 20 20 22 20  n or off\n".  " 
c1d0: 20 20 2d 62 61 69 6c 20 20 20 20 20 20 20 20 20    -bail         
c1e0: 20 20 20 20 20 20 20 73 74 6f 70 20 61 66 74 65         stop afte
c1f0: 72 20 68 69 74 74 69 6e 67 20 61 6e 20 65 72 72  r hitting an err
c200: 6f 72 5c 6e 22 0a 20 20 22 20 20 20 2d 69 6e 74  or\n".  "   -int
c210: 65 72 61 63 74 69 76 65 20 20 20 20 20 20 20 20  eractive        
c220: 20 66 6f 72 63 65 20 69 6e 74 65 72 61 63 74 69   force interacti
c230: 76 65 20 49 2f 4f 5c 6e 22 0a 20 20 22 20 20 20  ve I/O\n".  "   
c240: 2d 62 61 74 63 68 20 20 20 20 20 20 20 20 20 20  -batch          
c250: 20 20 20 20 20 66 6f 72 63 65 20 62 61 74 63 68       force batch
c260: 20 49 2f 4f 5c 6e 22 0a 20 20 22 20 20 20 2d 63   I/O\n".  "   -c
c270: 6f 6c 75 6d 6e 20 20 20 20 20 20 20 20 20 20 20  olumn           
c280: 20 20 20 73 65 74 20 6f 75 74 70 75 74 20 6d 6f     set output mo
c290: 64 65 20 74 6f 20 27 63 6f 6c 75 6d 6e 27 5c 6e  de to 'column'\n
c2a0: 22 0a 20 20 22 20 20 20 2d 63 73 76 20 20 20 20  ".  "   -csv    
c2b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 65 74               set
c2c0: 20 6f 75 74 70 75 74 20 6d 6f 64 65 20 74 6f 20   output mode to 
c2d0: 27 63 73 76 27 5c 6e 22 0a 20 20 22 20 20 20 2d  'csv'\n".  "   -
c2e0: 68 74 6d 6c 20 20 20 20 20 20 20 20 20 20 20 20  html            
c2f0: 20 20 20 20 73 65 74 20 6f 75 74 70 75 74 20 6d      set output m
c300: 6f 64 65 20 74 6f 20 48 54 4d 4c 5c 6e 22 0a 20  ode to HTML\n". 
c310: 20 22 20 20 20 2d 6c 69 6e 65 20 20 20 20 20 20   "   -line      
c320: 20 20 20 20 20 20 20 20 20 20 73 65 74 20 6f 75            set ou
c330: 74 70 75 74 20 6d 6f 64 65 20 74 6f 20 27 6c 69  tput mode to 'li
c340: 6e 65 27 5c 6e 22 0a 20 20 22 20 20 20 2d 6c 69  ne'\n".  "   -li
c350: 73 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20  st              
c360: 20 20 73 65 74 20 6f 75 74 70 75 74 20 6d 6f 64    set output mod
c370: 65 20 74 6f 20 27 6c 69 73 74 27 5c 6e 22 0a 20  e to 'list'\n". 
c380: 20 22 20 20 20 2d 73 65 70 61 72 61 74 6f 72 20   "   -separator 
c390: 27 78 27 20 20 20 20 20 20 20 73 65 74 20 6f 75  'x'       set ou
c3a0: 74 70 75 74 20 66 69 65 6c 64 20 73 65 70 61 72  tput field separ
c3b0: 61 74 6f 72 20 28 7c 29 5c 6e 22 0a 20 20 22 20  ator (|)\n".  " 
c3c0: 20 20 2d 6e 75 6c 6c 76 61 6c 75 65 20 27 74 65    -nullvalue 'te
c3d0: 78 74 27 20 20 20 20 73 65 74 20 74 65 78 74 20  xt'    set text 
c3e0: 73 74 72 69 6e 67 20 66 6f 72 20 4e 55 4c 4c 20  string for NULL 
c3f0: 76 61 6c 75 65 73 5c 6e 22 0a 20 20 22 20 20 20  values\n".  "   
c400: 2d 76 65 72 73 69 6f 6e 20 20 20 20 20 20 20 20  -version        
c410: 20 20 20 20 20 73 68 6f 77 20 53 51 4c 69 74 65       show SQLite
c420: 20 76 65 72 73 69 6f 6e 5c 6e 22 0a 3b 0a 73 74   version\n".;.st
c430: 61 74 69 63 20 76 6f 69 64 20 75 73 61 67 65 28  atic void usage(
c440: 69 6e 74 20 73 68 6f 77 44 65 74 61 69 6c 29 7b  int showDetail){
c450: 0a 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72  .  fprintf(stder
c460: 72 2c 0a 20 20 20 20 20 20 22 55 73 61 67 65 3a  r,.      "Usage:
c470: 20 25 73 20 5b 4f 50 54 49 4f 4e 53 5d 20 46 49   %s [OPTIONS] FI
c480: 4c 45 4e 41 4d 45 20 5b 53 51 4c 5d 5c 6e 22 20  LENAME [SQL]\n" 
c490: 20 0a 20 20 20 20 20 20 22 46 49 4c 45 4e 41 4d   .      "FILENAM
c4a0: 45 20 69 73 20 74 68 65 20 6e 61 6d 65 20 6f 66  E is the name of
c4b0: 20 61 6e 20 53 51 4c 69 74 65 20 64 61 74 61 62   an SQLite datab
c4c0: 61 73 65 2e 20 41 20 6e 65 77 20 64 61 74 61 62  ase. A new datab
c4d0: 61 73 65 20 69 73 20 63 72 65 61 74 65 64 5c 6e  ase is created\n
c4e0: 22 0a 20 20 20 20 20 20 22 69 66 20 74 68 65 20  ".      "if the 
c4f0: 66 69 6c 65 20 64 6f 65 73 20 6e 6f 74 20 70 72  file does not pr
c500: 65 76 69 6f 75 73 6c 79 20 65 78 69 73 74 2e 5c  eviously exist.\
c510: 6e 22 2c 20 41 72 67 76 30 29 3b 0a 20 20 69 66  n", Argv0);.  if
c520: 28 20 73 68 6f 77 44 65 74 61 69 6c 20 29 7b 0a  ( showDetail ){.
c530: 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65      fprintf(stde
c540: 72 72 2c 20 22 4f 50 54 49 4f 4e 53 20 69 6e 63  rr, "OPTIONS inc
c550: 6c 75 64 65 3a 5c 6e 25 73 22 2c 20 7a 4f 70 74  lude:\n%s", zOpt
c560: 69 6f 6e 73 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a  ions);.  }else{.
c570: 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65      fprintf(stde
c580: 72 72 2c 20 22 55 73 65 20 74 68 65 20 2d 68 65  rr, "Use the -he
c590: 6c 70 20 6f 70 74 69 6f 6e 20 66 6f 72 20 61 64  lp option for ad
c5a0: 64 69 74 69 6f 6e 61 6c 20 69 6e 66 6f 72 6d 61  ditional informa
c5b0: 74 69 6f 6e 5c 6e 22 29 3b 0a 20 20 7d 0a 20 20  tion\n");.  }.  
c5c0: 65 78 69 74 28 31 29 3b 0a 7d 0a 0a 2f 2a 0a 2a  exit(1);.}../*.*
c5d0: 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 74 68 65  * Initialize the
c5e0: 20 73 74 61 74 65 20 69 6e 66 6f 72 6d 61 74 69   state informati
c5f0: 6f 6e 20 69 6e 20 64 61 74 61 0a 2a 2f 0a 73 74  on in data.*/.st
c600: 61 74 69 63 20 76 6f 69 64 20 6d 61 69 6e 5f 69  atic void main_i
c610: 6e 69 74 28 73 74 72 75 63 74 20 63 61 6c 6c 62  nit(struct callb
c620: 61 63 6b 5f 64 61 74 61 20 2a 64 61 74 61 29 20  ack_data *data) 
c630: 7b 0a 20 20 6d 65 6d 73 65 74 28 64 61 74 61 2c  {.  memset(data,
c640: 20 30 2c 20 73 69 7a 65 6f 66 28 2a 64 61 74 61   0, sizeof(*data
c650: 29 29 3b 0a 20 20 64 61 74 61 2d 3e 6d 6f 64 65  ));.  data->mode
c660: 20 3d 20 4d 4f 44 45 5f 4c 69 73 74 3b 0a 20 20   = MODE_List;.  
c670: 73 74 72 63 70 79 28 64 61 74 61 2d 3e 73 65 70  strcpy(data->sep
c680: 61 72 61 74 6f 72 2c 22 7c 22 29 3b 0a 20 20 64  arator,"|");.  d
c690: 61 74 61 2d 3e 73 68 6f 77 48 65 61 64 65 72 20  ata->showHeader 
c6a0: 3d 20 30 3b 0a 20 20 73 74 72 63 70 79 28 6d 61  = 0;.  strcpy(ma
c6b0: 69 6e 50 72 6f 6d 70 74 2c 22 73 71 6c 69 74 65  inPrompt,"sqlite
c6c0: 3e 20 22 29 3b 0a 20 20 73 74 72 63 70 79 28 63  > ");.  strcpy(c
c6d0: 6f 6e 74 69 6e 75 65 50 72 6f 6d 70 74 2c 22 20  ontinuePrompt," 
c6e0: 20 20 2e 2e 2e 3e 20 22 29 3b 0a 7d 0a 0a 69 6e    ...> ");.}..in
c6f0: 74 20 6d 61 69 6e 28 69 6e 74 20 61 72 67 63 2c  t main(int argc,
c700: 20 63 68 61 72 20 2a 2a 61 72 67 76 29 7b 0a 20   char **argv){. 
c710: 20 63 68 61 72 20 2a 7a 45 72 72 4d 73 67 20 3d   char *zErrMsg =
c720: 20 30 3b 0a 20 20 73 74 72 75 63 74 20 63 61 6c   0;.  struct cal
c730: 6c 62 61 63 6b 5f 64 61 74 61 20 64 61 74 61 3b  lback_data data;
c740: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
c750: 49 6e 69 74 46 69 6c 65 20 3d 20 30 3b 0a 20 20  InitFile = 0;.  
c760: 63 68 61 72 20 2a 7a 46 69 72 73 74 43 6d 64 20  char *zFirstCmd 
c770: 3d 20 30 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20  = 0;.  int i;.  
c780: 69 6e 74 20 72 63 20 3d 20 30 3b 0a 0a 23 69 66  int rc = 0;..#if
c790: 64 65 66 20 5f 5f 4d 41 43 4f 53 5f 5f 0a 20 20  def __MACOS__.  
c7a0: 61 72 67 63 20 3d 20 63 63 6f 6d 6d 61 6e 64 28  argc = ccommand(
c7b0: 26 61 72 67 76 29 3b 0a 23 65 6e 64 69 66 0a 0a  &argv);.#endif..
c7c0: 20 20 41 72 67 76 30 20 3d 20 61 72 67 76 5b 30    Argv0 = argv[0
c7d0: 5d 3b 0a 20 20 6d 61 69 6e 5f 69 6e 69 74 28 26  ];.  main_init(&
c7e0: 64 61 74 61 29 3b 0a 20 20 73 74 64 69 6e 5f 69  data);.  stdin_i
c7f0: 73 5f 69 6e 74 65 72 61 63 74 69 76 65 20 3d 20  s_interactive = 
c800: 69 73 61 74 74 79 28 30 29 3b 0a 0a 20 20 2f 2a  isatty(0);..  /*
c810: 20 4d 61 6b 65 20 73 75 72 65 20 77 65 20 68 61   Make sure we ha
c820: 76 65 20 61 20 76 61 6c 69 64 20 73 69 67 6e 61  ve a valid signa
c830: 6c 20 68 61 6e 64 6c 65 72 20 65 61 72 6c 79 2c  l handler early,
c840: 20 62 65 66 6f 72 65 20 61 6e 79 74 68 69 6e 67   before anything
c850: 0a 20 20 2a 2a 20 65 6c 73 65 20 69 73 20 64 6f  .  ** else is do
c860: 6e 65 2e 0a 20 20 2a 2f 0a 23 69 66 64 65 66 20  ne..  */.#ifdef 
c870: 53 49 47 49 4e 54 0a 20 20 73 69 67 6e 61 6c 28  SIGINT.  signal(
c880: 53 49 47 49 4e 54 2c 20 69 6e 74 65 72 72 75 70  SIGINT, interrup
c890: 74 5f 68 61 6e 64 6c 65 72 29 3b 0a 23 65 6e 64  t_handler);.#end
c8a0: 69 66 0a 0a 20 20 2f 2a 20 44 6f 20 61 6e 20 69  if..  /* Do an i
c8b0: 6e 69 74 69 61 6c 20 70 61 73 73 20 74 68 72 6f  nitial pass thro
c8c0: 75 67 68 20 74 68 65 20 63 6f 6d 6d 61 6e 64 2d  ugh the command-
c8d0: 6c 69 6e 65 20 61 72 67 75 6d 65 6e 74 20 74 6f  line argument to
c8e0: 20 6c 6f 63 61 74 65 0a 20 20 2a 2a 20 74 68 65   locate.  ** the
c8f0: 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 64 61 74   name of the dat
c900: 61 62 61 73 65 20 66 69 6c 65 2c 20 74 68 65 20  abase file, the 
c910: 6e 61 6d 65 20 6f 66 20 74 68 65 20 69 6e 69 74  name of the init
c920: 69 61 6c 69 7a 61 74 69 6f 6e 20 66 69 6c 65 2c  ialization file,
c930: 0a 20 20 2a 2a 20 61 6e 64 20 74 68 65 20 66 69  .  ** and the fi
c940: 72 73 74 20 63 6f 6d 6d 61 6e 64 20 74 6f 20 65  rst command to e
c950: 78 65 63 75 74 65 2e 0a 20 20 2a 2f 0a 20 20 66  xecute..  */.  f
c960: 6f 72 28 69 3d 31 3b 20 69 3c 61 72 67 63 2d 31  or(i=1; i<argc-1
c970: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 63 68 61 72  ; i++){.    char
c980: 20 2a 7a 3b 0a 20 20 20 20 69 66 28 20 61 72 67   *z;.    if( arg
c990: 76 5b 69 5d 5b 30 5d 21 3d 27 2d 27 20 29 20 62  v[i][0]!='-' ) b
c9a0: 72 65 61 6b 3b 0a 20 20 20 20 7a 20 3d 20 61 72  reak;.    z = ar
c9b0: 67 76 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 7a  gv[i];.    if( z
c9c0: 5b 30 5d 3d 3d 27 2d 27 20 26 26 20 7a 5b 31 5d  [0]=='-' && z[1]
c9d0: 3d 3d 27 2d 27 20 29 20 7a 2b 2b 3b 0a 20 20 20  =='-' ) z++;.   
c9e0: 20 69 66 28 20 73 74 72 63 6d 70 28 61 72 67 76   if( strcmp(argv
c9f0: 5b 69 5d 2c 22 2d 73 65 70 61 72 61 74 6f 72 22  [i],"-separator"
ca00: 29 3d 3d 30 20 7c 7c 20 73 74 72 63 6d 70 28 61  )==0 || strcmp(a
ca10: 72 67 76 5b 69 5d 2c 22 2d 6e 75 6c 6c 76 61 6c  rgv[i],"-nullval
ca20: 75 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  ue")==0 ){.     
ca30: 20 69 2b 2b 3b 0a 20 20 20 20 7d 65 6c 73 65 20   i++;.    }else 
ca40: 69 66 28 20 73 74 72 63 6d 70 28 61 72 67 76 5b  if( strcmp(argv[
ca50: 69 5d 2c 22 2d 69 6e 69 74 22 29 3d 3d 30 20 29  i],"-init")==0 )
ca60: 7b 0a 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20  {.      i++;.   
ca70: 20 20 20 7a 49 6e 69 74 46 69 6c 65 20 3d 20 61     zInitFile = a
ca80: 72 67 76 5b 69 5d 3b 0a 20 20 20 20 7d 0a 20 20  rgv[i];.    }.  
ca90: 7d 0a 20 20 69 66 28 20 69 3c 61 72 67 63 20 29  }.  if( i<argc )
caa0: 7b 0a 20 20 20 20 64 61 74 61 2e 7a 44 62 46 69  {.    data.zDbFi
cab0: 6c 65 6e 61 6d 65 20 3d 20 61 72 67 76 5b 69 2b  lename = argv[i+
cac0: 2b 5d 3b 0a 20 20 7d 65 6c 73 65 7b 0a 23 69 66  +];.  }else{.#if
cad0: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  ndef SQLITE_OMIT
cae0: 5f 4d 45 4d 4f 52 59 44 42 0a 20 20 20 20 64 61  _MEMORYDB.    da
caf0: 74 61 2e 7a 44 62 46 69 6c 65 6e 61 6d 65 20 3d  ta.zDbFilename =
cb00: 20 22 3a 6d 65 6d 6f 72 79 3a 22 3b 0a 23 65 6c   ":memory:";.#el
cb10: 73 65 0a 20 20 20 20 64 61 74 61 2e 7a 44 62 46  se.    data.zDbF
cb20: 69 6c 65 6e 61 6d 65 20 3d 20 30 3b 0a 23 65 6e  ilename = 0;.#en
cb30: 64 69 66 0a 20 20 7d 0a 20 20 69 66 28 20 69 3c  dif.  }.  if( i<
cb40: 61 72 67 63 20 29 7b 0a 20 20 20 20 7a 46 69 72  argc ){.    zFir
cb50: 73 74 43 6d 64 20 3d 20 61 72 67 76 5b 69 2b 2b  stCmd = argv[i++
cb60: 5d 3b 0a 20 20 7d 0a 20 20 64 61 74 61 2e 6f 75  ];.  }.  data.ou
cb70: 74 20 3d 20 73 74 64 6f 75 74 3b 0a 0a 23 69 66  t = stdout;..#if
cb80: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
cb90: 4d 45 4d 4f 52 59 44 42 0a 20 20 69 66 28 20 64  MEMORYDB.  if( d
cba0: 61 74 61 2e 7a 44 62 46 69 6c 65 6e 61 6d 65 3d  ata.zDbFilename=
cbb0: 3d 30 20 29 7b 0a 20 20 20 20 66 70 72 69 6e 74  =0 ){.    fprint
cbc0: 66 28 73 74 64 65 72 72 2c 22 25 73 3a 20 6e 6f  f(stderr,"%s: no
cbd0: 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 6e 61   database filena
cbe0: 6d 65 20 73 70 65 63 69 66 69 65 64 5c 6e 22 2c  me specified\n",
cbf0: 20 61 72 67 76 5b 30 5d 29 3b 0a 20 20 20 20 65   argv[0]);.    e
cc00: 78 69 74 28 31 29 3b 0a 20 20 7d 0a 23 65 6e 64  xit(1);.  }.#end
cc10: 69 66 0a 0a 20 20 2f 2a 20 47 6f 20 61 68 65 61  if..  /* Go ahea
cc20: 64 20 61 6e 64 20 6f 70 65 6e 20 74 68 65 20 64  d and open the d
cc30: 61 74 61 62 61 73 65 20 66 69 6c 65 20 69 66 20  atabase file if 
cc40: 69 74 20 61 6c 72 65 61 64 79 20 65 78 69 73 74  it already exist
cc50: 73 2e 20 20 49 66 20 74 68 65 0a 20 20 2a 2a 20  s.  If the.  ** 
cc60: 66 69 6c 65 20 64 6f 65 73 20 6e 6f 74 20 65 78  file does not ex
cc70: 69 73 74 2c 20 64 65 6c 61 79 20 6f 70 65 6e 69  ist, delay openi
cc80: 6e 67 20 69 74 2e 20 20 54 68 69 73 20 70 72 65  ng it.  This pre
cc90: 76 65 6e 74 73 20 65 6d 70 74 79 20 64 61 74 61  vents empty data
cca0: 62 61 73 65 0a 20 20 2a 2a 20 66 69 6c 65 73 20  base.  ** files 
ccb0: 66 72 6f 6d 20 62 65 69 6e 67 20 63 72 65 61 74  from being creat
ccc0: 65 64 20 69 66 20 61 20 75 73 65 72 20 6d 69 73  ed if a user mis
ccd0: 74 79 70 65 73 20 74 68 65 20 64 61 74 61 62 61  types the databa
cce0: 73 65 20 6e 61 6d 65 20 61 72 67 75 6d 65 6e 74  se name argument
ccf0: 0a 20 20 2a 2a 20 74 6f 20 74 68 65 20 73 71 6c  .  ** to the sql
cd00: 69 74 65 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65  ite command-line
cd10: 20 74 6f 6f 6c 2e 0a 20 20 2a 2f 0a 20 20 69 66   tool..  */.  if
cd20: 28 20 61 63 63 65 73 73 28 64 61 74 61 2e 7a 44  ( access(data.zD
cd30: 62 46 69 6c 65 6e 61 6d 65 2c 20 30 29 3d 3d 30  bFilename, 0)==0
cd40: 20 29 7b 0a 20 20 20 20 6f 70 65 6e 5f 64 62 28   ){.    open_db(
cd50: 26 64 61 74 61 29 3b 0a 20 20 7d 0a 0a 20 20 2f  &data);.  }..  /
cd60: 2a 20 50 72 6f 63 65 73 73 20 74 68 65 20 69 6e  * Process the in
cd70: 69 74 69 61 6c 69 7a 61 74 69 6f 6e 20 66 69 6c  itialization fil
cd80: 65 20 69 66 20 74 68 65 72 65 20 69 73 20 6f 6e  e if there is on
cd90: 65 2e 20 20 49 66 20 6e 6f 20 2d 69 6e 69 74 20  e.  If no -init 
cda0: 6f 70 74 69 6f 6e 0a 20 20 2a 2a 20 69 73 20 67  option.  ** is g
cdb0: 69 76 65 6e 20 6f 6e 20 74 68 65 20 63 6f 6d 6d  iven on the comm
cdc0: 61 6e 64 20 6c 69 6e 65 2c 20 6c 6f 6f 6b 20 66  and line, look f
cdd0: 6f 72 20 61 20 66 69 6c 65 20 6e 61 6d 65 64 20  or a file named 
cde0: 7e 2f 2e 73 71 6c 69 74 65 72 63 20 61 6e 64 0a  ~/.sqliterc and.
cdf0: 20 20 2a 2a 20 74 72 79 20 74 6f 20 70 72 6f 63    ** try to proc
ce00: 65 73 73 20 69 74 2e 0a 20 20 2a 2f 0a 20 20 70  ess it..  */.  p
ce10: 72 6f 63 65 73 73 5f 73 71 6c 69 74 65 72 63 28  rocess_sqliterc(
ce20: 26 64 61 74 61 2c 7a 49 6e 69 74 46 69 6c 65 29  &data,zInitFile)
ce30: 3b 0a 0a 20 20 2f 2a 20 4d 61 6b 65 20 61 20 73  ;..  /* Make a s
ce40: 65 63 6f 6e 64 20 70 61 73 73 20 74 68 72 6f 75  econd pass throu
ce50: 67 68 20 74 68 65 20 63 6f 6d 6d 61 6e 64 2d 6c  gh the command-l
ce60: 69 6e 65 20 61 72 67 75 6d 65 6e 74 20 61 6e 64  ine argument and
ce70: 20 73 65 74 0a 20 20 2a 2a 20 6f 70 74 69 6f 6e   set.  ** option
ce80: 73 2e 20 20 54 68 69 73 20 73 65 63 6f 6e 64 20  s.  This second 
ce90: 70 61 73 73 20 69 73 20 64 65 6c 61 79 65 64 20  pass is delayed 
cea0: 75 6e 74 69 6c 20 61 66 74 65 72 20 74 68 65 20  until after the 
ceb0: 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e 0a 20  initialization. 
cec0: 20 2a 2a 20 66 69 6c 65 20 69 73 20 70 72 6f 63   ** file is proc
ced0: 65 73 73 65 64 20 73 6f 20 74 68 61 74 20 74 68  essed so that th
cee0: 65 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65 20 61  e command-line a
cef0: 72 67 75 6d 65 6e 74 73 20 77 69 6c 6c 20 6f 76  rguments will ov
cf00: 65 72 72 69 64 65 0a 20 20 2a 2a 20 73 65 74 74  erride.  ** sett
cf10: 69 6e 67 73 20 69 6e 20 74 68 65 20 69 6e 69 74  ings in the init
cf20: 69 61 6c 69 7a 61 74 69 6f 6e 20 66 69 6c 65 2e  ialization file.
cf30: 0a 20 20 2a 2f 0a 20 20 66 6f 72 28 69 3d 31 3b  .  */.  for(i=1;
cf40: 20 69 3c 61 72 67 63 20 26 26 20 61 72 67 76 5b   i<argc && argv[
cf50: 69 5d 5b 30 5d 3d 3d 27 2d 27 3b 20 69 2b 2b 29  i][0]=='-'; i++)
cf60: 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 20 3d 20  {.    char *z = 
cf70: 61 72 67 76 5b 69 5d 3b 0a 20 20 20 20 69 66 28  argv[i];.    if(
cf80: 20 7a 5b 31 5d 3d 3d 27 2d 27 20 29 7b 20 7a 2b   z[1]=='-' ){ z+
cf90: 2b 3b 20 7d 0a 20 20 20 20 69 66 28 20 73 74 72  +; }.    if( str
cfa0: 63 6d 70 28 7a 2c 22 2d 69 6e 69 74 22 29 3d 3d  cmp(z,"-init")==
cfb0: 30 20 29 7b 0a 20 20 20 20 20 20 69 2b 2b 3b 0a  0 ){.      i++;.
cfc0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74      }else if( st
cfd0: 72 63 6d 70 28 7a 2c 22 2d 68 74 6d 6c 22 29 3d  rcmp(z,"-html")=
cfe0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 64 61 74 61  =0 ){.      data
cff0: 2e 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f 48 74 6d  .mode = MODE_Htm
d000: 6c 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28  l;.    }else if(
d010: 20 73 74 72 63 6d 70 28 7a 2c 22 2d 6c 69 73 74   strcmp(z,"-list
d020: 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 64  ")==0 ){.      d
d030: 61 74 61 2e 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f  ata.mode = MODE_
d040: 4c 69 73 74 3b 0a 20 20 20 20 7d 65 6c 73 65 20  List;.    }else 
d050: 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 2d 6c  if( strcmp(z,"-l
d060: 69 6e 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20 20  ine")==0 ){.    
d070: 20 20 64 61 74 61 2e 6d 6f 64 65 20 3d 20 4d 4f    data.mode = MO
d080: 44 45 5f 4c 69 6e 65 3b 0a 20 20 20 20 7d 65 6c  DE_Line;.    }el
d090: 73 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c  se if( strcmp(z,
d0a0: 22 2d 63 6f 6c 75 6d 6e 22 29 3d 3d 30 20 29 7b  "-column")==0 ){
d0b0: 0a 20 20 20 20 20 20 64 61 74 61 2e 6d 6f 64 65  .      data.mode
d0c0: 20 3d 20 4d 4f 44 45 5f 43 6f 6c 75 6d 6e 3b 0a   = MODE_Column;.
d0d0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74      }else if( st
d0e0: 72 63 6d 70 28 7a 2c 22 2d 63 73 76 22 29 3d 3d  rcmp(z,"-csv")==
d0f0: 30 20 29 7b 0a 20 20 20 20 20 20 64 61 74 61 2e  0 ){.      data.
d100: 6d 6f 64 65 20 3d 20 4d 4f 44 45 5f 43 73 76 3b  mode = MODE_Csv;
d110: 0a 20 20 20 20 20 20 73 74 72 63 70 79 28 64 61  .      strcpy(da
d120: 74 61 2e 73 65 70 61 72 61 74 6f 72 2c 22 2c 22  ta.separator,","
d130: 29 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28  );.    }else if(
d140: 20 73 74 72 63 6d 70 28 7a 2c 22 2d 73 65 70 61   strcmp(z,"-sepa
d150: 72 61 74 6f 72 22 29 3d 3d 30 20 29 7b 0a 20 20  rator")==0 ){.  
d160: 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20 20 20 73      i++;.      s
d170: 70 72 69 6e 74 66 28 64 61 74 61 2e 73 65 70 61  printf(data.sepa
d180: 72 61 74 6f 72 2c 22 25 2e 2a 73 22 2c 28 69 6e  rator,"%.*s",(in
d190: 74 29 73 69 7a 65 6f 66 28 64 61 74 61 2e 73 65  t)sizeof(data.se
d1a0: 70 61 72 61 74 6f 72 29 2d 31 2c 61 72 67 76 5b  parator)-1,argv[
d1b0: 69 5d 29 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69  i]);.    }else i
d1c0: 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 2d 6e 75  f( strcmp(z,"-nu
d1d0: 6c 6c 76 61 6c 75 65 22 29 3d 3d 30 20 29 7b 0a  llvalue")==0 ){.
d1e0: 20 20 20 20 20 20 69 2b 2b 3b 0a 20 20 20 20 20        i++;.     
d1f0: 20 73 70 72 69 6e 74 66 28 64 61 74 61 2e 6e 75   sprintf(data.nu
d200: 6c 6c 76 61 6c 75 65 2c 22 25 2e 2a 73 22 2c 28  llvalue,"%.*s",(
d210: 69 6e 74 29 73 69 7a 65 6f 66 28 64 61 74 61 2e  int)sizeof(data.
d220: 6e 75 6c 6c 76 61 6c 75 65 29 2d 31 2c 61 72 67  nullvalue)-1,arg
d230: 76 5b 69 5d 29 3b 0a 20 20 20 20 7d 65 6c 73 65  v[i]);.    }else
d240: 20 69 66 28 20 73 74 72 63 6d 70 28 7a 2c 22 2d   if( strcmp(z,"-
d250: 68 65 61 64 65 72 22 29 3d 3d 30 20 29 7b 0a 20  header")==0 ){. 
d260: 20 20 20 20 20 64 61 74 61 2e 73 68 6f 77 48 65       data.showHe
d270: 61 64 65 72 20 3d 20 31 3b 0a 20 20 20 20 7d 65  ader = 1;.    }e
d280: 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70 28 7a  lse if( strcmp(z
d290: 2c 22 2d 6e 6f 68 65 61 64 65 72 22 29 3d 3d 30  ,"-noheader")==0
d2a0: 20 29 7b 0a 20 20 20 20 20 20 64 61 74 61 2e 73   ){.      data.s
d2b0: 68 6f 77 48 65 61 64 65 72 20 3d 20 30 3b 0a 20  howHeader = 0;. 
d2c0: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72     }else if( str
d2d0: 63 6d 70 28 7a 2c 22 2d 65 63 68 6f 22 29 3d 3d  cmp(z,"-echo")==
d2e0: 30 20 29 7b 0a 20 20 20 20 20 20 64 61 74 61 2e  0 ){.      data.
d2f0: 65 63 68 6f 4f 6e 20 3d 20 31 3b 0a 20 20 20 20  echoOn = 1;.    
d300: 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70  }else if( strcmp
d310: 28 7a 2c 22 2d 62 61 69 6c 22 29 3d 3d 30 20 29  (z,"-bail")==0 )
d320: 7b 0a 20 20 20 20 20 20 62 61 69 6c 5f 6f 6e 5f  {.      bail_on_
d330: 65 72 72 6f 72 20 3d 20 31 3b 0a 20 20 20 20 7d  error = 1;.    }
d340: 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d 70 28  else if( strcmp(
d350: 7a 2c 22 2d 76 65 72 73 69 6f 6e 22 29 3d 3d 30  z,"-version")==0
d360: 20 29 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66   ){.      printf
d370: 28 22 25 73 5c 6e 22 2c 20 73 71 6c 69 74 65 33  ("%s\n", sqlite3
d380: 5f 6c 69 62 76 65 72 73 69 6f 6e 28 29 29 3b 0a  _libversion());.
d390: 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a        return 0;.
d3a0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 74      }else if( st
d3b0: 72 63 6d 70 28 7a 2c 22 2d 69 6e 74 65 72 61 63  rcmp(z,"-interac
d3c0: 74 69 76 65 22 29 3d 3d 30 20 29 7b 0a 20 20 20  tive")==0 ){.   
d3d0: 20 20 20 73 74 64 69 6e 5f 69 73 5f 69 6e 74 65     stdin_is_inte
d3e0: 72 61 63 74 69 76 65 20 3d 20 31 3b 0a 20 20 20  ractive = 1;.   
d3f0: 20 7d 65 6c 73 65 20 69 66 28 20 73 74 72 63 6d   }else if( strcm
d400: 70 28 7a 2c 22 2d 62 61 74 63 68 22 29 3d 3d 30  p(z,"-batch")==0
d410: 20 29 7b 0a 20 20 20 20 20 20 73 74 64 69 6e 5f   ){.      stdin_
d420: 69 73 5f 69 6e 74 65 72 61 63 74 69 76 65 20 3d  is_interactive =
d430: 20 30 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66   0;.    }else if
d440: 28 20 73 74 72 63 6d 70 28 7a 2c 22 2d 68 65 6c  ( strcmp(z,"-hel
d450: 70 22 29 3d 3d 30 20 7c 7c 20 73 74 72 63 6d 70  p")==0 || strcmp
d460: 28 7a 2c 20 22 2d 2d 68 65 6c 70 22 29 3d 3d 30  (z, "--help")==0
d470: 20 29 7b 0a 20 20 20 20 20 20 75 73 61 67 65 28   ){.      usage(
d480: 31 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20  1);.    }else{. 
d490: 20 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64       fprintf(std
d4a0: 65 72 72 2c 22 25 73 3a 20 75 6e 6b 6e 6f 77 6e  err,"%s: unknown
d4b0: 20 6f 70 74 69 6f 6e 3a 20 25 73 5c 6e 22 2c 20   option: %s\n", 
d4c0: 41 72 67 76 30 2c 20 7a 29 3b 0a 20 20 20 20 20  Argv0, z);.     
d4d0: 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72 2c   fprintf(stderr,
d4e0: 22 55 73 65 20 2d 68 65 6c 70 20 66 6f 72 20 61  "Use -help for a
d4f0: 20 6c 69 73 74 20 6f 66 20 6f 70 74 69 6f 6e 73   list of options
d500: 2e 5c 6e 22 29 3b 0a 20 20 20 20 20 20 72 65 74  .\n");.      ret
d510: 75 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d  urn 1;.    }.  }
d520: 0a 0a 20 20 69 66 28 20 7a 46 69 72 73 74 43 6d  ..  if( zFirstCm
d530: 64 20 29 7b 0a 20 20 20 20 2f 2a 20 52 75 6e 20  d ){.    /* Run 
d540: 6a 75 73 74 20 74 68 65 20 63 6f 6d 6d 61 6e 64  just the command
d550: 20 74 68 61 74 20 66 6f 6c 6c 6f 77 73 20 74 68   that follows th
d560: 65 20 64 61 74 61 62 61 73 65 20 6e 61 6d 65 0a  e database name.
d570: 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 7a      */.    if( z
d580: 46 69 72 73 74 43 6d 64 5b 30 5d 3d 3d 27 2e 27  FirstCmd[0]=='.'
d590: 20 29 7b 0a 20 20 20 20 20 20 64 6f 5f 6d 65 74   ){.      do_met
d5a0: 61 5f 63 6f 6d 6d 61 6e 64 28 7a 46 69 72 73 74  a_command(zFirst
d5b0: 43 6d 64 2c 20 26 64 61 74 61 29 3b 0a 20 20 20  Cmd, &data);.   
d5c0: 20 20 20 65 78 69 74 28 30 29 3b 0a 20 20 20 20     exit(0);.    
d5d0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74  }else{.      int
d5e0: 20 72 63 3b 0a 20 20 20 20 20 20 6f 70 65 6e 5f   rc;.      open_
d5f0: 64 62 28 26 64 61 74 61 29 3b 0a 20 20 20 20 20  db(&data);.     
d600: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 65 78   rc = sqlite3_ex
d610: 65 63 28 64 61 74 61 2e 64 62 2c 20 7a 46 69 72  ec(data.db, zFir
d620: 73 74 43 6d 64 2c 20 63 61 6c 6c 62 61 63 6b 2c  stCmd, callback,
d630: 20 26 64 61 74 61 2c 20 26 7a 45 72 72 4d 73 67   &data, &zErrMsg
d640: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 72 63 21  );.      if( rc!
d650: 3d 30 20 26 26 20 7a 45 72 72 4d 73 67 21 3d 30  =0 && zErrMsg!=0
d660: 20 29 7b 0a 20 20 20 20 20 20 20 20 66 70 72 69   ){.        fpri
d670: 6e 74 66 28 73 74 64 65 72 72 2c 22 53 51 4c 20  ntf(stderr,"SQL 
d680: 65 72 72 6f 72 3a 20 25 73 5c 6e 22 2c 20 7a 45  error: %s\n", zE
d690: 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 20 20  rrMsg);.        
d6a0: 65 78 69 74 28 31 29 3b 0a 20 20 20 20 20 20 7d  exit(1);.      }
d6b0: 0a 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 7b 0a  .    }.  }else{.
d6c0: 20 20 20 20 2f 2a 20 52 75 6e 20 63 6f 6d 6d 61      /* Run comma
d6d0: 6e 64 73 20 72 65 63 65 69 76 65 64 20 66 72 6f  nds received fro
d6e0: 6d 20 73 74 61 6e 64 61 72 64 20 69 6e 70 75 74  m standard input
d6f0: 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20  .    */.    if( 
d700: 73 74 64 69 6e 5f 69 73 5f 69 6e 74 65 72 61 63  stdin_is_interac
d710: 74 69 76 65 20 29 7b 0a 20 20 20 20 20 20 63 68  tive ){.      ch
d720: 61 72 20 2a 7a 48 6f 6d 65 3b 0a 20 20 20 20 20  ar *zHome;.     
d730: 20 63 68 61 72 20 2a 7a 48 69 73 74 6f 72 79 20   char *zHistory 
d740: 3d 20 30 3b 0a 20 20 20 20 20 20 70 72 69 6e 74  = 0;.      print
d750: 66 28 0a 20 20 20 20 20 20 20 20 22 53 51 4c 69  f(.        "SQLi
d760: 74 65 20 76 65 72 73 69 6f 6e 20 25 73 5c 6e 22  te version %s\n"
d770: 0a 20 20 20 20 20 20 20 20 22 45 6e 74 65 72 20  .        "Enter 
d780: 5c 22 2e 68 65 6c 70 5c 22 20 66 6f 72 20 69 6e  \".help\" for in
d790: 73 74 72 75 63 74 69 6f 6e 73 5c 6e 22 2c 0a 20  structions\n",. 
d7a0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 6c         sqlite3_l
d7b0: 69 62 76 65 72 73 69 6f 6e 28 29 0a 20 20 20 20  ibversion().    
d7c0: 20 20 29 3b 0a 20 20 20 20 20 20 7a 48 6f 6d 65    );.      zHome
d7d0: 20 3d 20 66 69 6e 64 5f 68 6f 6d 65 5f 64 69 72   = find_home_dir
d7e0: 28 29 3b 0a 20 20 20 20 20 20 69 66 28 20 7a 48  ();.      if( zH
d7f0: 6f 6d 65 20 26 26 20 28 7a 48 69 73 74 6f 72 79  ome && (zHistory
d800: 20 3d 20 6d 61 6c 6c 6f 63 28 73 74 72 6c 65 6e   = malloc(strlen
d810: 28 7a 48 6f 6d 65 29 2b 32 30 29 29 21 3d 30 20  (zHome)+20))!=0 
d820: 29 7b 0a 20 20 20 20 20 20 20 20 73 70 72 69 6e  ){.        sprin
d830: 74 66 28 7a 48 69 73 74 6f 72 79 2c 22 25 73 2f  tf(zHistory,"%s/
d840: 2e 73 71 6c 69 74 65 5f 68 69 73 74 6f 72 79 22  .sqlite_history"
d850: 2c 20 7a 48 6f 6d 65 29 3b 0a 20 20 20 20 20 20  , zHome);.      
d860: 7d 0a 23 69 66 20 64 65 66 69 6e 65 64 28 48 41  }.#if defined(HA
d870: 56 45 5f 52 45 41 44 4c 49 4e 45 29 20 26 26 20  VE_READLINE) && 
d880: 48 41 56 45 5f 52 45 41 44 4c 49 4e 45 3d 3d 31  HAVE_READLINE==1
d890: 0a 20 20 20 20 20 20 69 66 28 20 7a 48 69 73 74  .      if( zHist
d8a0: 6f 72 79 20 29 20 72 65 61 64 5f 68 69 73 74 6f  ory ) read_histo
d8b0: 72 79 28 7a 48 69 73 74 6f 72 79 29 3b 0a 23 65  ry(zHistory);.#e
d8c0: 6e 64 69 66 0a 20 20 20 20 20 20 72 63 20 3d 20  ndif.      rc = 
d8d0: 70 72 6f 63 65 73 73 5f 69 6e 70 75 74 28 26 64  process_input(&d
d8e0: 61 74 61 2c 20 30 29 3b 0a 20 20 20 20 20 20 69  ata, 0);.      i
d8f0: 66 28 20 7a 48 69 73 74 6f 72 79 20 29 7b 0a 20  f( zHistory ){. 
d900: 20 20 20 20 20 20 20 73 74 69 66 6c 65 5f 68 69         stifle_hi
d910: 73 74 6f 72 79 28 31 30 30 29 3b 0a 20 20 20 20  story(100);.    
d920: 20 20 20 20 77 72 69 74 65 5f 68 69 73 74 6f 72      write_histor
d930: 79 28 7a 48 69 73 74 6f 72 79 29 3b 0a 20 20 20  y(zHistory);.   
d940: 20 20 20 20 20 66 72 65 65 28 7a 48 69 73 74 6f       free(zHisto
d950: 72 79 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  ry);.      }.   
d960: 20 20 20 66 72 65 65 28 7a 48 6f 6d 65 29 3b 0a     free(zHome);.
d970: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
d980: 20 72 63 20 3d 20 70 72 6f 63 65 73 73 5f 69 6e   rc = process_in
d990: 70 75 74 28 26 64 61 74 61 2c 20 73 74 64 69 6e  put(&data, stdin
d9a0: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 73  );.    }.  }.  s
d9b0: 65 74 5f 74 61 62 6c 65 5f 6e 61 6d 65 28 26 64  et_table_name(&d
d9c0: 61 74 61 2c 20 30 29 3b 0a 20 20 69 66 28 20 64  ata, 0);.  if( d
d9d0: 62 20 29 7b 0a 20 20 20 20 69 66 28 20 73 71 6c  b ){.    if( sql
d9e0: 69 74 65 33 5f 63 6c 6f 73 65 28 64 62 29 21 3d  ite3_close(db)!=
d9f0: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
da00: 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72     fprintf(stder
da10: 72 2c 22 65 72 72 6f 72 20 63 6c 6f 73 69 6e 67  r,"error closing
da20: 20 64 61 74 61 62 61 73 65 3a 20 25 73 5c 6e 22   database: %s\n"
da30: 2c 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67  , sqlite3_errmsg
da40: 28 64 62 29 29 3b 0a 20 20 20 20 7d 0a 20 20 7d  (db));.    }.  }
da50: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.