/ Hex Artifact Content
Login

Artifact bcc939e9fbcf702f9e5fce73c2563b42d04a663c:


0000: 23 21 2f 62 69 6e 2f 73 68 0a 23 0a 23 20 54 68  #!/bin/sh.#.# Th
0010: 69 73 20 73 63 72 69 70 74 20 69 73 20 75 73 65  is script is use
0020: 64 20 74 6f 20 63 6f 6d 70 69 6c 65 20 53 51 4c  d to compile SQL
0030: 69 74 65 20 61 6e 64 20 61 6c 6c 20 69 74 73 20  ite and all its 
0040: 64 6f 63 75 6d 65 6e 74 61 74 69 6f 6e 20 61 6e  documentation an
0050: 64 0a 23 20 73 68 69 70 20 65 76 65 72 79 74 68  d.# ship everyth
0060: 69 6e 67 20 75 70 20 74 6f 20 74 68 65 20 53 51  ing up to the SQ
0070: 4c 69 74 65 20 77 65 62 73 69 74 65 2e 20 20 54  Lite website.  T
0080: 68 69 73 20 73 63 72 69 70 74 20 77 69 6c 6c 20  his script will 
0090: 6f 6e 6c 79 20 77 6f 72 6b 0a 23 20 6f 6e 20 74  only work.# on t
00a0: 68 65 20 73 79 73 74 65 6d 20 22 7a 61 64 6f 6b  he system "zadok
00b0: 22 20 61 74 20 74 68 65 20 48 77 61 63 69 20 6f  " at the Hwaci o
00c0: 66 66 69 63 65 73 2e 20 20 42 75 74 20 6f 74 68  ffices.  But oth
00d0: 65 72 73 20 6d 69 67 68 74 20 66 69 6e 64 0a 23  ers might find.#
00e0: 20 74 68 65 20 73 63 72 69 70 74 20 75 73 65 66   the script usef
00f0: 75 6c 20 61 73 20 61 6e 20 65 78 61 6d 70 6c 65  ul as an example
0100: 2e 0a 23 0a 0a 23 20 53 65 74 20 73 72 63 64 69  ..#..# Set srcdi
0110: 72 20 74 6f 20 74 68 65 20 6e 61 6d 65 20 6f 66  r to the name of
0120: 20 74 68 65 20 64 69 72 65 63 74 6f 72 79 20 74   the directory t
0130: 68 61 74 20 63 6f 6e 74 61 69 6e 73 20 74 68 65  hat contains the
0140: 20 70 75 62 6c 69 73 68 2e 73 68 0a 23 20 73 63   publish.sh.# sc
0150: 72 69 70 74 2e 0a 23 0a 73 72 63 64 69 72 3d 60  ript..#.srcdir=`
0160: 65 63 68 6f 20 22 24 30 22 20 7c 20 73 65 64 20  echo "$0" | sed 
0170: 27 73 25 5c 28 5e 2e 2a 5c 29 2f 5b 5e 2f 5d 5b  's%\(^.*\)/[^/][
0180: 5e 2f 5d 2a 24 25 5c 31 25 27 60 0a 0a 23 20 47  ^/]*$%\1%'`..# G
0190: 65 74 20 74 68 65 20 6d 61 6b 65 66 69 6c 65 2e  et the makefile.
01a0: 0a 23 0a 63 70 20 24 73 72 63 64 69 72 2f 4d 61  .#.cp $srcdir/Ma
01b0: 6b 65 66 69 6c 65 2e 6c 69 6e 75 78 2d 67 63 63  kefile.linux-gcc
01c0: 20 2e 2f 4d 61 6b 65 66 69 6c 65 0a 63 68 6d 6f   ./Makefile.chmo
01d0: 64 20 2b 78 20 24 73 72 63 64 69 72 2f 69 6e 73  d +x $srcdir/ins
01e0: 74 61 6c 6c 2d 73 68 0a 0a 23 20 43 6c 65 61 72  tall-sh..# Clear
01f0: 20 6f 75 74 20 74 68 65 20 62 75 69 6c 64 20 64   out the build d
0200: 69 72 65 63 74 6f 72 79 20 22 64 6f 63 22 0a 23  irectory "doc".#
0210: 0a 23 72 6d 20 2d 72 66 20 64 6f 63 0a 23 6d 61  .#rm -rf doc.#ma
0220: 6b 65 20 64 6f 63 0a 0a 23 20 47 65 74 20 74 68  ke doc..# Get th
0230: 65 20 63 75 72 72 65 6e 74 20 76 65 72 73 69 6f  e current versio
0240: 6e 20 6e 75 6d 62 65 72 20 2d 20 6e 65 65 64 65  n number - neede
0250: 64 20 74 6f 20 68 65 6c 70 20 62 75 69 6c 64 20  d to help build 
0260: 66 69 6c 65 6e 61 6d 65 73 0a 23 0a 56 45 52 53  filenames.#.VERS
0270: 3d 60 63 61 74 20 24 73 72 63 64 69 72 2f 56 45  =`cat $srcdir/VE
0280: 52 53 49 4f 4e 60 0a 56 45 52 53 57 3d 60 73 65  RSION`.VERSW=`se
0290: 64 20 27 73 2f 5c 2e 2f 5f 2f 67 27 20 24 73 72  d 's/\./_/g' $sr
02a0: 63 64 69 72 2f 56 45 52 53 49 4f 4e 60 0a 0a 23  cdir/VERSION`..#
02b0: 20 53 74 61 72 74 20 62 79 20 62 75 69 6c 64 69   Start by buildi
02c0: 6e 67 20 61 6e 20 73 71 6c 69 74 65 20 73 68 65  ng an sqlite she
02d0: 6c 6c 20 66 6f 72 20 6c 69 6e 75 78 2e 0a 23 0a  ll for linux..#.
02e0: 6d 61 6b 65 20 63 6c 65 61 6e 0a 6d 61 6b 65 20  make clean.make 
02f0: 73 71 6c 69 74 65 0a 73 74 72 69 70 20 73 71 6c  sqlite.strip sql
0300: 69 74 65 0a 6d 76 20 73 71 6c 69 74 65 20 73 71  ite.mv sqlite sq
0310: 6c 69 74 65 2d 24 56 45 52 53 2e 62 69 6e 0a 72  lite-$VERS.bin.r
0320: 6d 20 2d 66 20 73 71 6c 69 74 65 2e 62 69 6e 2e  m -f sqlite.bin.
0330: 67 7a 0a 67 7a 69 70 20 73 71 6c 69 74 65 2d 24  gz.gzip sqlite-$
0340: 56 45 52 53 2e 62 69 6e 0a 6d 76 20 73 71 6c 69  VERS.bin.mv sqli
0350: 74 65 2d 24 56 45 52 53 2e 62 69 6e 2e 67 7a 20  te-$VERS.bin.gz 
0360: 64 6f 63 0a 0a 23 20 42 75 69 6c 64 20 74 68 65  doc..# Build the
0370: 20 74 63 6c 73 71 6c 69 74 65 2e 73 6f 20 73 68   tclsqlite.so sh
0380: 61 72 65 64 20 6c 69 62 72 61 72 79 20 66 6f 72  ared library for
0390: 20 69 6d 70 6f 72 74 20 69 6e 74 6f 20 74 63 6c   import into tcl
03a0: 73 68 20 6f 72 20 77 69 73 68 0a 23 20 75 6e 64  sh or wish.# und
03b0: 65 72 20 4c 69 6e 75 78 0a 23 0a 6d 61 6b 65 20  er Linux.#.make 
03c0: 74 61 72 67 65 74 5f 73 6f 75 72 63 65 0a 72 6d  target_source.rm
03d0: 20 2d 66 20 64 6f 63 2f 73 71 6c 69 74 65 2d 73   -f doc/sqlite-s
03e0: 6f 75 72 63 65 2d 24 56 45 52 53 57 2e 7a 69 70  ource-$VERSW.zip
03f0: 0a 63 64 20 74 73 72 63 0a 7a 69 70 20 2e 2e 2f  .cd tsrc.zip ../
0400: 64 6f 63 2f 73 71 6c 69 74 65 2d 73 6f 75 72 63  doc/sqlite-sourc
0410: 65 2d 24 56 45 52 53 57 2e 7a 69 70 20 2a 0a 72  e-$VERSW.zip *.r
0420: 6d 20 73 68 65 6c 6c 2e 63 0a 54 43 4c 44 49 52  m shell.c.TCLDIR
0430: 3d 2f 68 6f 6d 65 2f 64 72 68 2f 74 63 6c 74 6b  =/home/drh/tcltk
0440: 2f 38 2e 32 6c 69 6e 75 78 0a 54 43 4c 53 54 55  /8.2linux.TCLSTU
0450: 42 4c 49 42 3d 24 54 43 4c 44 49 52 2f 6c 69 62  BLIB=$TCLDIR/lib
0460: 74 63 6c 73 74 75 62 38 2e 32 67 2e 61 0a 4f 50  tclstub8.2g.a.OP
0470: 54 53 3d 27 2d 44 55 53 45 5f 54 43 4c 5f 53 54  TS='-DUSE_TCL_ST
0480: 55 42 53 3d 31 20 2d 44 4e 44 45 42 55 47 3d 31  UBS=1 -DNDEBUG=1
0490: 27 0a 67 63 63 20 2d 66 50 49 43 20 24 4f 50 54  '.gcc -fPIC $OPT
04a0: 53 20 2d 4f 32 20 2d 49 2e 20 2d 49 24 54 43 4c  S -O2 -I. -I$TCL
04b0: 44 49 52 20 2d 73 68 61 72 65 64 20 2a 2e 63 20  DIR -shared *.c 
04c0: 24 54 43 4c 53 54 55 42 4c 49 42 20 2d 6f 20 74  $TCLSTUBLIB -o t
04d0: 63 6c 73 71 6c 69 74 65 2e 73 6f 0a 73 74 72 69  clsqlite.so.stri
04e0: 70 20 74 63 6c 73 71 6c 69 74 65 2e 73 6f 0a 6d  p tclsqlite.so.m
04f0: 76 20 74 63 6c 73 71 6c 69 74 65 2e 73 6f 20 74  v tclsqlite.so t
0500: 63 6c 73 71 6c 69 74 65 2d 24 56 45 52 53 2e 73  clsqlite-$VERS.s
0510: 6f 0a 67 7a 69 70 20 74 63 6c 73 71 6c 69 74 65  o.gzip tclsqlite
0520: 2d 24 56 45 52 53 2e 73 6f 0a 6d 76 20 74 63 6c  -$VERS.so.mv tcl
0530: 73 71 6c 69 74 65 2d 24 56 45 52 53 2e 73 6f 2e  sqlite-$VERS.so.
0540: 67 7a 20 2e 2e 2f 64 6f 63 0a 72 6d 20 74 63 6c  gz ../doc.rm tcl
0550: 73 71 6c 69 74 65 2e 63 0a 67 63 63 20 2d 66 50  sqlite.c.gcc -fP
0560: 49 43 20 2d 44 4e 44 45 42 55 47 3d 31 20 2d 4f  IC -DNDEBUG=1 -O
0570: 32 20 2d 49 2e 20 2d 73 68 61 72 65 64 20 2a 2e  2 -I. -shared *.
0580: 63 20 2d 6f 20 73 71 6c 69 74 65 2e 73 6f 0a 73  c -o sqlite.so.s
0590: 74 72 69 70 20 73 71 6c 69 74 65 2e 73 6f 0a 6d  trip sqlite.so.m
05a0: 76 20 73 71 6c 69 74 65 2e 73 6f 20 73 71 6c 69  v sqlite.so sqli
05b0: 74 65 2d 24 56 45 52 53 2e 73 6f 0a 67 7a 69 70  te-$VERS.so.gzip
05c0: 20 73 71 6c 69 74 65 2d 24 56 45 52 53 2e 73 6f   sqlite-$VERS.so
05d0: 0a 6d 76 20 73 71 6c 69 74 65 2d 24 56 45 52 53  .mv sqlite-$VERS
05e0: 2e 73 6f 2e 67 7a 20 2e 2e 2f 64 6f 63 0a 63 64  .so.gz ../doc.cd
05f0: 20 2e 2e 0a 0a 23 20 42 75 69 6c 64 20 74 68 65   ....# Build the
0600: 20 74 63 6c 73 71 6c 69 74 65 2e 64 6c 6c 20 73   tclsqlite.dll s
0610: 68 61 72 65 64 20 6c 69 62 72 61 72 79 20 74 68  hared library th
0620: 61 74 20 63 61 6e 20 62 65 20 69 6d 70 6f 72 74  at can be import
0630: 65 64 20 69 6e 74 6f 20 74 63 6c 73 68 0a 23 20  ed into tclsh.# 
0640: 6f 72 20 77 69 73 68 20 6f 6e 20 77 69 6e 64 6f  or wish on windo
0650: 77 73 2e 0a 23 0a 6d 61 6b 65 20 74 61 72 67 65  ws..#.make targe
0660: 74 5f 73 6f 75 72 63 65 0a 63 64 20 74 73 72 63  t_source.cd tsrc
0670: 0a 72 6d 20 73 68 65 6c 6c 2e 63 0a 54 43 4c 44  .rm shell.c.TCLD
0680: 49 52 3d 2f 68 6f 6d 65 2f 64 72 68 2f 74 63 6c  IR=/home/drh/tcl
0690: 74 6b 2f 38 2e 32 77 69 6e 0a 54 43 4c 53 54 55  tk/8.2win.TCLSTU
06a0: 42 4c 49 42 3d 24 54 43 4c 44 49 52 2f 74 63 6c  BLIB=$TCLDIR/tcl
06b0: 73 74 75 62 38 32 2e 61 0a 50 41 54 48 3d 24 50  stub82.a.PATH=$P
06c0: 41 54 48 3a 2f 6f 70 74 2f 6d 69 6e 67 77 2f 62  ATH:/opt/mingw/b
06d0: 69 6e 0a 4f 50 54 53 3d 27 2d 44 55 53 45 5f 54  in.OPTS='-DUSE_T
06e0: 43 4c 5f 53 54 55 42 53 3d 31 20 2d 44 4e 44 45  CL_STUBS=1 -DNDE
06f0: 42 55 47 3d 31 20 2d 44 54 48 52 45 41 44 53 41  BUG=1 -DTHREADSA
0700: 46 45 3d 31 27 0a 43 43 3d 22 69 33 38 36 2d 6d  FE=1'.CC="i386-m
0710: 69 6e 67 77 33 32 6d 73 76 63 2d 67 63 63 20 2d  ingw32msvc-gcc -
0720: 4f 32 20 24 4f 50 54 53 20 2d 49 2e 20 2d 49 24  O2 $OPTS -I. -I$
0730: 54 43 4c 44 49 52 22 0a 72 6d 20 73 68 65 6c 6c  TCLDIR".rm shell
0740: 2e 63 0a 66 6f 72 20 69 20 69 6e 20 2a 2e 63 3b  .c.for i in *.c;
0750: 20 64 6f 0a 20 20 43 4d 44 3d 22 24 43 43 20 2d   do.  CMD="$CC -
0760: 63 20 24 69 22 0a 20 20 65 63 68 6f 20 24 43 4d  c $i".  echo $CM
0770: 44 0a 20 20 24 43 4d 44 0a 64 6f 6e 65 0a 65 63  D.  $CMD.done.ec
0780: 68 6f 20 27 45 58 50 4f 52 54 53 27 20 3e 74 63  ho 'EXPORTS' >tc
0790: 6c 73 71 6c 69 74 65 2e 64 65 66 0a 65 63 68 6f  lsqlite.def.echo
07a0: 20 27 54 63 6c 73 71 6c 69 74 65 5f 49 6e 69 74   'Tclsqlite_Init
07b0: 27 20 3e 3e 74 63 6c 73 71 6c 69 74 65 2e 64 65  ' >>tclsqlite.de
07c0: 66 0a 65 63 68 6f 20 27 53 71 6c 69 74 65 5f 49  f.echo 'Sqlite_I
07d0: 6e 69 74 27 20 3e 3e 74 63 6c 73 71 6c 69 74 65  nit' >>tclsqlite
07e0: 2e 64 65 66 0a 69 33 38 36 2d 6d 69 6e 67 77 33  .def.i386-mingw3
07f0: 32 6d 73 76 63 2d 64 6c 6c 77 72 61 70 20 5c 0a  2msvc-dllwrap \.
0800: 20 20 20 20 20 2d 2d 64 65 66 20 74 63 6c 73 71       --def tclsq
0810: 6c 69 74 65 2e 64 65 66 20 2d 76 20 2d 2d 65 78  lite.def -v --ex
0820: 70 6f 72 74 2d 61 6c 6c 20 5c 0a 20 20 20 20 20  port-all \.     
0830: 2d 2d 64 72 69 76 65 72 2d 6e 61 6d 65 20 69 33  --driver-name i3
0840: 38 36 2d 6d 69 6e 67 77 33 32 6d 73 76 63 2d 67  86-mingw32msvc-g
0850: 63 63 20 5c 0a 20 20 20 20 20 2d 2d 64 6c 6c 74  cc \.     --dllt
0860: 6f 6f 6c 2d 6e 61 6d 65 20 69 33 38 36 2d 6d 69  ool-name i386-mi
0870: 6e 67 77 33 32 6d 73 76 63 2d 64 6c 6c 74 6f 6f  ngw32msvc-dlltoo
0880: 6c 20 5c 0a 20 20 20 20 20 2d 2d 61 73 20 69 33  l \.     --as i3
0890: 38 36 2d 6d 69 6e 67 77 33 32 6d 73 76 63 2d 61  86-mingw32msvc-a
08a0: 73 20 5c 0a 20 20 20 20 20 2d 2d 74 61 72 67 65  s \.     --targe
08b0: 74 20 69 33 38 36 2d 6d 69 6e 67 77 33 32 20 5c  t i386-mingw32 \
08c0: 0a 20 20 20 20 20 2d 64 6c 6c 6e 61 6d 65 20 74  .     -dllname t
08d0: 63 6c 73 71 6c 69 74 65 2e 64 6c 6c 20 2d 6c 6d  clsqlite.dll -lm
08e0: 73 76 63 72 74 20 2a 2e 6f 20 24 54 43 4c 53 54  svcrt *.o $TCLST
08f0: 55 42 4c 49 42 0a 69 33 38 36 2d 6d 69 6e 67 77  UBLIB.i386-mingw
0900: 33 32 6d 73 76 63 2d 73 74 72 69 70 20 74 63 6c  32msvc-strip tcl
0910: 73 71 6c 69 74 65 2e 64 6c 6c 0a 23 6d 76 20 74  sqlite.dll.#mv t
0920: 63 6c 73 71 6c 69 74 65 2e 64 6c 6c 20 2e 2e 2f  clsqlite.dll ../
0930: 74 63 6c 73 71 6c 69 74 65 2d 24 56 45 52 53 57  tclsqlite-$VERSW
0940: 2e 64 6c 6c 0a 72 6d 20 74 63 6c 73 71 6c 69 74  .dll.rm tclsqlit
0950: 65 2e 6f 0a 63 61 74 20 3e 73 71 6c 69 74 65 2e  e.o.cat >sqlite.
0960: 64 65 66 20 3c 3c 5c 45 4e 44 5f 4f 46 5f 46 49  def <<\END_OF_FI
0970: 4c 45 0a 45 58 50 4f 52 54 53 0a 73 71 6c 69 74  LE.EXPORTS.sqlit
0980: 65 5f 6f 70 65 6e 0a 73 71 6c 69 74 65 5f 63 6c  e_open.sqlite_cl
0990: 6f 73 65 0a 73 71 6c 69 74 65 5f 65 78 65 63 0a  ose.sqlite_exec.
09a0: 73 71 6c 69 74 65 5f 6c 61 73 74 5f 69 6e 73 65  sqlite_last_inse
09b0: 72 74 5f 72 6f 77 69 64 0a 73 71 6c 69 74 65 5f  rt_rowid.sqlite_
09c0: 65 72 72 6f 72 5f 73 74 72 69 6e 67 0a 73 71 6c  error_string.sql
09d0: 69 74 65 5f 69 6e 74 65 72 72 75 70 74 0a 73 71  ite_interrupt.sq
09e0: 6c 69 74 65 5f 63 6f 6d 70 6c 65 74 65 0a 73 71  lite_complete.sq
09f0: 6c 69 74 65 5f 62 75 73 79 5f 68 61 6e 64 6c 65  lite_busy_handle
0a00: 72 0a 73 71 6c 69 74 65 5f 62 75 73 79 5f 74 69  r.sqlite_busy_ti
0a10: 6d 65 6f 75 74 0a 73 71 6c 69 74 65 5f 67 65 74  meout.sqlite_get
0a20: 5f 74 61 62 6c 65 0a 73 71 6c 69 74 65 5f 66 72  _table.sqlite_fr
0a30: 65 65 5f 74 61 62 6c 65 0a 73 71 6c 69 74 65 5f  ee_table.sqlite_
0a40: 6d 70 72 69 6e 74 66 0a 73 71 6c 69 74 65 5f 76  mprintf.sqlite_v
0a50: 6d 70 72 69 6e 74 66 0a 73 71 6c 69 74 65 5f 65  mprintf.sqlite_e
0a60: 78 65 63 5f 70 72 69 6e 74 66 0a 73 71 6c 69 74  xec_printf.sqlit
0a70: 65 5f 65 78 65 63 5f 76 70 72 69 6e 74 66 0a 73  e_exec_vprintf.s
0a80: 71 6c 69 74 65 5f 67 65 74 5f 74 61 62 6c 65 5f  qlite_get_table_
0a90: 70 72 69 6e 74 66 0a 73 71 6c 69 74 65 5f 67 65  printf.sqlite_ge
0aa0: 74 5f 74 61 62 6c 65 5f 76 70 72 69 6e 74 66 0a  t_table_vprintf.
0ab0: 73 71 6c 69 74 65 5f 66 72 65 65 6d 65 6d 0a 73  sqlite_freemem.s
0ac0: 71 6c 69 74 65 5f 6c 69 62 76 65 72 73 69 6f 6e  qlite_libversion
0ad0: 0a 73 71 6c 69 74 65 5f 6c 69 62 65 6e 63 6f 64  .sqlite_libencod
0ae0: 69 6e 67 0a 73 71 6c 69 74 65 5f 63 68 61 6e 67  ing.sqlite_chang
0af0: 65 73 0a 73 71 6c 69 74 65 5f 63 72 65 61 74 65  es.sqlite_create
0b00: 5f 66 75 6e 63 74 69 6f 6e 0a 73 71 6c 69 74 65  _function.sqlite
0b10: 5f 63 72 65 61 74 65 5f 61 67 67 72 65 67 61 74  _create_aggregat
0b20: 65 0a 73 71 6c 69 74 65 5f 66 75 6e 63 74 69 6f  e.sqlite_functio
0b30: 6e 5f 74 79 70 65 0a 73 71 6c 69 74 65 5f 75 73  n_type.sqlite_us
0b40: 65 72 5f 64 61 74 61 0a 73 71 6c 69 74 65 5f 61  er_data.sqlite_a
0b50: 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74  ggregate_context
0b60: 0a 73 71 6c 69 74 65 5f 61 67 67 72 65 67 61 74  .sqlite_aggregat
0b70: 65 5f 63 6f 75 6e 74 0a 73 71 6c 69 74 65 5f 73  e_count.sqlite_s
0b80: 65 74 5f 72 65 73 75 6c 74 5f 73 74 72 69 6e 67  et_result_string
0b90: 0a 73 71 6c 69 74 65 5f 73 65 74 5f 72 65 73 75  .sqlite_set_resu
0ba0: 6c 74 5f 69 6e 74 0a 73 71 6c 69 74 65 5f 73 65  lt_int.sqlite_se
0bb0: 74 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 0a  t_result_double.
0bc0: 73 71 6c 69 74 65 5f 73 65 74 5f 72 65 73 75 6c  sqlite_set_resul
0bd0: 74 5f 65 72 72 6f 72 0a 73 71 6c 69 74 65 4d 61  t_error.sqliteMa
0be0: 6c 6c 6f 63 0a 73 71 6c 69 74 65 46 72 65 65 0a  lloc.sqliteFree.
0bf0: 73 71 6c 69 74 65 52 65 61 6c 6c 6f 63 0a 73 71  sqliteRealloc.sq
0c00: 6c 69 74 65 5f 73 65 74 5f 61 75 74 68 6f 72 69  lite_set_authori
0c10: 7a 65 72 0a 73 71 6c 69 74 65 5f 74 72 61 63 65  zer.sqlite_trace
0c20: 0a 73 71 6c 69 74 65 5f 63 6f 6d 70 69 6c 65 0a  .sqlite_compile.
0c30: 73 71 6c 69 74 65 5f 73 74 65 70 0a 73 71 6c 69  sqlite_step.sqli
0c40: 74 65 5f 66 69 6e 61 6c 69 7a 65 0a 73 71 6c 69  te_finalize.sqli
0c50: 74 65 5f 72 65 73 65 74 0a 73 71 6c 69 74 65 5f  te_reset.sqlite_
0c60: 62 69 6e 64 0a 73 71 6c 69 74 65 5f 6c 61 73 74  bind.sqlite_last
0c70: 5f 73 74 61 74 65 6d 65 6e 74 5f 63 68 61 6e 67  _statement_chang
0c80: 65 73 0a 73 71 6c 69 74 65 5f 65 6e 63 6f 64 65  es.sqlite_encode
0c90: 5f 62 69 6e 61 72 79 0a 73 71 6c 69 74 65 5f 64  _binary.sqlite_d
0ca0: 65 63 6f 64 65 5f 62 69 6e 61 72 79 0a 45 4e 44  ecode_binary.END
0cb0: 5f 4f 46 5f 46 49 4c 45 0a 69 33 38 36 2d 6d 69  _OF_FILE.i386-mi
0cc0: 6e 67 77 33 32 6d 73 76 63 2d 64 6c 6c 77 72 61  ngw32msvc-dllwra
0cd0: 70 20 5c 0a 20 20 20 20 20 2d 2d 64 65 66 20 73  p \.     --def s
0ce0: 71 6c 69 74 65 2e 64 65 66 20 2d 76 20 2d 2d 65  qlite.def -v --e
0cf0: 78 70 6f 72 74 2d 61 6c 6c 20 5c 0a 20 20 20 20  xport-all \.    
0d00: 20 2d 2d 64 72 69 76 65 72 2d 6e 61 6d 65 20 69   --driver-name i
0d10: 33 38 36 2d 6d 69 6e 67 77 33 32 6d 73 76 63 2d  386-mingw32msvc-
0d20: 67 63 63 20 5c 0a 20 20 20 20 20 2d 2d 64 6c 6c  gcc \.     --dll
0d30: 74 6f 6f 6c 2d 6e 61 6d 65 20 69 33 38 36 2d 6d  tool-name i386-m
0d40: 69 6e 67 77 33 32 6d 73 76 63 2d 64 6c 6c 74 6f  ingw32msvc-dllto
0d50: 6f 6c 20 5c 0a 20 20 20 20 20 2d 2d 61 73 20 69  ol \.     --as i
0d60: 33 38 36 2d 6d 69 6e 67 77 33 32 6d 73 76 63 2d  386-mingw32msvc-
0d70: 61 73 20 5c 0a 20 20 20 20 20 2d 2d 74 61 72 67  as \.     --targ
0d80: 65 74 20 69 33 38 36 2d 6d 69 6e 67 77 33 32 20  et i386-mingw32 
0d90: 5c 0a 20 20 20 20 20 2d 64 6c 6c 6e 61 6d 65 20  \.     -dllname 
0da0: 73 71 6c 69 74 65 2e 64 6c 6c 20 2d 6c 6d 73 76  sqlite.dll -lmsv
0db0: 63 72 74 20 2a 2e 6f 0a 69 33 38 36 2d 6d 69 6e  crt *.o.i386-min
0dc0: 67 77 33 32 6d 73 76 63 2d 73 74 72 69 70 20 73  gw32msvc-strip s
0dd0: 71 6c 69 74 65 2e 64 6c 6c 0a 7a 69 70 20 2e 2e  qlite.dll.zip ..
0de0: 2f 64 6f 63 2f 74 63 6c 73 71 6c 69 74 65 2d 24  /doc/tclsqlite-$
0df0: 56 45 52 53 57 2e 7a 69 70 20 74 63 6c 73 71 6c  VERSW.zip tclsql
0e00: 69 74 65 2e 64 6c 6c 0a 7a 69 70 20 2e 2e 2f 64  ite.dll.zip ../d
0e10: 6f 63 2f 73 71 6c 69 74 65 2d 24 56 45 52 53 57  oc/sqlite-$VERSW
0e20: 2e 7a 69 70 20 73 71 6c 69 74 65 2e 64 6c 6c 20  .zip sqlite.dll 
0e30: 73 71 6c 69 74 65 2e 64 65 66 0a 63 64 20 2e 2e  sqlite.def.cd ..
0e40: 0a 0a 23 20 42 75 69 6c 64 20 74 68 65 20 73 71  ..# Build the sq
0e50: 6c 69 74 65 2e 65 78 65 20 65 78 65 63 75 74 61  lite.exe executa
0e60: 62 6c 65 20 66 6f 72 20 77 69 6e 64 6f 77 73 2e  ble for windows.
0e70: 0a 23 0a 6d 61 6b 65 20 74 61 72 67 65 74 5f 73  .#.make target_s
0e80: 6f 75 72 63 65 0a 63 64 20 74 73 72 63 0a 72 6d  ource.cd tsrc.rm
0e90: 20 74 63 6c 73 71 6c 69 74 65 2e 63 0a 4f 50 54   tclsqlite.c.OPT
0ea0: 53 3d 27 2d 44 53 54 41 54 49 43 5f 42 55 49 4c  S='-DSTATIC_BUIL
0eb0: 44 3d 31 20 2d 44 4e 44 45 42 55 47 3d 31 27 0a  D=1 -DNDEBUG=1'.
0ec0: 69 33 38 36 2d 6d 69 6e 67 77 33 32 6d 73 76 63  i386-mingw32msvc
0ed0: 2d 67 63 63 20 2d 4f 32 20 24 4f 50 54 53 20 2d  -gcc -O2 $OPTS -
0ee0: 49 2e 20 2d 49 24 54 43 4c 44 49 52 20 2a 2e 63  I. -I$TCLDIR *.c
0ef0: 20 2d 6f 20 73 71 6c 69 74 65 2e 65 78 65 0a 7a   -o sqlite.exe.z
0f00: 69 70 20 2e 2e 2f 64 6f 63 2f 73 71 6c 69 74 65  ip ../doc/sqlite
0f10: 2d 24 56 45 52 53 57 2e 7a 69 70 20 73 71 6c 69  -$VERSW.zip sqli
0f20: 74 65 2e 65 78 65 0a 63 64 20 2e 2e 0a 0a 23 20  te.exe.cd ....# 
0f30: 43 6f 6e 73 74 72 75 63 74 20 61 20 74 61 72 62  Construct a tarb
0f40: 61 6c 6c 20 6f 66 20 74 68 65 20 73 6f 75 72 63  all of the sourc
0f50: 65 20 74 72 65 65 0a 23 0a 4f 52 49 47 49 4e 3d  e tree.#.ORIGIN=
0f60: 60 70 77 64 60 0a 63 64 20 24 73 72 63 64 69 72  `pwd`.cd $srcdir
0f70: 0a 63 64 20 2e 2e 0a 45 58 43 4c 55 44 45 3d 60  .cd ...EXCLUDE=`
0f80: 66 69 6e 64 20 73 71 6c 69 74 65 20 2d 70 72 69  find sqlite -pri
0f90: 6e 74 20 7c 20 67 72 65 70 20 43 56 53 20 7c 20  nt | grep CVS | 
0fa0: 73 65 64 20 27 73 2c 5e 2c 20 2d 2d 65 78 63 6c  sed 's,^, --excl
0fb0: 75 64 65 20 2c 27 60 0a 74 61 72 20 63 7a 66 20  ude ,'`.tar czf 
0fc0: 24 4f 52 49 47 49 4e 2f 64 6f 63 2f 73 71 6c 69  $ORIGIN/doc/sqli
0fd0: 74 65 2d 24 56 45 52 53 2e 74 61 72 2e 67 7a 20  te-$VERS.tar.gz 
0fe0: 24 45 58 43 4c 55 44 45 20 73 71 6c 69 74 65 0a  $EXCLUDE sqlite.
0ff0: 63 64 20 24 4f 52 49 47 49 4e 0a 0a 23 0a 23 20  cd $ORIGIN..#.# 
1000: 42 75 69 6c 64 20 52 50 4d 53 20 28 62 69 6e 61  Build RPMS (bina
1010: 72 79 29 20 61 6e 64 20 53 6f 75 72 63 65 20 52  ry) and Source R
1020: 50 4d 0a 23 0a 0a 23 20 4d 61 6b 65 20 73 75 72  PM.#..# Make sur
1030: 65 20 77 65 20 61 72 65 20 70 72 6f 70 65 72 6c  e we are properl
1040: 79 20 73 65 74 75 70 20 74 6f 20 62 75 69 6c 64  y setup to build
1050: 20 52 50 4d 73 0a 23 0a 65 63 68 6f 20 22 25 48   RPMs.#.echo "%H
1060: 4f 4d 45 20 25 7b 65 78 70 61 6e 64 3a 25 25 28  OME %{expand:%%(
1070: 63 64 3b 20 70 77 64 29 7d 22 20 3e 20 24 48 4f  cd; pwd)}" > $HO
1080: 4d 45 2f 2e 72 70 6d 6d 61 63 72 6f 73 0a 65 63  ME/.rpmmacros.ec
1090: 68 6f 20 22 25 5f 74 6f 70 64 69 72 20 25 7b 48  ho "%_topdir %{H
10a0: 4f 4d 45 7d 2f 72 70 6d 22 20 3e 3e 20 24 48 4f  OME}/rpm" >> $HO
10b0: 4d 45 2f 2e 72 70 6d 6d 61 63 72 6f 73 0a 6d 6b  ME/.rpmmacros.mk
10c0: 64 69 72 20 24 48 4f 4d 45 2f 72 70 6d 0a 6d 6b  dir $HOME/rpm.mk
10d0: 64 69 72 20 24 48 4f 4d 45 2f 72 70 6d 2f 42 55  dir $HOME/rpm/BU
10e0: 49 4c 44 0a 6d 6b 64 69 72 20 24 48 4f 4d 45 2f  ILD.mkdir $HOME/
10f0: 72 70 6d 2f 53 4f 55 52 43 45 53 0a 6d 6b 64 69  rpm/SOURCES.mkdi
1100: 72 20 24 48 4f 4d 45 2f 72 70 6d 2f 52 50 4d 53  r $HOME/rpm/RPMS
1110: 0a 6d 6b 64 69 72 20 24 48 4f 4d 45 2f 72 70 6d  .mkdir $HOME/rpm
1120: 2f 53 52 50 4d 53 0a 6d 6b 64 69 72 20 24 48 4f  /SRPMS.mkdir $HO
1130: 4d 45 2f 72 70 6d 2f 53 50 45 43 53 0a 0a 23 20  ME/rpm/SPECS..# 
1140: 63 72 65 61 74 65 20 74 68 65 20 73 70 65 63 20  create the spec 
1150: 66 69 6c 65 20 66 72 6f 6d 20 74 68 65 20 74 65  file from the te
1160: 6d 70 6c 61 74 65 0a 73 65 64 20 73 2f 53 51 4c  mplate.sed s/SQL
1170: 49 54 45 5f 56 45 52 53 49 4f 4e 2f 24 56 45 52  ITE_VERSION/$VER
1180: 53 2f 67 20 24 73 72 63 64 69 72 2f 73 70 65 63  S/g $srcdir/spec
1190: 2e 74 65 6d 70 6c 61 74 65 20 3e 20 24 48 4f 4d  .template > $HOM
11a0: 45 2f 72 70 6d 2f 53 50 45 43 53 2f 73 71 6c 69  E/rpm/SPECS/sqli
11b0: 74 65 2e 73 70 65 63 0a 0a 23 20 63 6f 70 79 20  te.spec..# copy 
11c0: 74 68 65 20 73 6f 75 72 63 65 20 74 61 72 62 61  the source tarba
11d0: 6c 6c 20 74 6f 20 74 68 65 20 72 70 6d 20 64 69  ll to the rpm di
11e0: 72 65 63 74 6f 72 79 0a 63 70 20 64 6f 63 2f 73  rectory.cp doc/s
11f0: 71 6c 69 74 65 2d 24 56 45 52 53 2e 74 61 72 2e  qlite-$VERS.tar.
1200: 67 7a 20 24 48 4f 4d 45 2f 72 70 6d 2f 53 4f 55  gz $HOME/rpm/SOU
1210: 52 43 45 53 2f 2e 0a 0a 23 20 62 75 69 6c 64 20  RCES/...# build 
1220: 61 6c 6c 20 74 68 65 20 72 70 6d 73 0a 72 70 6d  all the rpms.rpm
1230: 20 2d 62 61 20 24 48 4f 4d 45 2f 72 70 6d 2f 53   -ba $HOME/rpm/S
1240: 50 45 43 53 2f 73 71 6c 69 74 65 2e 73 70 65 63  PECS/sqlite.spec
1250: 20 3e 26 20 72 70 6d 2d 24 76 65 72 73 2e 6c 6f   >& rpm-$vers.lo
1260: 67 0a 0a 23 20 63 6f 70 79 20 74 68 65 20 52 50  g..# copy the RP
1270: 4d 73 20 69 6e 74 6f 20 74 68 65 20 62 75 69 6c  Ms into the buil
1280: 64 20 64 69 72 65 63 74 6f 72 79 2e 0a 6d 76 20  d directory..mv 
1290: 24 48 4f 4d 45 2f 72 70 6d 2f 52 50 4d 53 2f 69  $HOME/rpm/RPMS/i
12a0: 33 38 36 2f 73 71 6c 69 74 65 2a 2d 24 56 45 52  386/sqlite*-$VER
12b0: 53 2a 2e 72 70 6d 20 64 6f 63 0a 6d 76 20 24 48  S*.rpm doc.mv $H
12c0: 4f 4d 45 2f 72 70 6d 2f 53 52 50 4d 53 2f 73 71  OME/rpm/SRPMS/sq
12d0: 6c 69 74 65 2d 24 56 45 52 53 2a 2e 72 70 6d 20  lite-$VERS*.rpm 
12e0: 64 6f 63 0a                                      doc.