Hex Artifact Content

Artifact 8577620ff564a63190a3a9950a601380daa88f3c:


0000: 54 68 69 73 20 77 69 6c 6c 20 62 75 69 6c 64 20  This will build 
0010: 61 20 54 63 6c 6b 69 74 20 6e 61 6d 65 64 20 22  a Tclkit named "
0020: 74 63 6c 6b 69 74 2d 3c 76 65 72 73 69 6f 6e 3e  tclkit-<version>
0030: 22 20 6f 72 20 61 20 4b 69 74 44 4c 4c 20 6e 61  " or a KitDLL na
0040: 6d 65 64 0a 22 6c 69 62 74 63 6c 6b 69 74 3c 76  med."libtclkit<v
0050: 65 72 73 69 6f 6e 3e 2e 73 6f 22 2e 0a 0a 2d 2d  ersion>.so"...--
0060: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 55 73  -------------.Us
0070: 69 6e 67 20 54 68 69 73 20 54 6f 6f 6c 0a 2d 2d  ing This Tool.--
0080: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 55 73  -------------.Us
0090: 61 67 65 3a 0a 09 6b 69 74 63 72 65 61 74 6f 72  age:..kitcreator
00a0: 20 5b 7b 62 75 69 6c 64 20 7c 20 72 65 74 72 79   [{build | retry
00b0: 20 7c 20 63 6c 65 61 6e 20 7c 20 64 69 73 74 63   | clean | distc
00c0: 6c 65 61 6e 7d 5d 0a 09 20 20 20 20 20 20 20 20  lean}]..        
00d0: 20 20 20 5b 7b 3c 76 65 72 73 69 6f 6e 3e 20 7c     [{<version> |
00e0: 20 63 76 73 5f 3c 74 61 67 3e 20 7c 20 66 6f 73   cvs_<tag> | fos
00f0: 73 69 6c 5f 3c 74 61 67 3e 7d 5d 0a 09 20 20 20  sil_<tag>}]..   
0100: 20 20 20 20 20 20 20 20 5b 3c 63 6f 6e 66 69 67          [<config
0110: 75 72 65 5f 6f 70 74 69 6f 6e 3e 20 2e 2e 2e 5d  ure_option> ...]
0120: 0a 0a 09 57 68 65 72 65 3a 0a 09 09 76 65 72 73  ...Where:...vers
0130: 69 6f 6e 20 20 20 20 20 20 20 20 20 20 20 20 69  ion            i
0140: 73 20 61 20 54 63 6c 20 76 65 72 73 69 6f 6e 20  s a Tcl version 
0150: 6e 75 6d 62 65 72 20 28 65 2e 67 2e 2c 20 38 2e  number (e.g., 8.
0160: 36 2e 31 29 0a 09 09 74 61 67 20 20 20 20 20 20  6.1)...tag      
0170: 20 20 20 20 20 20 20 20 20 20 69 73 20 61 20 43            is a C
0180: 56 53 20 6f 72 20 66 6f 73 73 69 6c 20 72 65 6c  VS or fossil rel
0190: 65 61 73 65 20 74 61 67 20 28 65 2e 67 2e 2c 20  ease tag (e.g., 
01a0: 48 45 41 44 29 0a 09 09 63 6f 6e 66 69 67 75 72  HEAD)...configur
01b0: 65 5f 6f 70 74 69 6f 6e 20 20 20 6f 70 74 69 6f  e_option   optio
01c0: 6e 20 74 6f 20 70 61 73 73 20 74 6f 20 73 75 62  n to pass to sub
01d0: 6f 72 64 69 6e 61 74 65 20 63 6f 6e 66 69 67 75  ordinate configu
01e0: 72 65 0a 09 09 20 20 20 20 20 20 20 20 20 20 20  re...           
01f0: 20 20 20 20 20 20 20 20 73 63 72 69 70 74 73 20          scripts 
0200: 28 65 2e 67 2e 2c 20 2d 2d 65 6e 61 62 6c 65 2d  (e.g., --enable-
0210: 36 34 62 69 74 29 0a 0a 09 44 65 66 61 75 6c 74  64bit)...Default
0220: 20 69 73 20 74 6f 20 63 72 65 61 74 65 20 61 20   is to create a 
0230: 54 63 6c 6b 69 74 20 66 72 6f 6d 20 54 63 6c 20  Tclkit from Tcl 
0240: 76 65 72 73 69 6f 6e 20 38 2e 36 2e 31 0a 0a 45  version 8.6.1..E
0250: 78 61 6d 70 6c 65 73 3a 0a 09 31 2e 20 43 72 65  xamples:..1. Cre
0260: 61 74 65 20 61 20 54 63 6c 6b 69 74 3a 0a 09 09  ate a Tclkit:...
0270: 61 2e 20 24 20 2e 2f 6b 69 74 63 72 65 61 74 6f  a. $ ./kitcreato
0280: 72 0a 0a 09 32 2e 20 43 72 65 61 74 65 20 61 20  r...2. Create a 
0290: 54 63 6c 6b 69 74 20 66 6f 72 20 54 63 6c 20 38  Tclkit for Tcl 8
02a0: 2e 35 2e 31 35 3a 0a 09 09 61 2e 20 24 20 2e 2f  .5.15:...a. $ ./
02b0: 6b 69 74 63 72 65 61 74 6f 72 20 38 2e 35 2e 31  kitcreator 8.5.1
02c0: 35 0a 0a 09 33 2e 20 43 72 65 61 74 65 20 61 20  5...3. Create a 
02d0: 54 63 6c 6b 69 74 20 66 6f 72 20 54 63 6c 20 66  Tclkit for Tcl f
02e0: 72 6f 6d 20 43 56 53 20 48 45 41 44 3a 0a 09 09  rom CVS HEAD:...
02f0: 61 2e 20 24 20 2e 2f 6b 69 74 63 72 65 61 74 6f  a. $ ./kitcreato
0300: 72 20 63 76 73 5f 48 45 41 44 0a 0a 09 34 2e 20  r cvs_HEAD...4. 
0310: 43 6f 6d 70 69 6c 65 20 61 20 36 34 2d 62 69 74  Compile a 64-bit
0320: 20 54 63 6c 6b 69 74 3a 0a 09 09 61 2e 20 24 20   Tclkit:...a. $ 
0330: 2e 2f 6b 69 74 63 72 65 61 74 6f 72 20 2d 2d 65  ./kitcreator --e
0340: 6e 61 62 6c 65 2d 36 34 62 69 74 0a 0a 09 35 2e  nable-64bit...5.
0350: 20 43 72 6f 73 73 2d 63 6f 6d 70 69 6c 65 20 61   Cross-compile a
0360: 20 54 63 6c 6b 69 74 3a 0a 09 09 61 2e 20 42 6f   Tclkit:...a. Bo
0370: 6f 74 73 74 72 61 70 20 28 6f 70 74 69 6f 6e 61  otstrap (optiona
0380: 6c 2c 20 79 6f 75 20 63 61 6e 20 75 73 65 20 61  l, you can use a
0390: 6e 20 65 78 69 73 74 69 6e 67 20 54 63 6c 6b 69  n existing Tclki
03a0: 74 29 3a 0a 09 09 09 69 2e 20 20 20 24 20 2e 2f  t):....i.   $ ./
03b0: 6b 69 74 63 72 65 61 74 6f 72 0a 09 09 09 69 69  kitcreator....ii
03c0: 2e 20 20 24 20 6d 76 20 74 63 6c 6b 69 74 2d 38  .  $ mv tclkit-8
03d0: 2e 34 2e 31 39 20 74 63 6c 6b 69 74 2d 6c 6f 63  .4.19 tclkit-loc
03e0: 61 6c 0a 09 09 09 69 69 69 2e 20 24 20 54 43 4c  al....iii. $ TCL
03f0: 4b 49 54 3d 22 60 70 77 64 60 2f 74 63 6c 6b 69  KIT="`pwd`/tclki
0400: 74 2d 6c 6f 63 61 6c 22 0a 09 09 09 69 76 2e 20  t-local"....iv. 
0410: 20 24 20 65 78 70 6f 72 74 20 54 43 4c 4b 49 54   $ export TCLKIT
0420: 0a 09 09 62 2e 20 43 72 6f 73 73 2d 63 6f 6d 70  ...b. Cross-comp
0430: 69 6c 65 3a 0a 09 09 09 69 2e 20 20 20 24 20 43  ile:....i.   $ C
0440: 43 3d 6d 69 70 73 65 6c 2d 6c 69 6e 75 78 2d 75  C=mipsel-linux-u
0450: 63 6c 69 62 63 2d 67 63 63 0a 09 09 09 69 69 2e  clibc-gcc....ii.
0460: 20 20 24 20 43 58 58 3d 66 61 6c 73 65 0a 09 09    $ CXX=false...
0470: 09 69 69 69 2e 20 24 20 41 52 3d 6d 69 70 73 65  .iii. $ AR=mipse
0480: 6c 2d 6c 69 6e 75 78 2d 75 63 6c 69 62 63 2d 61  l-linux-uclibc-a
0490: 72 0a 09 09 09 69 76 2e 20 20 24 20 52 41 4e 4c  r....iv.  $ RANL
04a0: 49 42 3d 6d 69 70 73 65 6c 2d 6c 69 6e 75 78 2d  IB=mipsel-linux-
04b0: 75 63 6c 69 62 63 2d 72 61 6e 6c 69 62 0a 09 09  uclibc-ranlib...
04c0: 09 76 2e 20 20 20 24 20 65 78 70 6f 72 74 20 43  .v.   $ export C
04d0: 43 20 43 58 58 20 41 52 20 52 41 4e 4c 49 42 0a  C CXX AR RANLIB.
04e0: 09 09 09 76 69 2e 20 20 24 20 2e 2f 6b 69 74 63  ...vi.  $ ./kitc
04f0: 72 65 61 74 6f 72 20 2d 2d 68 6f 73 74 3d 6d 69  reator --host=mi
0500: 70 73 65 6c 2d 6c 69 6e 75 78 2d 75 63 6c 69 62  psel-linux-uclib
0510: 63 0a 09 20 20 20 4e 6f 74 65 3a 20 57 68 65 6e  c..   Note: When
0520: 20 63 72 6f 73 73 2d 63 6f 6d 70 69 6c 69 6e 67   cross-compiling
0530: 2c 20 74 68 65 20 54 63 6c 20 63 6f 6e 66 69 67  , the Tcl config
0540: 75 72 65 20 73 63 72 69 70 74 20 6d 61 79 20 62  ure script may b
0550: 65 20 75 6e 61 62 6c 65 0a 09 20 20 20 74 6f 20  e unable..   to 
0560: 64 65 74 65 72 6d 69 6e 65 20 77 68 69 63 68 20  determine which 
0570: 73 65 72 69 61 6c 20 73 75 70 70 6f 72 74 20 6d  serial support m
0580: 65 74 68 6f 64 20 74 6f 20 75 73 65 2e 20 49 66  ethod to use. If
0590: 20 79 6f 75 20 77 61 6e 74 20 73 65 72 69 61 6c   you want serial
05a0: 0a 09 20 20 20 73 75 70 70 6f 72 74 20 69 6e 20  ..   support in 
05b0: 61 20 63 72 6f 73 73 2d 63 6f 6d 70 69 6c 65 64  a cross-compiled
05c0: 20 74 63 6c 6b 69 74 2c 20 73 70 65 63 69 66 79   tclkit, specify
05d0: 20 69 74 20 6d 61 6e 75 61 6c 6c 79 2c 20 65 2e   it manually, e.
05e0: 67 2e 3a 0a 09 09 24 20 2e 2f 6b 69 74 63 72 65  g.:...$ ./kitcre
05f0: 61 74 6f 72 20 43 46 4c 41 47 53 3d 2d 44 55 53  ator CFLAGS=-DUS
0600: 45 5f 54 45 52 4d 49 4f 53 3d 31 20 2d 68 6f 73  E_TERMIOS=1 -hos
0610: 74 3d 6d 69 70 73 65 6c 2d 6c 69 6e 75 78 2d 75  t=mipsel-linux-u
0620: 63 6c 69 62 63 0a 0a 09 36 2e 20 43 6f 6d 70 69  clibc...6. Compi
0630: 6c 65 20 61 20 36 34 2d 62 69 74 20 54 63 6c 6b  le a 64-bit Tclk
0640: 69 74 20 38 2e 35 2e 31 35 20 75 73 69 6e 67 20  it 8.5.15 using 
0650: 53 75 6e 53 74 75 64 69 6f 20 31 32 2e 31 20 6f  SunStudio 12.1 o
0660: 6e 20 53 6f 6c 61 72 69 73 2f 78 38 36 3a 0a 09  n Solaris/x86:..
0670: 09 61 2e 20 24 20 43 43 3d 27 2f 6f 70 74 2f 73  .a. $ CC='/opt/s
0680: 75 6e 73 74 75 64 69 6f 31 32 2e 31 2f 62 69 6e  unstudio12.1/bin
0690: 2f 63 63 20 2d 6d 36 34 27 0a 09 09 62 2e 20 24  /cc -m64'...b. $
06a0: 20 43 58 58 3d 27 2f 6f 70 74 2f 73 75 6e 73 74   CXX='/opt/sunst
06b0: 75 64 69 6f 31 32 2e 31 2f 62 69 6e 2f 43 43 20  udio12.1/bin/CC 
06c0: 2d 6d 36 34 27 0a 09 09 63 2e 20 24 20 50 41 54  -m64'...c. $ PAT
06d0: 43 48 3d 27 67 70 61 74 63 68 27 0a 09 09 63 2e  CH='gpatch'...c.
06e0: 20 24 20 65 78 70 6f 72 74 20 43 43 20 43 58 58   $ export CC CXX
06f0: 20 50 41 54 43 48 0a 09 09 64 2e 20 24 20 2e 2f   PATCH...d. $ ./
0700: 6b 69 74 63 72 65 61 74 6f 72 20 38 2e 35 2e 31  kitcreator 8.5.1
0710: 35 20 2d 2d 65 6e 61 62 6c 65 2d 36 34 62 69 74  5 --enable-64bit
0720: 0a 0a 09 37 2e 20 54 6f 20 63 6c 65 61 6e 20 75  ...7. To clean u
0730: 70 20 70 6f 73 74 2d 62 75 69 6c 64 3a 0a 09 09  p post-build:...
0740: 61 2e 20 24 20 2e 2f 6b 69 74 63 72 65 61 74 6f  a. $ ./kitcreato
0750: 72 20 63 6c 65 61 6e 0a 0a 09 38 2e 20 43 72 65  r clean...8. Cre
0760: 61 74 65 20 61 20 54 63 6c 6b 69 74 20 77 69 74  ate a Tclkit wit
0770: 68 6f 75 74 20 4d 65 74 61 6b 69 74 34 20 73 75  hout Metakit4 su
0780: 70 70 6f 72 74 20 28 66 61 6c 6c 73 20 62 61 63  pport (falls bac
0790: 6b 20 74 6f 20 5a 69 70 20 66 6f 72 20 73 74 6f  k to Zip for sto
07a0: 72 61 67 65 29 3a 0a 09 09 61 2e 20 4b 49 54 43  rage):...a. KITC
07b0: 52 45 41 54 4f 52 5f 50 4b 47 53 3d 27 74 6b 20  REATOR_PKGS='tk 
07c0: 69 74 63 6c 27 0a 09 09 62 2e 20 65 78 70 6f 72  itcl'...b. expor
07d0: 74 20 4b 49 54 43 52 45 41 54 4f 52 5f 50 4b 47  t KITCREATOR_PKG
07e0: 53 0a 09 09 63 2e 20 2e 2f 6b 69 74 63 72 65 61  S...c. ./kitcrea
07f0: 74 6f 72 0a 0a 09 39 2e 20 43 72 65 61 74 65 20  tor...9. Create 
0800: 61 20 54 63 6c 6b 69 74 20 77 69 74 68 20 4d 65  a Tclkit with Me
0810: 74 61 6b 69 74 34 20 73 75 70 70 6f 72 74 2c 20  takit4 support, 
0820: 62 75 74 20 75 73 69 6e 67 20 5a 69 70 20 66 6f  but using Zip fo
0830: 72 20 73 74 6f 72 61 67 65 3a 0a 09 09 61 2e 20  r storage:...a. 
0840: 24 20 2e 2f 6b 69 74 63 72 65 61 74 6f 72 20 2d  $ ./kitcreator -
0850: 2d 65 6e 61 62 6c 65 2d 6b 69 74 2d 73 74 6f 72  -enable-kit-stor
0860: 61 67 65 3d 7a 69 70 0a 0a 09 31 30 2e 20 43 72  age=zip...10. Cr
0870: 65 61 74 65 20 61 20 54 63 6c 6b 69 74 20 77 69  eate a Tclkit wi
0880: 74 68 20 4d 65 74 61 6b 69 74 34 20 73 75 70 70  th Metakit4 supp
0890: 6f 72 74 2c 20 62 75 74 20 75 73 69 6e 67 20 43  ort, but using C
08a0: 2d 56 46 53 20 66 6f 72 20 73 74 6f 72 61 67 65  -VFS for storage
08b0: 0a 09 09 61 2e 20 24 20 2e 2f 6b 69 74 63 72 65  ...a. $ ./kitcre
08c0: 61 74 6f 72 20 2d 2d 65 6e 61 62 6c 65 2d 6b 69  ator --enable-ki
08d0: 74 2d 73 74 6f 72 61 67 65 3d 63 76 66 73 0a 0a  t-storage=cvfs..
08e0: 09 31 31 2e 20 43 72 65 61 74 65 20 61 20 4b 69  .11. Create a Ki
08f0: 74 44 4c 4c 20 77 69 74 68 6f 75 74 20 4d 65 74  tDLL without Met
0900: 61 6b 69 74 20 73 75 70 70 6f 72 74 20 28 77 69  akit support (wi
0910: 6c 6c 20 6e 6f 74 20 63 72 65 61 74 65 20 61 20  ll not create a 
0920: 54 63 6c 6b 69 74 0a 09 20 20 20 20 62 69 6e 61  Tclkit..    bina
0930: 72 79 2c 20 6a 75 73 74 20 74 68 65 20 6c 69 62  ry, just the lib
0940: 72 61 72 79 29 3a 0a 09 09 61 2e 20 24 20 4b 49  rary):...a. $ KI
0950: 54 43 52 45 41 54 4f 52 5f 50 4b 47 53 3d 27 74  TCREATOR_PKGS='t
0960: 6b 20 69 74 63 6c 20 6b 69 74 64 6c 6c 27 0a 09  k itcl kitdll'..
0970: 09 62 2e 20 24 20 65 78 70 6f 72 74 20 4b 49 54  .b. $ export KIT
0980: 43 52 45 41 54 4f 52 5f 50 4b 47 53 0a 09 09 63  CREATOR_PKGS...c
0990: 2e 20 24 20 2e 2f 6b 69 74 63 72 65 61 74 6f 72  . $ ./kitcreator
09a0: 0a 0a 45 6e 76 69 72 6f 6e 6d 65 6e 74 20 76 61  ..Environment va
09b0: 72 69 61 62 6c 65 73 3a 0a 09 31 2e 20 4d 41 4b  riables:..1. MAK
09c0: 45 0a 09 09 53 70 65 63 69 66 69 65 73 20 74 68  E...Specifies th
09d0: 65 20 74 6f 6f 6c 20 79 6f 75 20 77 69 73 68 20  e tool you wish 
09e0: 74 6f 20 62 65 20 63 61 6c 6c 65 64 20 74 6f 20  to be called to 
09f0: 62 75 69 6c 64 20 74 61 72 67 65 74 73 0a 09 09  build targets...
0a00: 66 72 6f 6d 20 61 20 4d 61 6b 65 66 69 6c 65 2e  from a Makefile.
0a10: 20 20 54 68 69 73 20 73 63 72 69 70 74 20 69 73    This script is
0a20: 20 67 65 6e 65 72 61 6c 6c 79 20 6d 6f 72 65 20   generally more 
0a30: 77 65 6c 6c 20 74 65 73 74 65 64 0a 09 09 77 69  well tested...wi
0a40: 74 68 20 47 4e 55 20 4d 61 6b 65 2e 0a 0a 09 32  th GNU Make....2
0a50: 2e 20 50 41 54 43 48 0a 09 09 53 70 65 63 69 66  . PATCH...Specif
0a60: 69 65 73 20 74 68 65 20 74 6f 6f 6c 20 79 6f 75  ies the tool you
0a70: 20 77 69 73 68 20 74 6f 20 62 65 20 63 61 6c 6c   wish to be call
0a80: 65 64 20 74 6f 20 61 70 70 6c 79 20 75 6e 69 66  ed to apply unif
0a90: 69 65 64 0a 09 09 64 69 66 66 20 70 61 74 63 68  ied...diff patch
0aa0: 65 73 2e 20 20 54 68 69 73 20 73 63 72 69 70 74  es.  This script
0ab0: 20 69 73 20 67 65 6e 65 72 61 6c 6c 79 20 6d 6f   is generally mo
0ac0: 72 65 20 77 65 6c 6c 20 74 65 73 74 65 64 20 77  re well tested w
0ad0: 69 74 68 0a 09 09 47 4e 55 20 50 61 74 63 68 2e  ith...GNU Patch.
0ae0: 20 0a 0a 09 33 2e 20 54 43 4c 4b 49 54 0a 09 09   ...3. TCLKIT...
0af0: 53 70 65 63 69 66 79 20 74 68 65 20 70 61 74 68  Specify the path
0b00: 20 74 6f 20 61 20 54 63 6c 6b 69 74 20 74 68 61   to a Tclkit tha
0b10: 74 20 69 73 20 72 75 6e 6e 61 62 6c 65 20 6f 6e  t is runnable on
0b20: 20 74 68 65 20 63 75 72 72 65 6e 74 0a 09 09 73   the current...s
0b30: 79 73 74 65 6d 2e 20 20 54 68 65 20 64 65 66 61  ystem.  The defa
0b40: 75 6c 74 20 69 73 20 22 74 63 6c 6b 69 74 22 2e  ult is "tclkit".
0b50: 20 20 41 20 77 6f 72 6b 69 6e 67 20 74 63 6c 6b    A working tclk
0b60: 69 74 20 69 73 20 72 65 71 75 69 72 65 64 0a 09  it is required..
0b70: 09 66 6f 72 20 63 72 6f 73 73 2d 63 6f 6d 70 69  .for cross-compi
0b80: 6c 69 6e 67 20 54 63 6c 6b 69 74 73 2e 0a 0a 09  ling Tclkits....
0b90: 34 2e 20 53 54 41 54 49 43 54 4b 0a 09 09 53 70  4. STATICTK...Sp
0ba0: 65 63 69 66 79 20 74 68 69 73 20 61 73 20 22 31  ecify this as "1
0bb0: 22 20 74 6f 20 73 74 61 74 69 63 61 6c 6c 79 20  " to statically 
0bc0: 6c 69 6e 6b 20 74 6f 20 54 6b 2e 20 20 54 68 65  link to Tk.  The
0bd0: 20 64 65 66 61 75 6c 74 0a 09 09 61 63 74 69 6f   default...actio
0be0: 6e 20 6f 6e 20 6d 6f 73 74 20 70 6c 61 74 66 6f  n on most platfo
0bf0: 72 6d 73 20 69 73 20 74 6f 20 64 79 6e 61 6d 69  rms is to dynami
0c00: 63 61 6c 6c 79 20 6c 69 6e 6b 20 74 6f 20 54 6b  cally link to Tk
0c10: 2e 20 20 57 68 65 6e 0a 09 09 62 75 69 6c 64 69  .  When...buildi
0c20: 6e 67 20 4b 69 74 44 4c 4c 2c 20 53 54 41 54 49  ng KitDLL, STATI
0c30: 43 54 4b 20 69 73 20 22 31 22 20 62 79 20 64 65  CTK is "1" by de
0c40: 66 61 75 6c 74 2e 20 20 49 66 20 79 6f 75 20 77  fault.  If you w
0c50: 61 6e 74 20 74 6f 0a 09 09 65 6e 61 62 6c 65 20  ant to...enable 
0c60: 64 79 6e 61 6d 69 63 20 6c 69 6e 6b 69 6e 67 20  dynamic linking 
0c70: 6f 66 20 54 6b 20 77 69 74 68 20 4b 69 74 44 4c  of Tk with KitDL
0c80: 4c 20 79 6f 75 20 77 69 6c 6c 20 68 61 76 65 20  L you will have 
0c90: 74 6f 0a 09 09 73 70 65 63 69 66 79 20 74 68 69  to...specify thi
0ca0: 73 20 61 73 20 22 2d 31 22 2e 0a 0a 09 35 2e 20  s as "-1"....5. 
0cb0: 53 54 41 54 49 43 4d 4b 34 0a 09 09 53 70 65 63  STATICMK4...Spec
0cc0: 69 66 79 20 74 68 69 73 20 61 73 20 22 30 22 20  ify this as "0" 
0cd0: 74 6f 20 61 74 74 65 6d 70 74 20 74 6f 20 63 72  to attempt to cr
0ce0: 65 61 74 65 20 63 72 65 61 74 65 20 74 68 65 20  eate create the 
0cf0: 22 6d 6b 34 74 63 6c 22 0a 09 09 70 72 6f 6a 65  "mk4tcl"...proje
0d00: 63 74 20 61 73 20 61 20 73 68 61 72 65 64 20 6f  ct as a shared o
0d10: 62 6a 65 63 74 2e 20 20 49 66 20 74 68 69 73 20  bject.  If this 
0d20: 66 61 69 6c 73 2c 20 69 74 20 77 69 6c 6c 20 66  fails, it will f
0d30: 61 6c 6c 20 62 61 63 6b 0a 09 09 74 6f 20 62 75  all back...to bu
0d40: 69 6c 64 69 6e 67 20 73 74 61 74 69 63 61 6c 6c  ilding staticall
0d50: 79 2e 20 20 53 70 65 63 69 66 79 20 69 74 20 61  y.  Specify it a
0d60: 73 20 22 2d 31 22 20 74 6f 20 66 6f 72 63 65 20  s "-1" to force 
0d70: 62 75 69 6c 64 69 6e 67 0a 09 09 69 74 20 61 73  building...it as
0d80: 20 61 20 73 68 61 72 65 64 20 6f 62 6a 65 63 74   a shared object
0d90: 2e 20 20 41 6e 79 20 6f 74 68 65 72 20 76 61 6c  .  Any other val
0da0: 75 65 2c 20 69 6e 63 6c 75 64 69 6e 67 20 62 65  ue, including be
0db0: 69 6e 67 20 75 6e 73 65 74 0a 09 09 72 65 73 75  ing unset...resu
0dc0: 6c 74 73 20 69 6e 20 22 6d 6b 34 74 63 6c 22 20  lts in "mk4tcl" 
0dd0: 62 65 69 6e 67 20 62 75 69 6c 74 20 61 6e 64 20  being built and 
0de0: 6c 69 6e 6b 65 64 20 73 74 61 74 69 63 61 6c 6c  linked staticall
0df0: 79 2e 20 20 4b 69 74 44 49 4c 4c 0a 09 09 73 65  y.  KitDILL...se
0e00: 74 73 20 74 68 69 73 20 74 6f 20 76 61 72 69 61  ts this to varia
0e10: 62 6c 65 20 74 6f 20 22 30 22 2e 20 20 49 66 20  ble to "0".  If 
0e20: 4d 65 74 61 6b 69 74 34 20 69 73 20 62 75 69 6c  Metakit4 is buil
0e30: 74 20 73 68 61 72 65 64 2c 20 69 74 0a 09 09 63  t shared, it...c
0e40: 61 6e 6e 6f 74 20 62 65 20 75 73 65 64 20 66 6f  annot be used fo
0e50: 72 20 74 68 65 20 6b 69 74 20 73 74 6f 72 61 67  r the kit storag
0e60: 65 20 66 6f 72 20 54 63 6c 6b 69 74 2e 0a 0a 09  e for Tclkit....
0e70: 36 2e 20 53 54 52 49 50 0a 09 09 53 70 65 63 69  6. STRIP...Speci
0e80: 66 69 65 73 20 74 68 65 20 74 6f 6f 6c 20 79 6f  fies the tool yo
0e90: 75 20 77 69 73 68 20 74 6f 20 62 65 20 63 61 6c  u wish to be cal
0ea0: 6c 65 64 20 74 6f 20 73 74 72 69 70 20 6f 62 6a  led to strip obj
0eb0: 65 63 74 20 66 69 6c 65 73 2c 0a 09 09 61 72 63  ect files,...arc
0ec0: 68 69 76 65 73 2c 20 61 6e 64 20 73 68 61 72 65  hives, and share
0ed0: 64 20 6f 62 6a 65 63 74 73 2e 20 20 54 68 65 20  d objects.  The 
0ee0: 64 65 66 61 75 6c 74 20 69 73 20 22 73 74 72 69  default is "stri
0ef0: 70 22 2e 20 20 59 6f 75 0a 09 09 73 68 6f 75 6c  p".  You...shoul
0f00: 64 20 70 72 6f 62 61 62 6c 79 20 73 65 74 20 74  d probably set t
0f10: 68 69 73 20 69 66 20 79 6f 75 20 61 72 65 20 63  his if you are c
0f20: 72 6f 73 73 2d 63 6f 6d 70 69 6c 69 6e 67 2e 0a  ross-compiling..
0f30: 0a 09 37 2e 20 4b 49 54 43 52 45 41 54 4f 52 5f  ..7. KITCREATOR_
0f40: 50 4b 47 53 0a 09 09 53 70 65 63 69 66 79 20 77  PKGS...Specify w
0f50: 68 69 63 68 20 6e 6f 6e 2d 72 65 71 75 69 72 65  hich non-require
0f60: 64 20 70 61 63 6b 61 67 65 73 20 74 6f 20 62 75  d packages to bu
0f70: 69 6c 64 2e 20 20 54 68 65 20 64 65 66 61 75 6c  ild.  The defaul
0f80: 74 20 6c 69 73 74 0a 09 09 69 73 3a 0a 09 09 09  t list...is:....
0f90: 74 6b 20 69 74 63 6c 20 6d 6b 34 74 63 6c 0a 0a  tk itcl mk4tcl..
0fa0: 09 09 49 66 20 6d 6b 34 74 63 6c 20 69 73 20 6e  ..If mk4tcl is n
0fb0: 6f 74 20 70 72 65 73 65 6e 74 20 61 20 5a 69 70  ot present a Zip
0fc0: 2d 62 61 73 65 64 20 73 74 6f 72 61 67 65 20 6d  -based storage m
0fd0: 65 63 68 61 6e 69 73 6d 20 77 69 6c 6c 20 62 65  echanism will be
0fe0: 0a 09 09 75 73 65 64 20 69 6e 73 74 65 61 64 2e  ...used instead.
0ff0: 20 20 54 6f 20 73 70 65 63 69 66 79 20 74 68 61    To specify tha
1000: 74 20 74 68 65 20 64 65 66 61 75 6c 74 20 62 65  t the default be
1010: 20 75 73 65 64 2c 20 64 6f 20 6e 6f 74 20 73 65   used, do not se
1020: 74 0a 09 09 74 68 69 73 20 6f 72 20 73 65 74 20  t...this or set 
1030: 69 74 20 74 6f 20 74 68 65 20 65 6d 70 74 79 20  it to the empty 
1040: 73 74 72 69 6e 67 2e 20 20 54 6f 20 73 70 65 63  string.  To spec
1050: 69 66 79 20 74 68 61 74 20 6e 6f 0a 09 09 6e 6f  ify that no...no
1060: 6e 2d 72 65 71 75 69 72 65 64 20 70 61 63 6b 61  n-required packa
1070: 67 65 73 20 62 65 20 62 75 69 6c 74 2c 20 73 65  ges be built, se
1080: 74 20 69 74 20 74 6f 20 61 20 73 74 72 69 6e 67  t it to a string
1090: 20 74 68 61 74 0a 09 09 63 6f 6e 74 61 69 6e 73   that...contains
10a0: 20 6f 6e 6c 79 20 77 68 69 74 65 20 73 70 61 63   only white spac
10b0: 65 2e 0a 0a 09 09 49 66 20 22 6b 69 74 64 6c 6c  e.....If "kitdll
10c0: 22 20 69 73 20 73 70 65 63 69 66 69 65 64 20 69  " is specified i
10d0: 6e 20 74 68 65 20 6c 69 73 74 20 74 68 65 20 74  n the list the t
10e0: 61 72 67 65 74 20 62 65 63 6f 6d 65 73 20 4b 69  arget becomes Ki
10f0: 74 44 4c 4c 0a 09 09 61 6e 64 20 6e 6f 20 54 63  tDLL...and no Tc
1100: 6c 6b 69 74 20 77 69 6c 6c 20 62 75 69 6c 74 2c  lkit will built,
1110: 20 62 75 74 20 69 6e 73 74 65 61 64 20 6c 69 62   but instead lib
1120: 74 63 6c 6b 69 74 2e 0a 0a 09 38 2e 20 4b 49 54  tclkit....8. KIT
1130: 43 52 45 41 54 4f 52 5f 4d 49 4e 45 4e 43 4f 44  CREATOR_MINENCOD
1140: 49 4e 47 53 0a 09 09 53 65 74 20 74 68 69 73 20  INGS...Set this 
1150: 76 61 72 69 61 62 6c 65 20 74 6f 20 61 20 6e 6f  variable to a no
1160: 6e 2d 65 6d 70 74 79 20 73 74 72 69 6e 67 20 74  n-empty string t
1170: 6f 20 67 65 6e 65 72 61 74 65 20 61 20 54 63 6c  o generate a Tcl
1180: 6b 69 74 0a 09 09 77 69 74 68 6f 75 74 20 61 6c  kit...without al
1190: 6c 20 65 6e 63 6f 64 69 6e 67 73 2c 20 6f 6e 6c  l encodings, onl
11a0: 79 20 69 6e 63 6c 75 64 69 6e 67 20 74 68 65 20  y including the 
11b0: 66 6f 6c 6c 6f 77 69 6e 67 3a 0a 09 09 09 61 73  following:....as
11c0: 63 69 69 2e 65 6e 63 20 63 70 31 32 35 32 2e 65  cii.enc cp1252.e
11d0: 6e 63 20 69 73 6f 38 38 35 39 2d 31 2e 65 6e 63  nc iso8859-1.enc
11e0: 20 69 73 6f 38 38 35 39 2d 31 35 2e 65 6e 63 0a   iso8859-15.enc.
11f0: 09 09 09 69 73 6f 38 38 35 39 2d 32 2e 65 6e 63  ...iso8859-2.enc
1200: 20 6b 6f 69 38 2d 72 2e 65 6e 63 20 6d 61 63 52   koi8-r.enc macR
1210: 6f 6d 61 6e 2e 65 6e 63 0a 0a 09 39 2e 20 4b 49  oman.enc...9. KI
1220: 54 43 52 45 41 54 4f 52 5f 4d 49 4e 42 55 49 4c  TCREATOR_MINBUIL
1230: 44 0a 09 09 53 65 74 20 74 68 69 73 20 76 61 72  D...Set this var
1240: 69 61 62 6c 65 20 74 6f 20 61 20 6e 6f 6e 2d 65  iable to a non-e
1250: 6d 70 74 79 20 73 74 72 69 6e 67 20 74 6f 20 65  mpty string to e
1260: 78 63 6c 75 64 65 20 75 6e 6e 65 63 65 73 73 61  xclude unnecessa
1270: 72 79 0a 09 09 70 61 63 6b 61 67 65 73 20 66 72  ry...packages fr
1280: 6f 6d 20 54 63 6c 20 62 75 69 6c 64 2e 20 20 54  om Tcl build.  T
1290: 68 69 73 20 65 78 63 6c 75 64 65 73 20 74 68 65  his excludes the
12a0: 20 66 6f 6c 6c 6f 77 69 6e 67 20 70 61 63 6b 61   following packa
12b0: 67 65 73 3a 0a 09 09 09 74 63 6c 74 65 73 74 0a  ges:....tcltest.
12c0: 0a 09 09 41 64 64 69 74 69 6f 6e 61 6c 6c 79 2c  ...Additionally,
12d0: 20 61 6e 79 20 62 75 6e 64 6c 65 64 20 70 61 63   any bundled pac
12e0: 6b 61 67 65 73 20 28 69 6e 20 74 68 65 20 22 70  kages (in the "p
12f0: 6b 67 73 22 20 64 69 72 65 63 74 6f 72 79 29 0a  kgs" directory).
1300: 09 09 61 72 65 20 65 78 63 6c 75 64 65 64 2e 20  ..are excluded. 
1310: 20 54 68 69 73 20 74 79 70 69 63 61 6c 6c 79 20   This typically 
1320: 69 6e 63 6c 75 64 65 73 20 28 61 73 20 6f 66 20  includes (as of 
1330: 54 63 6c 20 38 2e 36 29 3a 0a 09 09 09 69 74 63  Tcl 8.6):....itc
1340: 6c 20 74 68 72 65 61 64 0a 0a 09 31 30 2e 20 4b  l thread...10. K
1350: 43 5f 54 43 4c 5f 53 54 41 54 49 43 50 4b 47 53  C_TCL_STATICPKGS
1360: 0a 09 09 53 65 74 20 74 68 69 73 20 76 61 72 69  ...Set this vari
1370: 61 62 6c 65 20 74 6f 20 74 68 65 20 76 61 6c 75  able to the valu
1380: 65 20 22 31 22 20 74 6f 20 61 74 74 65 6d 70 74  e "1" to attempt
1390: 20 74 6f 20 66 6f 72 63 65 20 74 68 65 0a 09 09   to force the...
13a0: 70 61 63 6b 61 67 65 73 20 69 6e 63 6c 75 64 65  packages include
13b0: 64 20 69 6e 20 74 68 65 20 22 70 6b 67 73 22 20  d in the "pkgs" 
13c0: 64 69 72 65 63 74 6f 72 79 20 6f 66 20 54 63 6c  directory of Tcl
13d0: 20 38 2e 36 2b 0a 09 09 74 6f 20 62 65 20 63 6f   8.6+...to be co
13e0: 6d 70 69 6c 65 64 20 73 74 61 74 69 63 61 6c 6c  mpiled staticall
13f0: 79 0a 0a 09 31 31 2e 20 4b 49 54 43 52 45 41 54  y...11. KITCREAT
1400: 4f 52 5f 53 54 41 54 49 43 5f 4b 49 54 44 4c 4c  OR_STATIC_KITDLL
1410: 0a 09 09 53 65 74 20 74 68 69 73 20 76 61 72 69  ...Set this vari
1420: 61 62 6c 65 20 74 6f 20 74 68 65 20 76 61 6c 75  able to the valu
1430: 65 20 22 31 22 20 74 6f 20 62 75 69 6c 64 20 61  e "1" to build a
1440: 20 73 74 61 74 69 63 20 4b 69 74 44 4c 4c 2e 0a   static KitDLL..
1450: 09 09 54 68 69 73 20 6f 6e 6c 79 20 68 61 73 20  ..This only has 
1460: 61 6e 20 61 66 66 65 63 74 20 77 68 65 6e 20 4b  an affect when K
1470: 49 54 43 52 45 41 54 4f 52 5f 50 4b 47 53 20 73  ITCREATOR_PKGS s
1480: 70 65 63 69 66 69 65 73 20 74 68 61 74 0a 09 09  pecifies that...
1490: 22 6b 69 74 64 6c 6c 22 20 69 73 20 74 6f 20 62  "kitdll" is to b
14a0: 65 20 62 75 69 6c 74 20 28 65 2e 67 2e 2c 20 4b  e built (e.g., K
14b0: 49 54 43 52 45 41 54 4f 52 5f 50 4b 47 53 3d 27  ITCREATOR_PKGS='
14c0: 6b 69 74 64 6c 6c 27 29 0a 0a 09 31 32 2e 20 4b  kitdll')...12. K
14d0: 49 54 43 52 45 41 54 4f 52 5f 49 54 43 4c 33 5f  ITCREATOR_ITCL3_
14e0: 46 4f 52 43 45 0a 09 09 53 65 74 20 74 68 69 73  FORCE...Set this
14f0: 20 76 61 72 69 61 62 6c 65 20 74 6f 20 74 68 65   variable to the
1500: 20 76 61 6c 75 65 20 22 31 22 20 74 6f 20 62 75   value "1" to bu
1510: 69 6c 64 20 5b 69 6e 63 72 20 54 63 6c 5d 20 76  ild [incr Tcl] v
1520: 65 72 73 69 6f 6e 0a 09 09 33 2e 78 20 65 76 65  ersion...3.x eve
1530: 6e 20 77 69 74 68 20 54 63 6c 20 38 2e 36 2b 2e  n with Tcl 8.6+.
1540: 20 20 4e 6f 74 65 20 74 68 61 74 20 5b 69 6e 63    Note that [inc
1550: 72 20 54 63 6c 5d 20 34 2e 78 20 77 69 6c 6c 20  r Tcl] 4.x will 
1560: 73 74 69 6c 6c 0a 09 09 62 65 20 62 75 69 6c 74  still...be built
1570: 20 61 73 20 70 61 72 74 20 6f 66 20 54 63 6c 20   as part of Tcl 
1580: 38 2e 36 2b 20 28 75 6e 6c 65 73 73 20 65 78 63  8.6+ (unless exc
1590: 6c 75 64 65 64 20 75 73 69 6e 67 0a 09 09 4b 49  luded using...KI
15a0: 54 43 52 45 41 54 4f 52 5f 4d 49 4e 42 55 49 4c  TCREATOR_MINBUIL
15b0: 44 29 2e 0a 0a 0a 43 72 6f 73 73 20 63 6f 6d 70  D)....Cross comp
15c0: 69 6c 69 6e 67 20 45 6e 76 69 72 6f 6e 6d 65 6e  iling Environmen
15d0: 74 20 56 61 72 69 61 62 6c 65 73 3a 0a 0a 09 31  t Variables:...1
15e0: 2e 20 43 43 20 20 0a 09 09 43 20 63 6f 6d 70 69  . CC  ...C compi
15f0: 6c 65 72 20 20 20 65 2e 67 2e 20 69 36 38 36 2d  ler   e.g. i686-
1600: 70 63 2d 6d 69 6e 67 77 33 32 2d 67 63 63 0a 0a  pc-mingw32-gcc..
1610: 09 32 2e 20 43 58 58 0a 09 09 43 2b 2b 20 63 6f  .2. CXX...C++ co
1620: 6d 70 69 6c 65 72 2e 20 20 52 65 71 75 69 72 65  mpiler.  Require
1630: 64 20 69 66 20 79 6f 75 20 77 61 6e 74 20 74 6f  d if you want to
1640: 20 75 73 65 20 6d 6b 34 74 63 6c 2e 20 65 2e 67   use mk4tcl. e.g
1650: 2e 20 69 36 38 36 2d 70 63 2d 6d 69 6e 67 77 33  . i686-pc-mingw3
1660: 32 2d 67 2b 2b 0a 09 09 49 66 20 6e 6f 74 20 72  2-g++...If not r
1670: 65 71 75 69 72 65 64 2c 20 79 6f 75 20 63 61 6e  equired, you can
1680: 20 73 65 74 20 69 74 20 74 6f 20 74 68 65 20 73   set it to the s
1690: 74 72 69 6e 67 20 22 66 61 6c 73 65 22 0a 0a 09  tring "false"...
16a0: 33 2e 20 41 52 0a 09 09 4c 69 62 72 61 72 79 20  3. AR...Library 
16b0: 63 72 65 61 74 6f 72 20 65 2e 67 2e 20 69 36 38  creator e.g. i68
16c0: 36 2d 70 63 2d 6d 69 6e 67 77 33 32 2d 61 72 0a  6-pc-mingw32-ar.
16d0: 0a 09 34 2e 20 52 41 4e 4c 49 42 0a 09 09 4c 69  ..4. RANLIB...Li
16e0: 62 72 61 72 79 20 70 6f 73 74 20 70 72 6f 63 65  brary post proce
16f0: 73 73 69 6e 67 20 65 78 65 63 75 74 61 62 6c 65  ssing executable
1700: 20 65 2e 67 2e 20 69 36 38 36 2d 70 63 2d 6d 69   e.g. i686-pc-mi
1710: 6e 67 77 33 32 2d 72 61 6e 6c 69 62 0a 0a 09 35  ngw32-ranlib...5
1720: 2e 20 53 54 52 49 50 0a 09 09 45 78 65 63 75 74  . STRIP...Execut
1730: 61 62 6c 65 20 6e 61 6d 65 20 74 6f 20 73 74 72  able name to str
1740: 69 70 20 62 69 6e 61 72 69 65 73 20 65 2e 67 2e  ip binaries e.g.
1750: 20 69 36 38 36 2d 70 63 2d 6d 69 6e 67 77 33 32   i686-pc-mingw32
1760: 2d 73 74 72 69 70 0a 0a 09 36 2e 20 4e 4d 0a 09  -strip...6. NM..
1770: 09 45 78 65 63 75 74 61 62 6c 65 20 75 73 65 64  .Executable used
1780: 20 74 6f 20 64 75 6d 70 20 6e 61 6d 65 73 20 66   to dump names f
1790: 72 6f 6d 20 74 68 65 20 6f 62 6a 65 63 74 73 20  rom the objects 
17a0: 20 65 2e 67 2e 20 69 36 38 36 2d 70 63 2d 6d 69   e.g. i686-pc-mi
17b0: 6e 67 77 33 32 2d 6e 6d 0a 0a 09 37 2e 20 43 43  ngw32-nm...7. CC
17c0: 5f 46 4f 52 5f 42 55 49 4c 44 2c 20 48 4f 53 54  _FOR_BUILD, HOST
17d0: 5f 43 43 20 0a 09 09 53 65 74 20 74 68 69 73 20  _CC ...Set this 
17e0: 74 6f 20 74 68 65 20 6e 61 6d 65 20 6f 66 20 63  to the name of c
17f0: 6f 6d 70 69 6c 65 72 20 6f 6e 20 74 68 65 20 68  ompiler on the h
1800: 6f 73 74 20 6f 6e 20 77 68 69 63 68 0a 09 09 74  ost on which...t
1810: 68 65 20 63 72 6f 73 73 20 63 6f 6d 70 69 6c 61  he cross compila
1820: 74 69 6f 6e 20 69 73 20 62 65 69 6e 67 20 72 75  tion is being ru
1830: 6e 2e 0a 0a 4f 6e 20 57 69 6e 64 6f 77 73 20 77  n...On Windows w
1840: 65 20 61 6c 73 6f 20 6e 65 65 64 20 74 68 69 73  e also need this
1850: 3a 0a 0a 09 31 2e 20 52 43 0a 09 09 52 65 73 6f  :...1. RC...Reso
1860: 75 72 63 65 20 63 6f 6d 70 69 6c 65 72 20 3a 20  urce compiler : 
1870: 65 2e 67 2e 20 69 36 38 36 2d 70 63 2d 6d 69 6e  e.g. i686-pc-min
1880: 67 77 33 32 2d 77 69 6e 64 72 65 73 0a 0a 0a 4b  gw32-windres...K
1890: 69 74 73 68 20 43 6f 6e 66 69 67 75 72 65 20 4f  itsh Configure O
18a0: 70 74 69 6f 6e 73 3a 0a 09 31 2e 20 2d 2d 65 6e  ptions:..1. --en
18b0: 61 62 6c 65 2d 6b 69 74 2d 73 74 6f 72 61 67 65  able-kit-storage
18c0: 3d 7b 7a 69 70 7c 6d 6b 34 7c 63 76 66 73 7c 61  ={zip|mk4|cvfs|a
18d0: 75 74 6f 7d 0a 09 09 53 70 65 63 69 66 79 20 77  uto}...Specify w
18e0: 68 69 63 68 20 74 79 70 65 20 6f 66 20 73 74 6f  hich type of sto
18f0: 72 61 67 65 20 74 6f 20 75 73 65 20 77 69 74 68  rage to use with
1900: 20 74 68 65 20 54 63 6c 6b 69 74 2e 20 20 54 68   the Tclkit.  Th
1910: 65 0a 09 09 64 65 66 61 75 6c 74 20 69 73 20 74  e...default is t
1920: 6f 20 61 75 74 6f 2d 64 65 74 65 63 74 2e 20 20  o auto-detect.  
1930: 41 75 74 6f 2d 64 65 74 65 63 74 69 6f 6e 20 75  Auto-detection u
1940: 73 65 73 20 4d 6b 34 20 69 66 0a 09 09 61 76 61  ses Mk4 if...ava
1950: 69 6c 61 62 6c 65 20 61 6e 64 20 62 75 69 6c 74  ilable and built
1960: 20 73 74 61 74 69 63 61 6c 6c 79 2c 20 6f 74 68   statically, oth
1970: 65 72 77 69 73 65 20 69 74 20 66 61 6c 6c 73 20  erwise it falls 
1980: 62 61 63 6b 20 74 6f 20 5a 69 70 2e 0a 09 32 2e  back to Zip...2.
1990: 20 2d 2d 77 69 74 68 2d 6f 62 73 66 75 63 61 74   --with-obsfucat
19a0: 65 64 2d 63 76 66 73 0a 09 09 53 70 65 63 69 66  ed-cvfs...Specif
19b0: 79 20 74 68 61 74 20 43 56 46 53 20 73 68 6f 75  y that CVFS shou
19c0: 6c 64 20 62 65 20 6f 62 73 66 75 63 61 74 65 64  ld be obsfucated
19d0: 2e 20 20 54 68 65 20 63 6f 6e 74 65 6e 74 73 20  .  The contents 
19e0: 6f 66 20 74 68 65 0a 09 09 43 56 46 53 20 61 72  of the...CVFS ar
19f0: 65 20 65 6e 63 72 79 70 74 65 64 20 6f 6e 20 64  e encrypted on d
1a00: 69 73 6b 20 61 6e 64 20 74 68 65 20 65 6e 63 72  isk and the encr
1a10: 79 70 74 69 6f 6e 20 6b 65 79 20 69 73 20 69 6e  yption key is in
1a20: 63 6c 75 64 65 64 0a 09 09 69 6e 20 74 68 65 20  cluded...in the 
1a30: 65 78 65 63 75 74 61 62 6c 65 2e 20 20 46 69 6c  executable.  Fil
1a40: 65 73 20 61 72 65 20 74 68 65 6e 20 74 72 61 6e  es are then tran
1a50: 73 70 61 72 65 6e 74 6c 79 20 64 65 63 72 79 70  sparently decryp
1a60: 74 65 64 20 6f 6e 0a 09 09 61 63 63 65 73 73 2e  ted on...access.
1a70: 0a 0a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ..--------------
1a80: 2d 2d 2d 2d 2d 2d 0a 55 73 69 6e 67 20 74 68 65  ------.Using the
1a90: 20 4b 69 74 44 4c 4c 20 53 44 4b 0a 2d 2d 2d 2d   KitDLL SDK.----
1aa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1ab0: 0a 57 68 65 6e 20 79 6f 75 20 62 75 69 6c 64 20  .When you build 
1ac0: 61 20 4b 69 74 44 4c 4c 2c 20 61 20 22 6c 69 62  a KitDLL, a "lib
1ad0: 74 63 6c 6b 69 74 2d 73 64 6b 2d 3c 74 63 6c 76  tclkit-sdk-<tclv
1ae0: 65 72 73 3e 2e 74 61 72 2e 67 7a 22 20 74 61 72  ers>.tar.gz" tar
1af0: 62 61 6c 6c 20 69 73 20 61 6c 73 6f 0a 70 72 6f  ball is also.pro
1b00: 64 75 63 65 64 2e 20 20 54 68 69 73 20 74 61 72  duced.  This tar
1b10: 62 61 6c 6c 20 63 6f 6e 74 61 69 6e 73 20 74 68  ball contains th
1b20: 65 20 54 63 6c 20 28 61 6e 64 20 54 6b 2c 20 69  e Tcl (and Tk, i
1b30: 66 20 63 6f 6d 70 69 6c 65 64 29 20 73 74 75 62  f compiled) stub
1b40: 73 20 6c 69 62 72 61 72 69 65 73 2c 0a 61 6e 64  s libraries,.and
1b50: 20 54 63 6c 20 28 61 6e 64 20 54 6b 2c 20 69 66   Tcl (and Tk, if
1b60: 20 63 6f 6d 70 69 6c 65 64 29 20 68 65 61 64 65   compiled) heade
1b70: 72 20 66 69 6c 65 73 20 6e 65 65 64 65 64 20 74  r files needed t
1b80: 6f 20 63 6f 6d 70 69 6c 65 20 61 6e 64 20 6c 69  o compile and li
1b90: 6e 6b 20 74 68 69 6e 67 73 0a 61 67 61 69 6e 73  nk things.agains
1ba0: 74 20 54 63 6c 20 28 61 6e 64 20 54 6b 29 2e 20  t Tcl (and Tk). 
1bb0: 20 49 74 20 61 6c 73 6f 20 69 6e 63 6c 75 64 65   It also include
1bc0: 73 20 22 74 63 6c 43 6f 6e 66 69 67 2e 73 68 22  s "tclConfig.sh"
1bd0: 20 28 61 6e 64 20 22 74 6b 43 6f 6e 66 69 67 2e   (and "tkConfig.
1be0: 73 68 22 2c 20 69 66 0a 54 6b 20 77 61 73 20 63  sh", if.Tk was c
1bf0: 6f 6d 70 69 6c 65 64 29 2e 0a 0a 54 68 65 20 70  ompiled)...The p
1c00: 75 72 70 6f 73 65 20 66 6f 72 20 74 68 69 73 20  urpose for this 
1c10: 74 61 72 62 61 6c 6c 20 69 73 20 74 6f 20 62 65  tarball is to be
1c20: 20 75 73 65 64 20 74 6f 20 62 75 69 6c 64 20 54   used to build T
1c30: 63 6c 20 65 78 74 65 6e 73 69 6f 6e 73 20 6f 72  cl extensions or
1c40: 0a 61 70 70 6c 69 63 61 74 69 6f 6e 73 20 74 68  .applications th
1c50: 61 74 20 72 65 6c 79 20 6f 6e 20 54 63 6c 2f 54  at rely on Tcl/T
1c60: 6b 20 75 73 69 6e 67 20 74 68 65 20 4b 69 74 44  k using the KitD
1c70: 4c 4c 2e 0a 0a 54 6f 20 75 73 65 20 69 74 2c 20  LL...To use it, 
1c80: 6f 6e 65 20 66 69 72 73 74 20 6d 75 73 74 20 65  one first must e
1c90: 78 74 72 61 63 74 20 74 68 65 20 74 61 72 62 61  xtract the tarba
1ca0: 6c 6c 2e 20 20 41 66 74 65 72 20 74 68 61 74 20  ll.  After that 
1cb0: 74 68 65 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 0a  the environment.
1cc0: 76 61 72 69 61 62 6c 65 20 22 54 43 4c 4b 49 54  variable "TCLKIT
1cd0: 5f 53 44 4b 5f 44 49 52 22 20 6d 75 73 74 20 62  _SDK_DIR" must b
1ce0: 65 20 73 65 74 20 74 6f 20 74 68 65 20 64 69 72  e set to the dir
1cf0: 65 63 74 6f 72 79 20 74 68 61 74 20 77 61 73 20  ectory that was 
1d00: 63 72 65 61 74 65 64 20 69 6e 0a 6f 72 64 65 72  created in.order
1d10: 20 74 6f 20 6d 61 6b 65 20 6d 6f 73 74 20 6f 66   to make most of
1d20: 20 74 68 65 20 76 61 72 69 61 62 6c 65 73 20 63   the variables c
1d30: 6f 6e 74 61 69 6e 20 75 73 65 66 75 6c 20 76 61  ontain useful va
1d40: 6c 75 65 73 2e 0a 0a 46 6f 72 20 65 78 61 6d 70  lues...For examp
1d50: 6c 65 2c 20 74 6f 20 62 75 69 6c 64 20 61 6e 20  le, to build an 
1d60: 65 78 74 65 6e 73 69 6f 6e 20 75 73 69 6e 67 20  extension using 
1d70: 74 68 65 20 4b 69 74 44 4c 4c 20 53 44 4b 20 6f  the KitDLL SDK o
1d80: 6e 65 20 77 6f 75 6c 64 20 74 79 70 69 63 61 6c  ne would typical
1d90: 6c 79 20 64 6f 0a 73 6f 6d 65 74 68 69 6e 67 20  ly do.something 
1da0: 6c 69 6b 65 3a 0a 09 31 2e 20 43 6f 6d 70 69 6c  like:..1. Compil
1db0: 65 20 4b 69 74 44 4c 4c 20 28 6d 61 79 20 62 65  e KitDLL (may be
1dc0: 20 6f 6d 69 74 74 65 64 20 69 66 20 74 68 65 20   omitted if the 
1dd0: 4b 69 74 44 4c 4c 20 53 44 4b 20 69 73 20 61 6c  KitDLL SDK is al
1de0: 72 65 61 64 79 0a 09 20 20 20 61 76 61 69 6c 61  ready..   availa
1df0: 62 6c 65 29 0a 09 09 61 2e 20 24 20 4b 49 54 43  ble)...a. $ KITC
1e00: 52 45 41 54 4f 52 5f 50 4b 47 53 3d 27 74 6b 20  REATOR_PKGS='tk 
1e10: 69 74 63 6c 20 6b 69 74 64 6c 6c 27 0a 09 09 62  itcl kitdll'...b
1e20: 2e 20 24 20 65 78 70 6f 72 74 20 4b 49 54 43 52  . $ export KITCR
1e30: 45 41 54 4f 52 5f 50 4b 47 53 0a 09 09 63 2e 20  EATOR_PKGS...c. 
1e40: 24 20 2e 2f 6b 69 74 63 72 65 61 74 6f 72 0a 09  $ ./kitcreator..
1e50: 32 2e 20 43 6f 6d 70 69 6c 65 20 74 68 65 20 45  2. Compile the E
1e60: 78 74 65 6e 73 69 6f 6e 0a 09 09 61 2e 20 24 20  xtension...a. $ 
1e70: 74 61 72 20 2d 78 66 20 2f 70 61 74 68 2f 74 6f  tar -xf /path/to
1e80: 2f 6c 69 62 74 63 6c 6b 69 74 2d 73 64 6b 2d 38  /libtclkit-sdk-8
1e90: 2e 34 2e 31 39 2e 74 61 72 2e 67 7a 0a 09 09 62  .4.19.tar.gz...b
1ea0: 2e 20 24 20 54 43 4c 4b 49 54 5f 53 44 4b 5f 44  . $ TCLKIT_SDK_D
1eb0: 49 52 3d 22 24 28 70 77 64 29 2f 6c 69 62 74 63  IR="$(pwd)/libtc
1ec0: 6c 6b 69 74 2d 73 64 6b 2d 38 2e 34 2e 31 39 22  lkit-sdk-8.4.19"
1ed0: 0a 09 09 63 2e 20 24 20 65 78 70 6f 72 74 20 54  ...c. $ export T
1ee0: 43 4c 4b 49 54 5f 53 44 4b 5f 44 49 52 0a 09 09  CLKIT_SDK_DIR...
1ef0: 64 2e 20 24 20 2e 2f 63 6f 6e 66 69 67 75 72 65  d. $ ./configure
1f00: 20 2d 2d 77 69 74 68 2d 74 63 6c 3d 22 24 7b 54   --with-tcl="${T
1f10: 43 4c 4b 49 54 5f 53 44 4b 5f 44 49 52 7d 2f 6c  CLKIT_SDK_DIR}/l
1f20: 69 62 22 0a 09 09 65 2e 20 24 20 6d 61 6b 65 0a  ib"...e. $ make.
1f30: 0a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .---------------
1f40: 2d 2d 2d 2d 0a 4d 65 74 68 6f 64 20 6f 66 20 4f  ----.Method of O
1f50: 70 65 72 61 74 69 6f 6e 0a 2d 2d 2d 2d 2d 2d 2d  peration.-------
1f60: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 53 75 6d  ------------.Sum
1f70: 6d 61 72 79 3a 0a 09 31 2e 20 22 6b 69 74 63 72  mary:..1. "kitcr
1f80: 65 61 74 6f 72 22 20 63 61 6c 6c 73 20 2a 2f 62  eator" calls */b
1f90: 75 69 6c 64 2e 73 68 0a 09 32 2e 20 2a 2f 62 75  uild.sh..2. */bu
1fa0: 69 6c 64 2e 73 68 20 64 6f 77 6e 6c 6f 61 64 73  ild.sh downloads
1fb0: 20 61 6e 64 20 63 6f 6d 70 69 6c 65 73 20 61 70   and compiles ap
1fc0: 70 72 6f 70 72 69 61 74 65 20 73 6f 66 74 77 61  propriate softwa
1fd0: 72 65 0a 09 33 2e 20 2a 2f 62 75 69 6c 64 2e 73  re..3. */build.s
1fe0: 68 20 69 6e 73 74 61 6c 6c 73 20 73 6f 66 74 77  h installs softw
1ff0: 61 72 65 20 69 6e 74 6f 20 22 69 6e 73 74 22 20  are into "inst" 
2000: 28 72 75 6e 2d 74 69 6d 65 20 2b 20 63 6f 6d 70  (run-time + comp
2010: 69 6c 65 2d 74 69 6d 65 29 0a 09 34 2e 20 2a 2f  ile-time)..4. */
2020: 62 75 69 6c 64 2e 73 68 20 69 6e 73 74 61 6c 6c  build.sh install
2030: 73 20 72 75 6e 2d 74 69 6d 65 20 73 6f 66 74 77  s run-time softw
2040: 61 72 65 20 69 6e 74 6f 20 22 6f 75 74 22 2c 20  are into "out", 
2050: 74 68 69 73 20 77 69 6c 6c 20 62 65 0a 09 20 20  this will be..  
2060: 20 69 6e 63 6c 75 64 65 64 20 69 6e 20 74 68 65   included in the
2070: 20 54 63 6c 6b 69 74 20 61 73 20 69 66 20 69 74   Tclkit as if it
2080: 20 77 65 72 65 20 74 68 65 20 72 6f 6f 74 20 64   were the root d
2090: 69 72 65 63 74 6f 72 79 20 6f 66 20 74 68 65 0a  irectory of the.
20a0: 09 20 20 20 54 63 6c 6b 69 74 20 28 63 6f 6d 62  .   Tclkit (comb
20b0: 69 6e 65 64 20 77 69 74 68 20 6f 74 68 65 72 20  ined with other 
20c0: 22 6f 75 74 22 20 64 69 72 65 63 74 6f 72 69 65  "out" directorie
20d0: 73 29 0a 09 35 2e 20 6b 69 74 73 68 2f 62 75 69  s)..5. kitsh/bui
20e0: 6c 64 2e 73 68 20 63 6f 6d 70 69 6c 65 73 20 61  ld.sh compiles a
20f0: 20 22 6d 61 69 6e 22 20 66 75 6e 63 74 69 6f 6e   "main" function
2100: 20 61 6e 64 20 6c 69 6e 6b 73 20 61 6c 6c 20 74   and links all t
2110: 68 65 20 62 75 69 6c 74 0a 09 20 20 20 6c 69 62  he built..   lib
2120: 72 61 72 69 65 73 20 74 6f 67 65 74 68 65 72 20  raries together 
2130: 69 6e 74 6f 20 61 6e 20 65 78 65 63 75 74 61 62  into an executab
2140: 6c 65 0a 09 36 2e 20 6b 69 74 73 68 2f 62 75 69  le..6. kitsh/bui
2150: 6c 64 2e 73 68 20 63 6f 6d 62 69 6e 65 73 20 61  ld.sh combines a
2160: 6c 6c 20 74 68 65 20 22 6f 75 74 22 20 64 69 72  ll the "out" dir
2170: 65 63 74 6f 72 69 65 73 20 69 6e 74 6f 20 6f 6e  ectories into on
2180: 65 0a 09 37 2e 20 6b 69 74 73 68 2f 62 75 69 6c  e..7. kitsh/buil
2190: 64 2e 73 68 20 63 72 65 61 74 65 73 20 61 20 4d  d.sh creates a M
21a0: 65 74 61 6b 69 74 20 6f 72 20 5a 69 70 20 64 61  etakit or Zip da
21b0: 74 61 62 61 73 65 20 66 72 6f 6d 20 74 68 65 20  tabase from the 
21c0: 63 6f 6d 62 69 6e 65 64 0a 09 20 20 20 64 69 72  combined..   dir
21d0: 65 63 74 6f 72 69 65 73 20 61 6e 64 20 61 70 70  ectories and app
21e0: 65 6e 64 73 20 74 68 61 74 20 74 6f 20 74 68 65  ends that to the
21f0: 20 63 6f 6d 70 69 6c 65 64 20 65 78 65 63 75 74   compiled execut
2200: 61 62 6c 65 20 75 73 69 6e 67 3a 0a 09 09 61 2e  able using:...a.
2210: 20 41 20 54 63 6c 6b 69 74 20 66 6f 75 6e 64 20   A Tclkit found 
2220: 69 6e 20 74 68 65 20 65 6e 76 69 72 6f 6e 6d 65  in the environme
2230: 6e 74 20 76 61 72 69 61 62 6c 65 20 22 54 43 4c  nt variable "TCL
2240: 4b 49 54 22 20 28 74 63 6c 6b 69 74 0a 09 09 20  KIT" (tclkit... 
2250: 20 20 69 66 20 75 6e 73 65 74 29 20 69 66 20 69    if unset) if i
2260: 74 20 69 73 20 66 75 6e 63 74 69 6f 6e 61 6c 3b  t is functional;
2270: 20 6f 72 0a 09 09 62 2e 20 54 68 65 20 62 75 69   or...b. The bui
2280: 6c 74 20 6b 69 74 20 69 74 73 65 6c 66 20 28 64  lt kit itself (d
2290: 6f 65 73 20 6e 6f 74 20 77 6f 72 6b 20 66 6f 72  oes not work for
22a0: 20 63 72 6f 73 73 2d 63 6f 6d 70 69 6c 69 6e 67   cross-compiling
22b0: 29 0a 0a 44 65 74 61 69 6c 73 3a 0a 09 54 68 65  )..Details:..The
22c0: 20 67 65 6e 65 72 61 6c 20 6d 65 63 68 61 6e 69   general mechani
22d0: 73 6d 20 74 68 61 74 20 65 6e 61 62 6c 65 73 20  sm that enables 
22e0: 61 20 54 63 6c 6b 69 74 20 74 6f 20 6f 70 65 72  a Tclkit to oper
22f0: 61 74 65 20 69 73 20 61 20 73 6d 61 6c 6c 20 54  ate is a small T
2300: 63 6c 0a 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f  cl.initializatio
2310: 6e 20 72 6f 75 74 69 6e 65 20 6c 69 6e 6b 65 64  n routine linked
2320: 20 73 74 61 74 69 63 61 6c 6c 79 20 74 6f 20 74   statically to t
2330: 68 65 20 63 6f 72 65 20 6c 69 62 72 61 72 69 65  he core librarie
2340: 73 20 6e 65 65 64 65 64 20 74 6f 0a 6f 70 65 72  s needed to.oper
2350: 61 74 65 20 61 20 54 63 6c 20 69 6e 74 65 72 70  ate a Tcl interp
2360: 72 65 74 65 72 2c 20 74 68 65 20 54 63 6c 20 56  reter, the Tcl V
2370: 46 53 20 4c 61 79 65 72 2c 20 61 6e 64 20 61 20  FS Layer, and a 
2380: 64 61 74 61 62 61 73 65 2d 62 61 63 6b 65 64 20  database-backed 
2390: 28 4d 65 74 61 6b 69 74 29 0a 56 69 72 74 75 61  (Metakit).Virtua
23a0: 6c 20 46 69 6c 65 20 53 79 73 74 65 6d 20 74 68  l File System th
23b0: 61 74 20 69 73 20 61 70 70 65 6e 64 65 64 20 74  at is appended t
23c0: 6f 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65  o the end of the
23d0: 20 65 78 65 63 75 74 61 62 6c 65 2e 0a 0a 54 68   executable...Th
23e0: 69 73 20 70 72 6f 6a 65 63 74 20 62 72 69 6e 67  is project bring
23f0: 73 20 74 6f 67 65 74 68 65 72 20 61 6c 6c 20 6f  s together all o
2400: 66 20 74 68 65 20 72 65 71 75 69 72 65 64 20 70  f the required p
2410: 69 65 63 65 73 2c 20 70 6c 75 73 20 73 6f 6d 65  ieces, plus some
2420: 20 61 64 64 69 74 69 6f 6e 61 6c 0a 70 69 65 63   additional.piec
2430: 65 73 20 74 68 61 74 20 77 65 72 65 20 66 6f 75  es that were fou
2440: 6e 64 20 69 6e 20 74 68 65 20 6f 72 69 67 69 6e  nd in the origin
2450: 61 6c 20 54 63 6c 6b 69 74 3a 0a 09 31 2e 20 54  al Tclkit:..1. T
2460: 6b 20 28 64 79 6e 61 6d 69 63 61 6c 6c 79 20 6c  k (dynamically l
2470: 69 6e 6b 65 64 29 0a 09 32 2e 20 49 74 63 6c 20  inked)..2. Itcl 
2480: 28 64 79 6e 61 6d 69 63 61 6c 6c 79 20 6c 69 6e  (dynamically lin
2490: 6b 65 64 29 0a 0a 54 68 65 20 73 6f 75 72 63 65  ked)..The source
24a0: 20 63 6f 64 65 20 66 6f 72 20 74 68 65 73 65 20   code for these 
24b0: 70 69 65 63 65 73 20 61 72 65 20 64 6f 77 6e 6c  pieces are downl
24c0: 6f 61 64 65 64 2c 20 63 6f 6d 70 69 6c 65 64 2c  oaded, compiled,
24d0: 20 61 6e 64 20 6c 69 6e 6b 65 64 2c 20 61 6e 64   and linked, and
24e0: 20 74 68 65 0a 64 61 74 61 62 61 73 65 20 63 6f   the.database co
24f0: 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 61 70 70  ntaining the app
2500: 72 6f 70 72 69 61 74 65 20 66 69 6c 65 73 79 73  ropriate filesys
2510: 74 65 6d 20 64 61 74 61 20 69 73 20 63 72 65 61  tem data is crea
2520: 74 65 64 2e 20 20 57 68 61 74 20 73 65 74 73 0a  ted.  What sets.
2530: 74 68 69 73 20 70 72 6f 6a 65 63 74 20 61 70 61  this project apa
2540: 72 74 20 66 72 6f 6d 20 6f 74 68 65 72 20 73 69  rt from other si
2550: 6d 69 6c 61 72 20 70 72 6f 6a 65 63 74 73 20 69  milar projects i
2560: 73 20 74 68 61 74 3a 0a 09 31 2e 20 49 74 20 61  s that:..1. It a
2570: 74 74 65 6d 70 74 73 20 74 6f 20 62 65 20 6d 6f  ttempts to be mo
2580: 64 75 6c 61 72 3b 0a 09 32 2e 20 49 74 20 73 75  dular;..2. It su
2590: 70 70 6f 72 74 73 20 63 72 6f 73 73 2d 63 6f 6d  pports cross-com
25a0: 70 69 6c 69 6e 67 3b 0a 09 33 2e 20 49 74 20 64  piling;..3. It d
25b0: 6f 77 6e 6c 6f 61 64 73 20 74 68 65 20 73 6f 75  ownloads the sou
25c0: 72 63 65 20 66 72 6f 6d 20 74 68 65 69 72 20 6f  rce from their o
25d0: 72 69 67 69 6e 61 6c 20 72 65 70 6f 73 69 74 6f  riginal reposito
25e0: 72 69 65 73 3b 0a 09 34 2e 20 49 74 20 61 6c 6c  ries;..4. It all
25f0: 6f 77 73 20 79 6f 75 20 74 6f 20 73 70 65 63 69  ows you to speci
2600: 66 79 20 61 6e 20 61 72 62 69 74 72 61 72 79 20  fy an arbitrary 
2610: 76 65 72 73 69 6f 6e 20 6f 66 20 54 63 6c 20 28  version of Tcl (
2620: 69 6e 63 6c 75 64 69 6e 67 0a 09 20 20 20 43 56  including..   CV
2630: 53 29 3b 20 61 6e 64 0a 09 35 2e 20 49 74 20 75  S); and..5. It u
2640: 73 65 73 20 47 4e 55 20 41 75 74 6f 63 6f 6e 66  ses GNU Autoconf
2650: 20 73 63 72 69 70 74 73 20 66 6f 72 20 63 6f 6d   scripts for com
2660: 70 69 6c 69 6e 67 20 74 68 65 20 70 61 72 74 20  piling the part 
2670: 6f 66 20 74 68 65 20 54 63 6c 6b 69 74 0a 09 20  of the Tclkit.. 
2680: 20 20 74 68 61 74 20 62 72 69 6e 67 73 20 74 68    that brings th
2690: 65 20 77 68 6f 6c 65 20 74 68 69 6e 67 20 74 6f  e whole thing to
26a0: 67 65 74 68 65 72 20 28 74 68 65 20 4b 69 74 73  gether (the Kits
26b0: 68 29 0a 0a 54 6f 20 61 63 63 6f 6d 70 6c 69 73  h)..To accomplis
26c0: 68 20 74 68 65 73 65 20 67 6f 61 6c 73 20 74 68  h these goals th
26d0: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 6d 65 63 68  e following mech
26e0: 61 6e 69 73 6d 73 20 61 72 65 20 69 6e 20 70 6c  anisms are in pl
26f0: 61 63 65 3a 0a 09 31 2e 20 54 68 65 20 74 6f 70  ace:..1. The top
2700: 2d 6c 65 76 65 6c 20 22 6b 69 74 63 72 65 61 74  -level "kitcreat
2710: 6f 72 22 20 73 63 72 69 70 74 3b 20 61 6e 64 0a  or" script; and.
2720: 09 32 2e 20 50 65 72 2d 70 72 6f 6a 65 63 74 20  .2. Per-project 
2730: 73 75 62 64 69 72 65 63 74 6f 72 69 65 73 2c 20  subdirectories, 
2740: 65 61 63 68 20 63 6f 6e 74 61 69 6e 69 6e 67 20  each containing 
2750: 61 20 22 62 75 69 6c 64 2e 73 68 22 20 73 63 72  a "build.sh" scr
2760: 69 70 74 0a 0a 54 68 65 20 74 6f 70 2d 6c 65 76  ipt..The top-lev
2770: 65 6c 20 22 6b 69 74 63 72 65 61 74 6f 72 22 20  el "kitcreator" 
2780: 73 63 72 69 70 74 20 69 73 20 76 65 72 79 20 73  script is very s
2790: 69 6d 70 6c 65 2e 20 20 49 74 73 20 6f 6e 6c 79  imple.  Its only
27a0: 20 6a 6f 62 20 69 73 20 74 6f 0a 69 6e 74 65 72   job is to.inter
27b0: 70 72 65 74 20 63 6f 6d 6d 61 6e 64 20 6c 69 6e  pret command lin
27c0: 65 20 61 72 67 75 6d 65 6e 74 73 2c 20 61 6e 64  e arguments, and
27d0: 20 63 61 6c 6c 20 74 68 65 20 70 65 72 2d 70 72   call the per-pr
27e0: 6f 6a 65 63 74 20 22 62 75 69 6c 64 2e 73 68 22  oject "build.sh"
27f0: 20 73 63 72 69 70 74 73 2e 0a 46 6f 72 20 74 68   scripts..For th
2800: 65 20 22 74 63 6c 22 20 70 72 6f 6a 65 63 74 20  e "tcl" project 
2810: 69 74 20 61 6c 73 6f 20 66 69 6e 64 73 20 74 68  it also finds th
2820: 65 20 61 70 70 72 6f 70 72 69 61 74 65 20 22 74  e appropriate "t
2830: 63 6c 43 6f 6e 66 69 67 2e 73 68 22 20 28 61 6e  clConfig.sh" (an
2840: 64 20 73 74 6f 72 65 73 0a 74 68 69 73 20 70 61  d stores.this pa
2850: 74 68 20 69 6e 20 54 43 4c 43 4f 4e 46 49 47 44  th in TCLCONFIGD
2860: 49 52 29 20 74 6f 20 65 6e 61 62 6c 65 20 73 75  IR) to enable su
2870: 62 73 65 71 75 65 6e 74 20 62 75 69 6c 64 20 73  bsequent build s
2880: 63 72 69 70 74 73 20 74 6f 20 66 69 6e 64 20 74  cripts to find t
2890: 68 65 0a 61 70 70 72 6f 70 72 69 61 74 65 20 54  he.appropriate T
28a0: 63 6c 20 74 6f 20 6c 69 6e 6b 20 61 67 61 69 6e  cl to link again
28b0: 73 74 2e 0a 0a 54 68 65 20 70 65 72 2d 70 72 6f  st...The per-pro
28c0: 6a 65 63 74 20 22 62 75 69 6c 64 2e 73 68 22 20  ject "build.sh" 
28d0: 73 63 72 69 70 74 73 20 61 72 65 20 65 6e 74 69  scripts are enti
28e0: 72 65 6c 79 20 61 75 74 6f 6e 6f 6d 6f 75 73 2e  rely autonomous.
28f0: 20 20 54 68 65 79 20 61 72 65 0a 72 65 73 70 6f    They are.respo
2900: 6e 73 69 62 6c 65 20 66 6f 72 20 64 6f 77 6e 6c  nsible for downl
2910: 6f 61 64 69 6e 67 20 74 68 65 20 73 6f 75 72 63  oading the sourc
2920: 65 20 63 6f 64 65 20 66 6f 72 20 74 68 65 20 61  e code for the a
2930: 70 70 72 6f 70 72 69 61 74 65 20 76 65 72 73 69  ppropriate versi
2940: 6f 6e 20 74 68 61 74 0a 77 69 6c 6c 20 63 6f 6d  on that.will com
2950: 70 69 6c 65 20 61 6e 64 20 6c 69 6e 6b 20 61 67  pile and link ag
2960: 61 69 6e 73 74 20 74 68 65 20 63 75 72 72 65 6e  ainst the curren
2970: 74 20 76 65 72 73 69 6f 6e 20 6f 66 20 54 63 6c  t version of Tcl
2980: 20 28 75 73 65 72 20 72 65 71 75 65 73 74 65 64   (user requested
2990: 0a 76 65 72 73 69 6f 6e 20 63 61 6e 20 62 65 20  .version can be 
29a0: 66 6f 75 6e 64 20 69 6e 20 22 54 43 4c 56 45 52  found in "TCLVER
29b0: 53 22 2c 20 77 68 69 6c 65 20 74 68 65 20 61 63  S", while the ac
29c0: 74 75 61 6c 20 76 65 72 73 69 6f 6e 20 6d 75 73  tual version mus
29d0: 74 20 62 65 20 72 65 71 75 65 73 74 65 64 0a 66  t be requested.f
29e0: 72 6f 6d 20 74 68 65 20 22 74 63 6c 43 6f 6e 66  rom the "tclConf
29f0: 69 67 2e 73 68 22 20 73 63 72 69 70 74 29 2c 20  ig.sh" script), 
2a00: 63 6f 6d 70 69 6c 69 6e 67 20 69 74 2c 20 69 6e  compiling it, in
2a10: 73 74 61 6c 6c 69 6e 67 20 61 20 66 75 6e 63 74  stalling a funct
2a20: 69 6f 6e 61 6c 20 63 6f 70 79 0a 69 6e 74 6f 20  ional copy.into 
2a30: 74 68 65 20 70 65 72 2d 70 72 6f 6a 65 63 74 20  the per-project 
2a40: 22 69 6e 73 74 22 20 64 69 72 65 63 74 6f 72 79  "inst" directory
2a50: 2c 20 61 6e 64 20 69 6e 73 74 61 6c 6c 69 6e 67  , and installing
2a60: 20 61 6e 79 74 68 69 6e 67 20 74 68 61 74 20 6e   anything that n
2a70: 65 65 64 73 20 74 6f 0a 62 65 20 69 6e 20 74 68  eeds to.be in th
2a80: 65 20 54 63 6c 6b 69 74 27 73 20 56 46 53 20 72  e Tclkit's VFS r
2a90: 6f 6f 74 20 69 6e 74 6f 20 74 68 65 20 70 65 72  oot into the per
2aa0: 2d 70 72 6f 6a 65 63 74 20 22 6f 75 74 22 20 64  -project "out" d
2ab0: 69 72 65 63 74 6f 72 79 2e 0a 0a 41 6e 79 20 61  irectory...Any a
2ac0: 64 64 69 74 69 6f 6e 61 6c 20 70 72 6f 6a 65 63  dditional projec
2ad0: 74 73 20 63 61 6e 20 62 65 20 69 6e 63 6c 75 64  ts can be includ
2ae0: 65 64 20 73 69 6d 70 6c 79 20 62 79 20 63 72 65  ed simply by cre
2af0: 61 74 69 6e 67 20 74 68 65 20 61 70 70 72 6f 70  ating the approp
2b00: 72 69 61 74 65 0a 64 69 72 65 63 74 6f 72 79 20  riate.directory 
2b10: 69 6e 20 74 68 65 20 73 61 6d 65 20 64 69 72 65  in the same dire
2b20: 63 74 6f 72 79 20 61 73 20 74 68 65 20 22 6b 69  ctory as the "ki
2b30: 74 63 72 65 61 74 6f 72 22 20 73 63 72 69 70 74  tcreator" script
2b40: 2c 20 63 72 65 61 74 69 6e 67 20 61 0a 22 62 75  , creating a."bu
2b50: 69 6c 64 2e 73 68 22 20 73 63 72 69 70 74 20 69  ild.sh" script i
2b60: 6e 20 74 68 61 74 20 64 69 72 65 63 74 6f 72 79  n that directory
2b70: 20 74 68 61 74 20 66 6f 6c 6c 6f 77 73 20 74 68   that follows th
2b80: 65 20 61 62 6f 76 65 20 70 72 6f 63 65 64 75 72  e above procedur
2b90: 65 2c 20 61 6e 64 20 74 68 65 6e 0a 72 65 66 65  e, and then.refe
2ba0: 72 65 6e 63 69 6e 67 20 74 68 61 74 20 64 69 72  rencing that dir
2bb0: 65 63 74 6f 72 79 20 69 6e 20 22 4b 49 54 43 52  ectory in "KITCR
2bc0: 45 41 54 4f 52 5f 50 4b 47 53 22 20 66 6f 72 20  EATOR_PKGS" for 
2bd0: 74 68 65 20 22 6b 69 74 63 72 65 61 74 6f 72 22  the "kitcreator"
2be0: 20 69 6e 76 6f 63 61 74 69 6f 6e 2e 0a 49 6e 20   invocation..In 
2bf0: 74 68 69 73 20 77 61 79 20 4b 69 74 43 72 65 61  this way KitCrea
2c00: 74 6f 72 20 69 73 20 22 70 6c 75 67 67 61 62 6c  tor is "pluggabl
2c10: 65 22 2e 20 20 49 6e 63 6c 75 64 65 64 20 70 61  e".  Included pa
2c20: 63 6b 61 67 65 73 20 6d 61 79 20 62 65 20 65 69  ckages may be ei
2c30: 74 68 65 72 0a 73 74 61 74 69 63 61 6c 6c 79 20  ther.statically 
2c40: 6f 72 20 64 79 6e 61 6d 69 63 61 6c 6c 79 20 6c  or dynamically l
2c50: 69 6e 6b 65 64 2e 20 20 49 66 20 69 74 20 69 73  inked.  If it is
2c60: 20 73 74 61 74 69 63 61 6c 6c 79 20 6c 69 6e 6b   statically link
2c70: 65 64 20 74 68 65 6e 20 74 68 65 20 6d 6f 64 75  ed then the modu
2c80: 6c 65 0a 6e 61 6d 65 20 6d 75 73 74 20 62 65 20  le.name must be 
2c90: 74 68 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20  the name of the 
2ca0: 64 69 72 65 63 74 6f 72 79 20 2d 2d 20 74 68 61  directory -- tha
2cb0: 74 20 69 73 2c 20 69 66 20 74 68 65 20 64 69 72  t is, if the dir
2cc0: 65 63 74 6f 72 79 20 77 65 72 65 20 22 66 6f 6f  ectory were "foo
2cd0: 22 2c 0a 4b 69 74 43 72 65 61 74 6f 72 20 77 69  ",.KitCreator wi
2ce0: 6c 6c 20 65 78 70 65 63 74 20 74 6f 20 69 6e 69  ll expect to ini
2cf0: 74 69 61 6c 69 7a 65 20 74 68 65 20 6d 6f 64 75  tialize the modu
2d00: 6c 65 20 73 74 61 74 69 63 61 6c 6c 79 20 75 73  le statically us
2d10: 69 6e 67 20 46 6f 6f 5f 49 6e 69 74 28 29 2e 0a  ing Foo_Init()..
2d20: 0a 54 68 65 20 65 78 63 65 70 74 69 6f 6e 20 74  .The exception t
2d30: 6f 20 74 68 69 73 20 69 73 20 74 68 65 20 22 6b  o this is the "k
2d40: 69 74 73 68 22 20 70 72 6f 6a 65 63 74 2e 20 20  itsh" project.  
2d50: 49 74 20 69 73 20 74 68 65 20 67 6c 75 65 20 74  It is the glue t
2d60: 68 61 74 20 62 69 6e 64 73 20 61 6c 6c 0a 74 68  hat binds all.th
2d70: 65 20 69 6e 64 69 76 69 64 75 61 6c 20 70 72 6f  e individual pro
2d80: 6a 65 63 74 73 20 74 6f 67 65 74 68 65 72 20 69  jects together i
2d90: 6e 74 6f 20 61 20 73 69 6e 67 6c 65 20 65 78 65  nto a single exe
2da0: 63 75 74 61 62 6c 65 2e 20 20 49 74 73 20 62 75  cutable.  Its bu
2db0: 69 6c 64 20 73 63 72 69 70 74 0a 64 6f 65 73 20  ild script.does 
2dc0: 6e 6f 74 20 63 72 65 61 74 65 20 61 6e 20 22 69  not create an "i
2dd0: 6e 73 74 22 20 6f 72 20 61 6e 20 22 6f 75 74 22  nst" or an "out"
2de0: 20 64 69 72 65 63 74 6f 72 79 20 62 65 63 61 75   directory becau
2df0: 73 65 20 69 74 20 69 73 20 6e 6f 74 20 61 20 6c  se it is not a l
2e00: 69 62 72 61 72 79 2e 0a 49 6e 73 74 65 61 64 2c  ibrary..Instead,
2e10: 20 69 74 20 63 6f 6c 6c 65 63 74 73 20 61 6c 6c   it collects all
2e20: 20 74 68 65 20 6f 74 68 65 72 20 70 72 6f 6a 65   the other proje
2e30: 63 74 27 73 20 22 6f 75 74 22 20 64 69 72 65 63  ct's "out" direc
2e40: 74 6f 72 69 65 73 20 69 6e 74 6f 20 61 20 73 69  tories into a si
2e50: 6e 67 6c 65 0a 64 69 72 65 63 74 6f 72 79 20 28  ngle.directory (
2e60: 73 74 61 72 70 61 63 6b 2e 76 66 73 29 2c 20 61  starpack.vfs), a
2e70: 73 20 77 65 6c 6c 20 61 20 73 74 61 74 69 63 20  s well a static 
2e80: 66 69 6c 65 20 28 62 6f 6f 74 2e 74 63 6c 29 2e  file (boot.tcl).
2e90: 20 49 74 20 74 68 65 6e 20 63 6f 6d 70 69 6c 65   It then compile
2ea0: 73 0a 74 68 65 20 73 6f 75 72 63 65 20 63 6f 64  s.the source cod
2eb0: 65 2c 20 61 6e 64 20 74 68 65 6e 20 69 6e 73 74  e, and then inst
2ec0: 61 6c 6c 73 20 74 68 65 20 56 46 53 20 6f 6e 74  alls the VFS ont
2ed0: 6f 20 74 68 65 20 72 65 73 75 6c 74 69 6e 67 20  o the resulting 
2ee0: 65 78 65 63 75 74 61 62 6c 65 2e 0a 54 68 65 20  executable..The 
2ef0: 56 46 53 20 69 73 20 63 72 65 61 74 65 64 20 62  VFS is created b
2f00: 79 20 74 68 65 20 22 69 6e 73 74 61 6c 6c 76 66  y the "installvf
2f10: 73 2e 74 63 6c 22 20 73 63 72 69 70 74 20 66 6f  s.tcl" script fo
2f20: 72 20 4b 69 74 73 68 2e 20 20 46 6f 72 20 4b 69  r Kitsh.  For Ki
2f30: 74 44 4c 4c 20 74 68 65 0a 56 46 53 20 69 73 20  tDLL the.VFS is 
2f40: 63 72 65 61 74 65 64 20 62 79 20 22 64 69 72 32  created by "dir2
2f50: 63 2e 74 63 6c 22 2e 0a 0a 49 66 20 74 68 65 20  c.tcl"...If the 
2f60: 22 6d 6b 34 74 63 6c 22 20 70 72 6f 6a 65 63 74  "mk4tcl" project
2f70: 20 66 61 69 6c 73 20 74 6f 20 62 75 69 6c 64 20   fails to build 
2f80: 28 6f 72 20 69 73 20 6e 6f 74 20 72 65 71 75 65  (or is not reque
2f90: 73 74 65 64 20 74 6f 20 62 65 20 62 75 69 6c 74  sted to be built
2fa0: 29 2c 0a 74 68 65 20 72 65 73 74 20 6f 66 20 74  ),.the rest of t
2fb0: 68 65 20 70 72 6f 6a 65 63 74 20 77 69 6c 6c 20  he project will 
2fc0: 62 65 20 62 75 69 6c 74 20 75 73 69 6e 67 20 7a  be built using z
2fd0: 69 70 20 66 69 6c 65 73 20 69 6e 73 74 65 61 64  ip files instead
2fe0: 20 6f 66 20 4d 65 74 61 6b 69 74 0a 64 61 74 61   of Metakit.data
2ff0: 62 61 73 65 73 2e 0a 0a 54 6f 20 63 72 65 61 74  bases...To creat
3000: 65 20 74 68 65 20 73 74 6f 72 61 67 65 20 64 61  e the storage da
3010: 74 61 62 61 73 65 2c 20 6f 6e 65 20 6f 66 20 74  tabase, one of t
3020: 77 6f 20 54 63 6c 6b 69 74 73 20 69 73 20 75 73  wo Tclkits is us
3030: 65 64 20 28 74 72 69 65 64 20 69 6e 20 74 68 69  ed (tried in thi
3040: 73 0a 6f 72 64 65 72 29 3a 0a 09 31 2e 20 54 68  s.order):..1. Th
3050: 65 20 54 63 6c 6b 69 74 20 73 70 65 63 69 66 69  e Tclkit specifi
3060: 65 64 20 62 79 20 74 68 65 20 54 43 4c 4b 49 54  ed by the TCLKIT
3070: 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 76 61 72   environment var
3080: 69 61 62 6c 65 20 28 6f 72 0a 09 20 20 20 22 74  iable (or..   "t
3090: 63 6c 6b 69 74 22 20 69 66 20 74 68 61 74 20 76  clkit" if that v
30a0: 61 72 69 61 62 6c 65 20 69 73 20 6e 6f 74 20 73  ariable is not s
30b0: 65 74 29 20 69 66 20 69 74 20 69 73 20 66 75 6e  et) if it is fun
30c0: 63 74 69 6f 6e 61 6c 3b 20 6f 72 0a 09 32 2e 20  ctional; or..2. 
30d0: 54 68 65 20 62 75 69 6c 74 20 54 63 6c 6b 69 74  The built Tclkit
30e0: 20 69 74 73 65 6c 66 0a 0a 54 68 65 20 73 65 63   itself..The sec
30f0: 6f 6e 64 20 6d 65 74 68 6f 64 20 77 69 6c 6c 20  ond method will 
3100: 6e 6f 74 20 77 6f 72 6b 20 69 66 20 74 68 65 20  not work if the 
3110: 62 75 69 6c 74 20 54 63 6c 6b 69 74 20 69 73 20  built Tclkit is 
3120: 6e 6f 74 20 65 78 65 63 75 74 61 62 6c 65 20 6f  not executable o
3130: 6e 20 74 68 65 0a 63 75 72 72 65 6e 74 20 70 6c  n the.current pl
3140: 61 74 66 6f 72 6d 20 28 69 2e 65 2e 2c 20 69 6e  atform (i.e., in
3150: 20 74 68 65 20 63 61 73 65 20 6f 66 20 63 72 6f   the case of cro
3160: 73 73 2d 63 6f 6d 70 69 6c 61 74 69 6f 6e 29 20  ss-compilation) 
3170: 61 6e 64 20 73 6f 20 69 74 20 6d 61 79 20 62 65  and so it may be
3180: 0a 6e 65 63 65 73 73 61 72 79 20 74 6f 20 62 6f  .necessary to bo
3190: 6f 74 73 74 72 61 70 20 61 20 72 75 6e 6e 61 62  otstrap a runnab
31a0: 6c 65 20 54 63 6c 6b 69 74 20 66 69 72 73 74 2e  le Tclkit first.
31b0: 0a 0a 4b 69 74 44 4c 4c 20 6d 6f 75 6e 74 73 20  ..KitDLL mounts 
31c0: 74 68 65 20 56 46 53 20 66 6f 72 20 65 76 65 72  the VFS for ever
31d0: 79 20 69 6e 74 65 72 70 72 65 74 65 72 20 74 68  y interpreter th
31e0: 61 74 20 63 61 6c 6c 73 20 54 63 6c 5f 49 6e 69  at calls Tcl_Ini
31f0: 74 28 29 2e 20 20 54 68 65 20 73 79 73 74 65 6d  t().  The system
3200: 0a 56 46 53 20 74 68 61 74 20 69 73 20 63 72 65  .VFS that is cre
3210: 61 74 65 64 20 61 74 20 62 75 69 6c 64 20 74 69  ated at build ti
3220: 6d 65 20 69 73 20 6d 6f 75 6e 74 65 64 20 61 74  me is mounted at
3230: 20 2f 2e 4b 49 54 44 4c 4c 5f 54 43 4c 2e 20 20   /.KITDLL_TCL.  
3240: 41 64 64 69 74 69 6f 6e 61 6c 6c 79 2c 0a 69 66  Additionally,.if
3250: 20 74 68 65 72 65 20 69 73 20 61 20 5a 49 50 20   there is a ZIP 
3260: 66 69 6c 65 20 61 70 70 65 6e 64 65 64 20 74 6f  file appended to
3270: 20 74 68 65 20 44 4c 4c 20 69 74 20 77 69 6c 6c   the DLL it will
3280: 20 62 65 20 6d 6f 75 6e 74 65 64 20 61 74 20 2f   be mounted at /
3290: 2e 4b 49 54 44 4c 4c 5f 55 53 45 52 0a 61 6e 64  .KITDLL_USER.and
32a0: 20 69 66 20 74 68 65 72 65 20 69 73 20 61 20 5a   if there is a Z
32b0: 49 50 20 66 69 6c 65 20 61 70 70 65 6e 64 65 64  IP file appended
32c0: 20 74 6f 20 74 68 65 20 65 78 65 63 75 74 61 62   to the executab
32d0: 6c 65 20 69 74 20 77 69 6c 6c 20 62 65 20 6d 6f  le it will be mo
32e0: 75 6e 74 65 64 20 61 74 0a 2f 2e 4b 49 54 44 4c  unted at./.KITDL
32f0: 4c 5f 41 50 50 2e 20 20 41 6c 6c 20 56 46 53 65  L_APP.  All VFSe
3300: 73 20 74 68 61 74 20 61 72 65 20 6d 6f 75 6e 74  s that are mount
3310: 65 64 20 68 61 76 65 20 74 68 65 20 22 6c 69 62  ed have the "lib
3320: 22 20 73 75 62 2d 64 69 72 65 63 74 6f 72 79 20  " sub-directory 
3330: 61 70 70 65 6e 64 65 64 0a 74 6f 20 74 68 65 20  appended.to the 
3340: 69 6e 74 65 72 70 72 65 74 65 72 73 20 22 61 75  interpreters "au
3350: 74 6f 5f 70 61 74 68 22 20 76 61 72 69 61 62 6c  to_path" variabl
3360: 65 2e 0a                                         e..