Hex Artifact Content

Artifact 8ae30752c42de42d433734c8a6c7a88ec895a81e:


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 09 41 6c 73 6f  l thread....Also
1350: 2c 20 54 63 6c 4f 4f 20 69 73 20 72 65 6d 6f 76  , TclOO is remov
1360: 65 64 20 66 72 6f 6d 20 54 63 6c 20 38 2e 36 20  ed from Tcl 8.6 
1370: 66 6f 72 63 65 66 75 6c 6c 79 2e 0a 0a 0a 43 72  forcefully....Cr
1380: 6f 73 73 20 63 6f 6d 70 69 6c 69 6e 67 20 45 6e  oss compiling En
1390: 76 69 72 6f 6e 6d 65 6e 74 20 56 61 72 69 61 62  vironment Variab
13a0: 6c 65 73 3a 0a 0a 09 31 2e 20 43 43 20 20 0a 09  les:...1. CC  ..
13b0: 09 43 20 63 6f 6d 70 69 6c 65 72 20 20 20 65 2e  .C compiler   e.
13c0: 67 2e 20 69 36 38 36 2d 70 63 2d 6d 69 6e 67 77  g. i686-pc-mingw
13d0: 33 32 2d 67 63 63 0a 0a 09 32 2e 20 43 58 58 0a  32-gcc...2. CXX.
13e0: 09 09 43 2b 2b 20 63 6f 6d 70 69 6c 65 72 2e 20  ..C++ compiler. 
13f0: 20 52 65 71 75 69 72 65 64 20 69 66 20 79 6f 75   Required if you
1400: 20 77 61 6e 74 20 74 6f 20 75 73 65 20 6d 6b 34   want to use mk4
1410: 74 63 6c 2e 20 65 2e 67 2e 20 69 36 38 36 2d 70  tcl. e.g. i686-p
1420: 63 2d 6d 69 6e 67 77 33 32 2d 67 2b 2b 0a 09 09  c-mingw32-g++...
1430: 49 66 20 6e 6f 74 20 72 65 71 75 69 72 65 64 2c  If not required,
1440: 20 79 6f 75 20 63 61 6e 20 73 65 74 20 69 74 20   you can set it 
1450: 74 6f 20 74 68 65 20 73 74 72 69 6e 67 20 22 66  to the string "f
1460: 61 6c 73 65 22 0a 0a 09 33 2e 20 41 52 0a 09 09  alse"...3. AR...
1470: 4c 69 62 72 61 72 79 20 63 72 65 61 74 6f 72 20  Library creator 
1480: 65 2e 67 2e 20 69 36 38 36 2d 70 63 2d 6d 69 6e  e.g. i686-pc-min
1490: 67 77 33 32 2d 61 72 0a 0a 09 34 2e 20 52 41 4e  gw32-ar...4. RAN
14a0: 4c 49 42 0a 09 09 4c 69 62 72 61 72 79 20 70 6f  LIB...Library po
14b0: 73 74 20 70 72 6f 63 65 73 73 69 6e 67 20 65 78  st processing ex
14c0: 65 63 75 74 61 62 6c 65 20 65 2e 67 2e 20 69 36  ecutable e.g. i6
14d0: 38 36 2d 70 63 2d 6d 69 6e 67 77 33 32 2d 72 61  86-pc-mingw32-ra
14e0: 6e 6c 69 62 0a 0a 09 35 2e 20 53 54 52 49 50 0a  nlib...5. STRIP.
14f0: 09 09 45 78 65 63 75 74 61 62 6c 65 20 6e 61 6d  ..Executable nam
1500: 65 20 74 6f 20 73 74 72 69 70 20 62 69 6e 61 72  e to strip binar
1510: 69 65 73 20 65 2e 67 2e 20 69 36 38 36 2d 70 63  ies e.g. i686-pc
1520: 2d 6d 69 6e 67 77 33 32 2d 73 74 72 69 70 0a 0a  -mingw32-strip..
1530: 09 36 2e 20 4e 4d 0a 09 09 45 78 65 63 75 74 61  .6. NM...Executa
1540: 62 6c 65 20 75 73 65 64 20 74 6f 20 64 75 6d 70  ble used to dump
1550: 20 6e 61 6d 65 73 20 66 72 6f 6d 20 74 68 65 20   names from the 
1560: 6f 62 6a 65 63 74 73 20 20 65 2e 67 2e 20 69 36  objects  e.g. i6
1570: 38 36 2d 70 63 2d 6d 69 6e 67 77 33 32 2d 6e 6d  86-pc-mingw32-nm
1580: 0a 0a 09 37 2e 20 43 43 5f 46 4f 52 5f 42 55 49  ...7. CC_FOR_BUI
1590: 4c 44 2c 20 48 4f 53 54 5f 43 43 20 0a 09 09 53  LD, HOST_CC ...S
15a0: 65 74 20 74 68 69 73 20 74 6f 20 74 68 65 20 6e  et this to the n
15b0: 61 6d 65 20 6f 66 20 63 6f 6d 70 69 6c 65 72 20  ame of compiler 
15c0: 6f 6e 20 74 68 65 20 68 6f 73 74 20 6f 6e 20 77  on the host on w
15d0: 68 69 63 68 0a 09 09 74 68 65 20 63 72 6f 73 73  hich...the cross
15e0: 20 63 6f 6d 70 69 6c 61 74 69 6f 6e 20 69 73 20   compilation is 
15f0: 62 65 69 6e 67 20 72 75 6e 2e 0a 0a 4f 6e 20 57  being run...On W
1600: 69 6e 64 6f 77 73 20 77 65 20 61 6c 73 6f 20 6e  indows we also n
1610: 65 65 64 20 74 68 69 73 3a 0a 0a 09 31 2e 20 52  eed this:...1. R
1620: 43 0a 09 09 52 65 73 6f 75 72 63 65 20 63 6f 6d  C...Resource com
1630: 70 69 6c 65 72 20 3a 20 65 2e 67 2e 20 69 36 38  piler : e.g. i68
1640: 36 2d 70 63 2d 6d 69 6e 67 77 33 32 2d 77 69 6e  6-pc-mingw32-win
1650: 64 72 65 73 0a 0a 0a 4b 69 74 73 68 20 43 6f 6e  dres...Kitsh Con
1660: 66 69 67 75 72 65 20 4f 70 74 69 6f 6e 73 3a 0a  figure Options:.
1670: 09 31 2e 20 2d 2d 65 6e 61 62 6c 65 2d 6b 69 74  .1. --enable-kit
1680: 2d 73 74 6f 72 61 67 65 3d 7b 7a 69 70 7c 6d 6b  -storage={zip|mk
1690: 34 7c 61 75 74 6f 7d 0a 09 09 53 70 65 63 69 66  4|auto}...Specif
16a0: 79 20 77 68 69 63 68 20 74 79 70 65 20 6f 66 20  y which type of 
16b0: 73 74 6f 72 61 67 65 20 74 6f 20 75 73 65 20 77  storage to use w
16c0: 69 74 68 20 74 68 65 20 54 63 6c 6b 69 74 2e 20  ith the Tclkit. 
16d0: 20 54 68 65 0a 09 09 64 65 66 61 75 6c 74 20 69   The...default i
16e0: 73 20 74 6f 20 61 75 74 6f 2d 64 65 74 65 63 74  s to auto-detect
16f0: 2e 20 20 41 75 74 6f 2d 64 65 74 65 63 74 69 6f  .  Auto-detectio
1700: 6e 20 75 73 65 73 20 4d 6b 34 20 69 66 0a 09 09  n uses Mk4 if...
1710: 61 76 61 69 6c 61 62 6c 65 20 61 6e 64 20 62 75  available and bu
1720: 69 6c 74 20 73 74 61 74 69 63 61 6c 6c 79 2c 20  ilt statically, 
1730: 6f 74 68 65 72 77 69 73 65 20 69 74 20 66 61 6c  otherwise it fal
1740: 6c 73 20 62 61 63 6b 20 74 6f 20 5a 69 70 2e 0a  ls back to Zip..
1750: 0a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  .---------------
1760: 2d 2d 2d 2d 2d 0a 55 73 69 6e 67 20 74 68 65 20  -----.Using the 
1770: 4b 69 74 44 4c 4c 20 53 44 4b 0a 2d 2d 2d 2d 2d  KitDLL SDK.-----
1780: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
1790: 57 68 65 6e 20 79 6f 75 20 62 75 69 6c 64 20 61  When you build a
17a0: 20 4b 69 74 44 4c 4c 2c 20 61 20 22 6c 69 62 74   KitDLL, a "libt
17b0: 63 6c 6b 69 74 2d 73 64 6b 2d 3c 74 63 6c 76 65  clkit-sdk-<tclve
17c0: 72 73 3e 2e 74 61 72 2e 67 7a 22 20 74 61 72 62  rs>.tar.gz" tarb
17d0: 61 6c 6c 20 69 73 20 61 6c 73 6f 0a 70 72 6f 64  all is also.prod
17e0: 75 63 65 64 2e 20 20 54 68 69 73 20 74 61 72 62  uced.  This tarb
17f0: 61 6c 6c 20 63 6f 6e 74 61 69 6e 73 20 74 68 65  all contains the
1800: 20 54 63 6c 20 28 61 6e 64 20 54 6b 2c 20 69 66   Tcl (and Tk, if
1810: 20 63 6f 6d 70 69 6c 65 64 29 20 73 74 75 62 73   compiled) stubs
1820: 20 6c 69 62 72 61 72 69 65 73 2c 0a 61 6e 64 20   libraries,.and 
1830: 54 63 6c 20 28 61 6e 64 20 54 6b 2c 20 69 66 20  Tcl (and Tk, if 
1840: 63 6f 6d 70 69 6c 65 64 29 20 68 65 61 64 65 72  compiled) header
1850: 20 66 69 6c 65 73 20 6e 65 65 64 65 64 20 74 6f   files needed to
1860: 20 63 6f 6d 70 69 6c 65 20 61 6e 64 20 6c 69 6e   compile and lin
1870: 6b 20 74 68 69 6e 67 73 0a 61 67 61 69 6e 73 74  k things.against
1880: 20 54 63 6c 20 28 61 6e 64 20 54 6b 29 2e 20 20   Tcl (and Tk).  
1890: 49 74 20 61 6c 73 6f 20 69 6e 63 6c 75 64 65 73  It also includes
18a0: 20 22 74 63 6c 43 6f 6e 66 69 67 2e 73 68 22 20   "tclConfig.sh" 
18b0: 28 61 6e 64 20 22 74 6b 43 6f 6e 66 69 67 2e 73  (and "tkConfig.s
18c0: 68 22 2c 20 69 66 0a 54 6b 20 77 61 73 20 63 6f  h", if.Tk was co
18d0: 6d 70 69 6c 65 64 29 2e 0a 0a 54 68 65 20 70 75  mpiled)...The pu
18e0: 72 70 6f 73 65 20 66 6f 72 20 74 68 69 73 20 74  rpose for this t
18f0: 61 72 62 61 6c 6c 20 69 73 20 74 6f 20 62 65 20  arball is to be 
1900: 75 73 65 64 20 74 6f 20 62 75 69 6c 64 20 54 63  used to build Tc
1910: 6c 20 65 78 74 65 6e 73 69 6f 6e 73 20 6f 72 0a  l extensions or.
1920: 61 70 70 6c 69 63 61 74 69 6f 6e 73 20 74 68 61  applications tha
1930: 74 20 72 65 6c 79 20 6f 6e 20 54 63 6c 2f 54 6b  t rely on Tcl/Tk
1940: 20 75 73 69 6e 67 20 74 68 65 20 4b 69 74 44 4c   using the KitDL
1950: 4c 2e 0a 0a 54 6f 20 75 73 65 20 69 74 2c 20 6f  L...To use it, o
1960: 6e 65 20 66 69 72 73 74 20 6d 75 73 74 20 65 78  ne first must ex
1970: 74 72 61 63 74 20 74 68 65 20 74 61 72 62 61 6c  tract the tarbal
1980: 6c 2e 20 20 41 66 74 65 72 20 74 68 61 74 20 74  l.  After that t
1990: 68 65 20 65 6e 76 69 72 6f 6e 6d 65 6e 74 0a 76  he environment.v
19a0: 61 72 69 61 62 6c 65 20 22 54 43 4c 4b 49 54 5f  ariable "TCLKIT_
19b0: 53 44 4b 5f 44 49 52 22 20 6d 75 73 74 20 62 65  SDK_DIR" must be
19c0: 20 73 65 74 20 74 6f 20 74 68 65 20 64 69 72 65   set to the dire
19d0: 63 74 6f 72 79 20 74 68 61 74 20 77 61 73 20 63  ctory that was c
19e0: 72 65 61 74 65 64 20 69 6e 0a 6f 72 64 65 72 20  reated in.order 
19f0: 74 6f 20 6d 61 6b 65 20 6d 6f 73 74 20 6f 66 20  to make most of 
1a00: 74 68 65 20 76 61 72 69 61 62 6c 65 73 20 63 6f  the variables co
1a10: 6e 74 61 69 6e 20 75 73 65 66 75 6c 20 76 61 6c  ntain useful val
1a20: 75 65 73 2e 0a 0a 46 6f 72 20 65 78 61 6d 70 6c  ues...For exampl
1a30: 65 2c 20 74 6f 20 62 75 69 6c 64 20 61 6e 20 65  e, to build an e
1a40: 78 74 65 6e 73 69 6f 6e 20 75 73 69 6e 67 20 74  xtension using t
1a50: 68 65 20 4b 69 74 44 4c 4c 20 53 44 4b 20 6f 6e  he KitDLL SDK on
1a60: 65 20 77 6f 75 6c 64 20 74 79 70 69 63 61 6c 6c  e would typicall
1a70: 79 20 64 6f 0a 73 6f 6d 65 74 68 69 6e 67 20 6c  y do.something l
1a80: 69 6b 65 3a 0a 09 31 2e 20 43 6f 6d 70 69 6c 65  ike:..1. Compile
1a90: 20 4b 69 74 44 4c 4c 20 28 6d 61 79 20 62 65 20   KitDLL (may be 
1aa0: 6f 6d 69 74 74 65 64 20 69 66 20 74 68 65 20 4b  omitted if the K
1ab0: 69 74 44 4c 4c 20 53 44 4b 20 69 73 20 61 6c 72  itDLL SDK is alr
1ac0: 65 61 64 79 0a 09 20 20 20 61 76 61 69 6c 61 62  eady..   availab
1ad0: 6c 65 29 0a 09 09 61 2e 20 24 20 4b 49 54 43 52  le)...a. $ KITCR
1ae0: 45 41 54 4f 52 5f 50 4b 47 53 3d 27 74 6b 20 69  EATOR_PKGS='tk i
1af0: 74 63 6c 20 6b 69 74 64 6c 6c 27 0a 09 09 62 2e  tcl kitdll'...b.
1b00: 20 24 20 65 78 70 6f 72 74 20 4b 49 54 43 52 45   $ export KITCRE
1b10: 41 54 4f 52 5f 50 4b 47 53 0a 09 09 63 2e 20 24  ATOR_PKGS...c. $
1b20: 20 2e 2f 6b 69 74 63 72 65 61 74 6f 72 0a 09 32   ./kitcreator..2
1b30: 2e 20 43 6f 6d 70 69 6c 65 20 74 68 65 20 45 78  . Compile the Ex
1b40: 74 65 6e 73 69 6f 6e 0a 09 09 61 2e 20 24 20 74  tension...a. $ t
1b50: 61 72 20 2d 78 66 20 2f 70 61 74 68 2f 74 6f 2f  ar -xf /path/to/
1b60: 6c 69 62 74 63 6c 6b 69 74 2d 73 64 6b 2d 38 2e  libtclkit-sdk-8.
1b70: 34 2e 31 39 2e 74 61 72 2e 67 7a 0a 09 09 62 2e  4.19.tar.gz...b.
1b80: 20 24 20 54 43 4c 4b 49 54 5f 53 44 4b 5f 44 49   $ TCLKIT_SDK_DI
1b90: 52 3d 22 24 28 70 77 64 29 2f 6c 69 62 74 63 6c  R="$(pwd)/libtcl
1ba0: 6b 69 74 2d 73 64 6b 2d 38 2e 34 2e 31 39 22 0a  kit-sdk-8.4.19".
1bb0: 09 09 63 2e 20 24 20 65 78 70 6f 72 74 20 54 43  ..c. $ export TC
1bc0: 4c 4b 49 54 5f 53 44 4b 5f 44 49 52 0a 09 09 64  LKIT_SDK_DIR...d
1bd0: 2e 20 24 20 2e 2f 63 6f 6e 66 69 67 75 72 65 20  . $ ./configure 
1be0: 2d 2d 77 69 74 68 2d 74 63 6c 3d 22 24 7b 54 43  --with-tcl="${TC
1bf0: 4c 4b 49 54 5f 53 44 4b 5f 44 49 52 7d 2f 6c 69  LKIT_SDK_DIR}/li
1c00: 62 22 0a 09 09 65 2e 20 24 20 6d 61 6b 65 0a 0a  b"...e. $ make..
1c10: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1c20: 2d 2d 2d 0a 4d 65 74 68 6f 64 20 6f 66 20 4f 70  ---.Method of Op
1c30: 65 72 61 74 69 6f 6e 0a 2d 2d 2d 2d 2d 2d 2d 2d  eration.--------
1c40: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 53 75 6d 6d  -----------.Summ
1c50: 61 72 79 3a 0a 09 31 2e 20 22 6b 69 74 63 72 65  ary:..1. "kitcre
1c60: 61 74 6f 72 22 20 63 61 6c 6c 73 20 2a 2f 62 75  ator" calls */bu
1c70: 69 6c 64 2e 73 68 0a 09 32 2e 20 2a 2f 62 75 69  ild.sh..2. */bui
1c80: 6c 64 2e 73 68 20 64 6f 77 6e 6c 6f 61 64 73 20  ld.sh downloads 
1c90: 61 6e 64 20 63 6f 6d 70 69 6c 65 73 20 61 70 70  and compiles app
1ca0: 72 6f 70 72 69 61 74 65 20 73 6f 66 74 77 61 72  ropriate softwar
1cb0: 65 0a 09 33 2e 20 2a 2f 62 75 69 6c 64 2e 73 68  e..3. */build.sh
1cc0: 20 69 6e 73 74 61 6c 6c 73 20 73 6f 66 74 77 61   installs softwa
1cd0: 72 65 20 69 6e 74 6f 20 22 69 6e 73 74 22 20 28  re into "inst" (
1ce0: 72 75 6e 2d 74 69 6d 65 20 2b 20 63 6f 6d 70 69  run-time + compi
1cf0: 6c 65 2d 74 69 6d 65 29 0a 09 34 2e 20 2a 2f 62  le-time)..4. */b
1d00: 75 69 6c 64 2e 73 68 20 69 6e 73 74 61 6c 6c 73  uild.sh installs
1d10: 20 72 75 6e 2d 74 69 6d 65 20 73 6f 66 74 77 61   run-time softwa
1d20: 72 65 20 69 6e 74 6f 20 22 6f 75 74 22 2c 20 74  re into "out", t
1d30: 68 69 73 20 77 69 6c 6c 20 62 65 0a 09 20 20 20  his will be..   
1d40: 69 6e 63 6c 75 64 65 64 20 69 6e 20 74 68 65 20  included in the 
1d50: 54 63 6c 6b 69 74 20 61 73 20 69 66 20 69 74 20  Tclkit as if it 
1d60: 77 65 72 65 20 74 68 65 20 72 6f 6f 74 20 64 69  were the root di
1d70: 72 65 63 74 6f 72 79 20 6f 66 20 74 68 65 0a 09  rectory of the..
1d80: 20 20 20 54 63 6c 6b 69 74 20 28 63 6f 6d 62 69     Tclkit (combi
1d90: 6e 65 64 20 77 69 74 68 20 6f 74 68 65 72 20 22  ned with other "
1da0: 6f 75 74 22 20 64 69 72 65 63 74 6f 72 69 65 73  out" directories
1db0: 29 0a 09 35 2e 20 6b 69 74 73 68 2f 62 75 69 6c  )..5. kitsh/buil
1dc0: 64 2e 73 68 20 63 6f 6d 70 69 6c 65 73 20 61 20  d.sh compiles a 
1dd0: 22 6d 61 69 6e 22 20 66 75 6e 63 74 69 6f 6e 20  "main" function 
1de0: 61 6e 64 20 6c 69 6e 6b 73 20 61 6c 6c 20 74 68  and links all th
1df0: 65 20 62 75 69 6c 74 0a 09 20 20 20 6c 69 62 72  e built..   libr
1e00: 61 72 69 65 73 20 74 6f 67 65 74 68 65 72 20 69  aries together i
1e10: 6e 74 6f 20 61 6e 20 65 78 65 63 75 74 61 62 6c  nto an executabl
1e20: 65 0a 09 36 2e 20 6b 69 74 73 68 2f 62 75 69 6c  e..6. kitsh/buil
1e30: 64 2e 73 68 20 63 6f 6d 62 69 6e 65 73 20 61 6c  d.sh combines al
1e40: 6c 20 74 68 65 20 22 6f 75 74 22 20 64 69 72 65  l the "out" dire
1e50: 63 74 6f 72 69 65 73 20 69 6e 74 6f 20 6f 6e 65  ctories into one
1e60: 0a 09 37 2e 20 6b 69 74 73 68 2f 62 75 69 6c 64  ..7. kitsh/build
1e70: 2e 73 68 20 63 72 65 61 74 65 73 20 61 20 4d 65  .sh creates a Me
1e80: 74 61 6b 69 74 20 6f 72 20 5a 69 70 20 64 61 74  takit or Zip dat
1e90: 61 62 61 73 65 20 66 72 6f 6d 20 74 68 65 20 63  abase from the c
1ea0: 6f 6d 62 69 6e 65 64 0a 09 20 20 20 64 69 72 65  ombined..   dire
1eb0: 63 74 6f 72 69 65 73 20 61 6e 64 20 61 70 70 65  ctories and appe
1ec0: 6e 64 73 20 74 68 61 74 20 74 6f 20 74 68 65 20  nds that to the 
1ed0: 63 6f 6d 70 69 6c 65 64 20 65 78 65 63 75 74 61  compiled executa
1ee0: 62 6c 65 20 75 73 69 6e 67 3a 0a 09 09 61 2e 20  ble using:...a. 
1ef0: 41 20 54 63 6c 6b 69 74 20 66 6f 75 6e 64 20 69  A Tclkit found i
1f00: 6e 20 74 68 65 20 65 6e 76 69 72 6f 6e 6d 65 6e  n the environmen
1f10: 74 20 76 61 72 69 61 62 6c 65 20 22 54 43 4c 4b  t variable "TCLK
1f20: 49 54 22 20 28 74 63 6c 6b 69 74 0a 09 09 20 20  IT" (tclkit...  
1f30: 20 69 66 20 75 6e 73 65 74 29 20 69 66 20 69 74   if unset) if it
1f40: 20 69 73 20 66 75 6e 63 74 69 6f 6e 61 6c 3b 20   is functional; 
1f50: 6f 72 0a 09 09 62 2e 20 54 68 65 20 62 75 69 6c  or...b. The buil
1f60: 74 20 6b 69 74 20 69 74 73 65 6c 66 20 28 64 6f  t kit itself (do
1f70: 65 73 20 6e 6f 74 20 77 6f 72 6b 20 66 6f 72 20  es not work for 
1f80: 63 72 6f 73 73 2d 63 6f 6d 70 69 6c 69 6e 67 29  cross-compiling)
1f90: 0a 0a 44 65 74 61 69 6c 73 3a 0a 09 54 68 65 20  ..Details:..The 
1fa0: 67 65 6e 65 72 61 6c 20 6d 65 63 68 61 6e 69 73  general mechanis
1fb0: 6d 20 74 68 61 74 20 65 6e 61 62 6c 65 73 20 61  m that enables a
1fc0: 20 54 63 6c 6b 69 74 20 74 6f 20 6f 70 65 72 61   Tclkit to opera
1fd0: 74 65 20 69 73 20 61 20 73 6d 61 6c 6c 20 54 63  te is a small Tc
1fe0: 6c 0a 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e  l.initialization
1ff0: 20 72 6f 75 74 69 6e 65 20 6c 69 6e 6b 65 64 20   routine linked 
2000: 73 74 61 74 69 63 61 6c 6c 79 20 74 6f 20 74 68  statically to th
2010: 65 20 63 6f 72 65 20 6c 69 62 72 61 72 69 65 73  e core libraries
2020: 20 6e 65 65 64 65 64 20 74 6f 0a 6f 70 65 72 61   needed to.opera
2030: 74 65 20 61 20 54 63 6c 20 69 6e 74 65 72 70 72  te a Tcl interpr
2040: 65 74 65 72 2c 20 74 68 65 20 54 63 6c 20 56 46  eter, the Tcl VF
2050: 53 20 4c 61 79 65 72 2c 20 61 6e 64 20 61 20 64  S Layer, and a d
2060: 61 74 61 62 61 73 65 2d 62 61 63 6b 65 64 20 28  atabase-backed (
2070: 4d 65 74 61 6b 69 74 29 0a 56 69 72 74 75 61 6c  Metakit).Virtual
2080: 20 46 69 6c 65 20 53 79 73 74 65 6d 20 74 68 61   File System tha
2090: 74 20 69 73 20 61 70 70 65 6e 64 65 64 20 74 6f  t is appended to
20a0: 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20   the end of the 
20b0: 65 78 65 63 75 74 61 62 6c 65 2e 0a 0a 54 68 69  executable...Thi
20c0: 73 20 70 72 6f 6a 65 63 74 20 62 72 69 6e 67 73  s project brings
20d0: 20 74 6f 67 65 74 68 65 72 20 61 6c 6c 20 6f 66   together all of
20e0: 20 74 68 65 20 72 65 71 75 69 72 65 64 20 70 69   the required pi
20f0: 65 63 65 73 2c 20 70 6c 75 73 20 73 6f 6d 65 20  eces, plus some 
2100: 61 64 64 69 74 69 6f 6e 61 6c 0a 70 69 65 63 65  additional.piece
2110: 73 20 74 68 61 74 20 77 65 72 65 20 66 6f 75 6e  s that were foun
2120: 64 20 69 6e 20 74 68 65 20 6f 72 69 67 69 6e 61  d in the origina
2130: 6c 20 54 63 6c 6b 69 74 3a 0a 09 31 2e 20 54 6b  l Tclkit:..1. Tk
2140: 20 28 64 79 6e 61 6d 69 63 61 6c 6c 79 20 6c 69   (dynamically li
2150: 6e 6b 65 64 29 0a 09 32 2e 20 49 74 63 6c 20 28  nked)..2. Itcl (
2160: 64 79 6e 61 6d 69 63 61 6c 6c 79 20 6c 69 6e 6b  dynamically link
2170: 65 64 29 0a 0a 54 68 65 20 73 6f 75 72 63 65 20  ed)..The source 
2180: 63 6f 64 65 20 66 6f 72 20 74 68 65 73 65 20 70  code for these p
2190: 69 65 63 65 73 20 61 72 65 20 64 6f 77 6e 6c 6f  ieces are downlo
21a0: 61 64 65 64 2c 20 63 6f 6d 70 69 6c 65 64 2c 20  aded, compiled, 
21b0: 61 6e 64 20 6c 69 6e 6b 65 64 2c 20 61 6e 64 20  and linked, and 
21c0: 74 68 65 0a 64 61 74 61 62 61 73 65 20 63 6f 6e  the.database con
21d0: 74 61 69 6e 69 6e 67 20 74 68 65 20 61 70 70 72  taining the appr
21e0: 6f 70 72 69 61 74 65 20 66 69 6c 65 73 79 73 74  opriate filesyst
21f0: 65 6d 20 64 61 74 61 20 69 73 20 63 72 65 61 74  em data is creat
2200: 65 64 2e 20 20 57 68 61 74 20 73 65 74 73 0a 74  ed.  What sets.t
2210: 68 69 73 20 70 72 6f 6a 65 63 74 20 61 70 61 72  his project apar
2220: 74 20 66 72 6f 6d 20 6f 74 68 65 72 20 73 69 6d  t from other sim
2230: 69 6c 61 72 20 70 72 6f 6a 65 63 74 73 20 69 73  ilar projects is
2240: 20 74 68 61 74 3a 0a 09 31 2e 20 49 74 20 61 74   that:..1. It at
2250: 74 65 6d 70 74 73 20 74 6f 20 62 65 20 6d 6f 64  tempts to be mod
2260: 75 6c 61 72 3b 0a 09 32 2e 20 49 74 20 73 75 70  ular;..2. It sup
2270: 70 6f 72 74 73 20 63 72 6f 73 73 2d 63 6f 6d 70  ports cross-comp
2280: 69 6c 69 6e 67 3b 0a 09 33 2e 20 49 74 20 64 6f  iling;..3. It do
2290: 77 6e 6c 6f 61 64 73 20 74 68 65 20 73 6f 75 72  wnloads the sour
22a0: 63 65 20 66 72 6f 6d 20 74 68 65 69 72 20 6f 72  ce from their or
22b0: 69 67 69 6e 61 6c 20 72 65 70 6f 73 69 74 6f 72  iginal repositor
22c0: 69 65 73 3b 0a 09 34 2e 20 49 74 20 61 6c 6c 6f  ies;..4. It allo
22d0: 77 73 20 79 6f 75 20 74 6f 20 73 70 65 63 69 66  ws you to specif
22e0: 79 20 61 6e 20 61 72 62 69 74 72 61 72 79 20 76  y an arbitrary v
22f0: 65 72 73 69 6f 6e 20 6f 66 20 54 63 6c 20 28 69  ersion of Tcl (i
2300: 6e 63 6c 75 64 69 6e 67 0a 09 20 20 20 43 56 53  ncluding..   CVS
2310: 29 3b 20 61 6e 64 0a 09 35 2e 20 49 74 20 75 73  ); and..5. It us
2320: 65 73 20 47 4e 55 20 41 75 74 6f 63 6f 6e 66 20  es GNU Autoconf 
2330: 73 63 72 69 70 74 73 20 66 6f 72 20 63 6f 6d 70  scripts for comp
2340: 69 6c 69 6e 67 20 74 68 65 20 70 61 72 74 20 6f  iling the part o
2350: 66 20 74 68 65 20 54 63 6c 6b 69 74 0a 09 20 20  f the Tclkit..  
2360: 20 74 68 61 74 20 62 72 69 6e 67 73 20 74 68 65   that brings the
2370: 20 77 68 6f 6c 65 20 74 68 69 6e 67 20 74 6f 67   whole thing tog
2380: 65 74 68 65 72 20 28 74 68 65 20 4b 69 74 73 68  ether (the Kitsh
2390: 29 0a 0a 54 6f 20 61 63 63 6f 6d 70 6c 69 73 68  )..To accomplish
23a0: 20 74 68 65 73 65 20 67 6f 61 6c 73 20 74 68 65   these goals the
23b0: 20 66 6f 6c 6c 6f 77 69 6e 67 20 6d 65 63 68 61   following mecha
23c0: 6e 69 73 6d 73 20 61 72 65 20 69 6e 20 70 6c 61  nisms are in pla
23d0: 63 65 3a 0a 09 31 2e 20 54 68 65 20 74 6f 70 2d  ce:..1. The top-
23e0: 6c 65 76 65 6c 20 22 6b 69 74 63 72 65 61 74 6f  level "kitcreato
23f0: 72 22 20 73 63 72 69 70 74 3b 20 61 6e 64 0a 09  r" script; and..
2400: 32 2e 20 50 65 72 2d 70 72 6f 6a 65 63 74 20 73  2. Per-project s
2410: 75 62 64 69 72 65 63 74 6f 72 69 65 73 2c 20 65  ubdirectories, e
2420: 61 63 68 20 63 6f 6e 74 61 69 6e 69 6e 67 20 61  ach containing a
2430: 20 22 62 75 69 6c 64 2e 73 68 22 20 73 63 72 69   "build.sh" scri
2440: 70 74 0a 0a 54 68 65 20 74 6f 70 2d 6c 65 76 65  pt..The top-leve
2450: 6c 20 22 6b 69 74 63 72 65 61 74 6f 72 22 20 73  l "kitcreator" s
2460: 63 72 69 70 74 20 69 73 20 76 65 72 79 20 73 69  cript is very si
2470: 6d 70 6c 65 2e 20 20 49 74 73 20 6f 6e 6c 79 20  mple.  Its only 
2480: 6a 6f 62 20 69 73 20 74 6f 0a 69 6e 74 65 72 70  job is to.interp
2490: 72 65 74 20 63 6f 6d 6d 61 6e 64 20 6c 69 6e 65  ret command line
24a0: 20 61 72 67 75 6d 65 6e 74 73 2c 20 61 6e 64 20   arguments, and 
24b0: 63 61 6c 6c 20 74 68 65 20 70 65 72 2d 70 72 6f  call the per-pro
24c0: 6a 65 63 74 20 22 62 75 69 6c 64 2e 73 68 22 20  ject "build.sh" 
24d0: 73 63 72 69 70 74 73 2e 0a 46 6f 72 20 74 68 65  scripts..For the
24e0: 20 22 74 63 6c 22 20 70 72 6f 6a 65 63 74 20 69   "tcl" project i
24f0: 74 20 61 6c 73 6f 20 66 69 6e 64 73 20 74 68 65  t also finds the
2500: 20 61 70 70 72 6f 70 72 69 61 74 65 20 22 74 63   appropriate "tc
2510: 6c 43 6f 6e 66 69 67 2e 73 68 22 20 28 61 6e 64  lConfig.sh" (and
2520: 20 73 74 6f 72 65 73 0a 74 68 69 73 20 70 61 74   stores.this pat
2530: 68 20 69 6e 20 54 43 4c 43 4f 4e 46 49 47 44 49  h in TCLCONFIGDI
2540: 52 29 20 74 6f 20 65 6e 61 62 6c 65 20 73 75 62  R) to enable sub
2550: 73 65 71 75 65 6e 74 20 62 75 69 6c 64 20 73 63  sequent build sc
2560: 72 69 70 74 73 20 74 6f 20 66 69 6e 64 20 74 68  ripts to find th
2570: 65 0a 61 70 70 72 6f 70 72 69 61 74 65 20 54 63  e.appropriate Tc
2580: 6c 20 74 6f 20 6c 69 6e 6b 20 61 67 61 69 6e 73  l to link agains
2590: 74 2e 0a 0a 54 68 65 20 70 65 72 2d 70 72 6f 6a  t...The per-proj
25a0: 65 63 74 20 22 62 75 69 6c 64 2e 73 68 22 20 73  ect "build.sh" s
25b0: 63 72 69 70 74 73 20 61 72 65 20 65 6e 74 69 72  cripts are entir
25c0: 65 6c 79 20 61 75 74 6f 6e 6f 6d 6f 75 73 2e 20  ely autonomous. 
25d0: 20 54 68 65 79 20 61 72 65 0a 72 65 73 70 6f 6e   They are.respon
25e0: 73 69 62 6c 65 20 66 6f 72 20 64 6f 77 6e 6c 6f  sible for downlo
25f0: 61 64 69 6e 67 20 74 68 65 20 73 6f 75 72 63 65  ading the source
2600: 20 63 6f 64 65 20 66 6f 72 20 74 68 65 20 61 70   code for the ap
2610: 70 72 6f 70 72 69 61 74 65 20 76 65 72 73 69 6f  propriate versio
2620: 6e 20 74 68 61 74 0a 77 69 6c 6c 20 63 6f 6d 70  n that.will comp
2630: 69 6c 65 20 61 6e 64 20 6c 69 6e 6b 20 61 67 61  ile and link aga
2640: 69 6e 73 74 20 74 68 65 20 63 75 72 72 65 6e 74  inst the current
2650: 20 76 65 72 73 69 6f 6e 20 6f 66 20 54 63 6c 20   version of Tcl 
2660: 28 75 73 65 72 20 72 65 71 75 65 73 74 65 64 0a  (user requested.
2670: 76 65 72 73 69 6f 6e 20 63 61 6e 20 62 65 20 66  version can be f
2680: 6f 75 6e 64 20 69 6e 20 22 54 43 4c 56 45 52 53  ound in "TCLVERS
2690: 22 2c 20 77 68 69 6c 65 20 74 68 65 20 61 63 74  ", while the act
26a0: 75 61 6c 20 76 65 72 73 69 6f 6e 20 6d 75 73 74  ual version must
26b0: 20 62 65 20 72 65 71 75 65 73 74 65 64 0a 66 72   be requested.fr
26c0: 6f 6d 20 74 68 65 20 22 74 63 6c 43 6f 6e 66 69  om the "tclConfi
26d0: 67 2e 73 68 22 20 73 63 72 69 70 74 29 2c 20 63  g.sh" script), c
26e0: 6f 6d 70 69 6c 69 6e 67 20 69 74 2c 20 69 6e 73  ompiling it, ins
26f0: 74 61 6c 6c 69 6e 67 20 61 20 66 75 6e 63 74 69  talling a functi
2700: 6f 6e 61 6c 20 63 6f 70 79 0a 69 6e 74 6f 20 74  onal copy.into t
2710: 68 65 20 70 65 72 2d 70 72 6f 6a 65 63 74 20 22  he per-project "
2720: 69 6e 73 74 22 20 64 69 72 65 63 74 6f 72 79 2c  inst" directory,
2730: 20 61 6e 64 20 69 6e 73 74 61 6c 6c 69 6e 67 20   and installing 
2740: 61 6e 79 74 68 69 6e 67 20 74 68 61 74 20 6e 65  anything that ne
2750: 65 64 73 20 74 6f 0a 62 65 20 69 6e 20 74 68 65  eds to.be in the
2760: 20 54 63 6c 6b 69 74 27 73 20 56 46 53 20 72 6f   Tclkit's VFS ro
2770: 6f 74 20 69 6e 74 6f 20 74 68 65 20 70 65 72 2d  ot into the per-
2780: 70 72 6f 6a 65 63 74 20 22 6f 75 74 22 20 64 69  project "out" di
2790: 72 65 63 74 6f 72 79 2e 0a 0a 41 6e 79 20 61 64  rectory...Any ad
27a0: 64 69 74 69 6f 6e 61 6c 20 70 72 6f 6a 65 63 74  ditional project
27b0: 73 20 63 61 6e 20 62 65 20 69 6e 63 6c 75 64 65  s can be include
27c0: 64 20 73 69 6d 70 6c 79 20 62 79 20 63 72 65 61  d simply by crea
27d0: 74 69 6e 67 20 74 68 65 20 61 70 70 72 6f 70 72  ting the appropr
27e0: 69 61 74 65 0a 64 69 72 65 63 74 6f 72 79 20 69  iate.directory i
27f0: 6e 20 74 68 65 20 73 61 6d 65 20 64 69 72 65 63  n the same direc
2800: 74 6f 72 79 20 61 73 20 74 68 65 20 22 6b 69 74  tory as the "kit
2810: 63 72 65 61 74 6f 72 22 20 73 63 72 69 70 74 2c  creator" script,
2820: 20 63 72 65 61 74 69 6e 67 20 61 0a 22 62 75 69   creating a."bui
2830: 6c 64 2e 73 68 22 20 73 63 72 69 70 74 20 69 6e  ld.sh" script in
2840: 20 74 68 61 74 20 64 69 72 65 63 74 6f 72 79 20   that directory 
2850: 74 68 61 74 20 66 6f 6c 6c 6f 77 73 20 74 68 65  that follows the
2860: 20 61 62 6f 76 65 20 70 72 6f 63 65 64 75 72 65   above procedure
2870: 2c 20 61 6e 64 20 74 68 65 6e 0a 72 65 66 65 72  , and then.refer
2880: 65 6e 63 69 6e 67 20 74 68 61 74 20 64 69 72 65  encing that dire
2890: 63 74 6f 72 79 20 69 6e 20 22 4b 49 54 43 52 45  ctory in "KITCRE
28a0: 41 54 4f 52 5f 50 4b 47 53 22 20 66 6f 72 20 74  ATOR_PKGS" for t
28b0: 68 65 20 22 6b 69 74 63 72 65 61 74 6f 72 22 20  he "kitcreator" 
28c0: 69 6e 76 6f 63 61 74 69 6f 6e 2e 0a 49 6e 20 74  invocation..In t
28d0: 68 69 73 20 77 61 79 20 4b 69 74 43 72 65 61 74  his way KitCreat
28e0: 6f 72 20 69 73 20 22 70 6c 75 67 67 61 62 6c 65  or is "pluggable
28f0: 22 2e 20 20 49 6e 63 6c 75 64 65 64 20 70 61 63  ".  Included pac
2900: 6b 61 67 65 73 20 6d 61 79 20 62 65 20 65 69 74  kages may be eit
2910: 68 65 72 0a 73 74 61 74 69 63 61 6c 6c 79 20 6f  her.statically o
2920: 72 20 64 79 6e 61 6d 69 63 61 6c 6c 79 20 6c 69  r dynamically li
2930: 6e 6b 65 64 2e 20 20 49 66 20 69 74 20 69 73 20  nked.  If it is 
2940: 73 74 61 74 69 63 61 6c 6c 79 20 6c 69 6e 6b 65  statically linke
2950: 64 20 74 68 65 6e 20 74 68 65 20 6d 6f 64 75 6c  d then the modul
2960: 65 0a 6e 61 6d 65 20 6d 75 73 74 20 62 65 20 74  e.name must be t
2970: 68 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 64  he name of the d
2980: 69 72 65 63 74 6f 72 79 20 2d 2d 20 74 68 61 74  irectory -- that
2990: 20 69 73 2c 20 69 66 20 74 68 65 20 64 69 72 65   is, if the dire
29a0: 63 74 6f 72 79 20 77 65 72 65 20 22 66 6f 6f 22  ctory were "foo"
29b0: 2c 0a 4b 69 74 43 72 65 61 74 6f 72 20 77 69 6c  ,.KitCreator wil
29c0: 6c 20 65 78 70 65 63 74 20 74 6f 20 69 6e 69 74  l expect to init
29d0: 69 61 6c 69 7a 65 20 74 68 65 20 6d 6f 64 75 6c  ialize the modul
29e0: 65 20 73 74 61 74 69 63 61 6c 6c 79 20 75 73 69  e statically usi
29f0: 6e 67 20 46 6f 6f 5f 49 6e 69 74 28 29 2e 0a 0a  ng Foo_Init()...
2a00: 54 68 65 20 65 78 63 65 70 74 69 6f 6e 20 74 6f  The exception to
2a10: 20 74 68 69 73 20 69 73 20 74 68 65 20 22 6b 69   this is the "ki
2a20: 74 73 68 22 20 70 72 6f 6a 65 63 74 2e 20 20 49  tsh" project.  I
2a30: 74 20 69 73 20 74 68 65 20 67 6c 75 65 20 74 68  t is the glue th
2a40: 61 74 20 62 69 6e 64 73 20 61 6c 6c 0a 74 68 65  at binds all.the
2a50: 20 69 6e 64 69 76 69 64 75 61 6c 20 70 72 6f 6a   individual proj
2a60: 65 63 74 73 20 74 6f 67 65 74 68 65 72 20 69 6e  ects together in
2a70: 74 6f 20 61 20 73 69 6e 67 6c 65 20 65 78 65 63  to a single exec
2a80: 75 74 61 62 6c 65 2e 20 20 49 74 73 20 62 75 69  utable.  Its bui
2a90: 6c 64 20 73 63 72 69 70 74 0a 64 6f 65 73 20 6e  ld script.does n
2aa0: 6f 74 20 63 72 65 61 74 65 20 61 6e 20 22 69 6e  ot create an "in
2ab0: 73 74 22 20 6f 72 20 61 6e 20 22 6f 75 74 22 20  st" or an "out" 
2ac0: 64 69 72 65 63 74 6f 72 79 20 62 65 63 61 75 73  directory becaus
2ad0: 65 20 69 74 20 69 73 20 6e 6f 74 20 61 20 6c 69  e it is not a li
2ae0: 62 72 61 72 79 2e 0a 49 6e 73 74 65 61 64 2c 20  brary..Instead, 
2af0: 69 74 20 63 6f 6c 6c 65 63 74 73 20 61 6c 6c 20  it collects all 
2b00: 74 68 65 20 6f 74 68 65 72 20 70 72 6f 6a 65 63  the other projec
2b10: 74 27 73 20 22 6f 75 74 22 20 64 69 72 65 63 74  t's "out" direct
2b20: 6f 72 69 65 73 20 69 6e 74 6f 20 61 20 73 69 6e  ories into a sin
2b30: 67 6c 65 0a 64 69 72 65 63 74 6f 72 79 20 28 73  gle.directory (s
2b40: 74 61 72 70 61 63 6b 2e 76 66 73 29 2c 20 61 73  tarpack.vfs), as
2b50: 20 77 65 6c 6c 20 61 20 73 74 61 74 69 63 20 66   well a static f
2b60: 69 6c 65 20 28 62 6f 6f 74 2e 74 63 6c 29 2e 20  ile (boot.tcl). 
2b70: 49 74 20 74 68 65 6e 20 63 6f 6d 70 69 6c 65 73  It then compiles
2b80: 0a 74 68 65 20 73 6f 75 72 63 65 20 63 6f 64 65  .the source code
2b90: 2c 20 61 6e 64 20 74 68 65 6e 20 69 6e 73 74 61  , and then insta
2ba0: 6c 6c 73 20 74 68 65 20 56 46 53 20 6f 6e 74 6f  lls the VFS onto
2bb0: 20 74 68 65 20 72 65 73 75 6c 74 69 6e 67 20 65   the resulting e
2bc0: 78 65 63 75 74 61 62 6c 65 2e 0a 54 68 65 20 56  xecutable..The V
2bd0: 46 53 20 69 73 20 63 72 65 61 74 65 64 20 62 79  FS is created by
2be0: 20 74 68 65 20 22 69 6e 73 74 61 6c 6c 76 66 73   the "installvfs
2bf0: 2e 74 63 6c 22 20 73 63 72 69 70 74 20 66 6f 72  .tcl" script for
2c00: 20 4b 69 74 73 68 2e 20 20 46 6f 72 20 4b 69 74   Kitsh.  For Kit
2c10: 44 4c 4c 20 74 68 65 0a 56 46 53 20 69 73 20 63  DLL the.VFS is c
2c20: 72 65 61 74 65 64 20 62 79 20 22 64 69 72 32 63  reated by "dir2c
2c30: 2e 74 63 6c 22 2e 0a 0a 49 66 20 74 68 65 20 22  .tcl"...If the "
2c40: 6d 6b 34 74 63 6c 22 20 70 72 6f 6a 65 63 74 20  mk4tcl" project 
2c50: 66 61 69 6c 73 20 74 6f 20 62 75 69 6c 64 20 28  fails to build (
2c60: 6f 72 20 69 73 20 6e 6f 74 20 72 65 71 75 65 73  or is not reques
2c70: 74 65 64 20 74 6f 20 62 65 20 62 75 69 6c 74 29  ted to be built)
2c80: 2c 0a 74 68 65 20 72 65 73 74 20 6f 66 20 74 68  ,.the rest of th
2c90: 65 20 70 72 6f 6a 65 63 74 20 77 69 6c 6c 20 62  e project will b
2ca0: 65 20 62 75 69 6c 74 20 75 73 69 6e 67 20 7a 69  e built using zi
2cb0: 70 20 66 69 6c 65 73 20 69 6e 73 74 65 61 64 20  p files instead 
2cc0: 6f 66 20 4d 65 74 61 6b 69 74 0a 64 61 74 61 62  of Metakit.datab
2cd0: 61 73 65 73 2e 0a 0a 54 6f 20 63 72 65 61 74 65  ases...To create
2ce0: 20 74 68 65 20 73 74 6f 72 61 67 65 20 64 61 74   the storage dat
2cf0: 61 62 61 73 65 2c 20 6f 6e 65 20 6f 66 20 74 77  abase, one of tw
2d00: 6f 20 54 63 6c 6b 69 74 73 20 69 73 20 75 73 65  o Tclkits is use
2d10: 64 20 28 74 72 69 65 64 20 69 6e 20 74 68 69 73  d (tried in this
2d20: 0a 6f 72 64 65 72 29 3a 0a 09 31 2e 20 54 68 65  .order):..1. The
2d30: 20 54 63 6c 6b 69 74 20 73 70 65 63 69 66 69 65   Tclkit specifie
2d40: 64 20 62 79 20 74 68 65 20 54 43 4c 4b 49 54 20  d by the TCLKIT 
2d50: 65 6e 76 69 72 6f 6e 6d 65 6e 74 20 76 61 72 69  environment vari
2d60: 61 62 6c 65 20 28 6f 72 0a 09 20 20 20 22 74 63  able (or..   "tc
2d70: 6c 6b 69 74 22 20 69 66 20 74 68 61 74 20 76 61  lkit" if that va
2d80: 72 69 61 62 6c 65 20 69 73 20 6e 6f 74 20 73 65  riable is not se
2d90: 74 29 20 69 66 20 69 74 20 69 73 20 66 75 6e 63  t) if it is func
2da0: 74 69 6f 6e 61 6c 3b 20 6f 72 0a 09 32 2e 20 54  tional; or..2. T
2db0: 68 65 20 62 75 69 6c 74 20 54 63 6c 6b 69 74 20  he built Tclkit 
2dc0: 69 74 73 65 6c 66 0a 0a 54 68 65 20 73 65 63 6f  itself..The seco
2dd0: 6e 64 20 6d 65 74 68 6f 64 20 77 69 6c 6c 20 6e  nd method will n
2de0: 6f 74 20 77 6f 72 6b 20 69 66 20 74 68 65 20 62  ot work if the b
2df0: 75 69 6c 74 20 54 63 6c 6b 69 74 20 69 73 20 6e  uilt Tclkit is n
2e00: 6f 74 20 65 78 65 63 75 74 61 62 6c 65 20 6f 6e  ot executable on
2e10: 20 74 68 65 0a 63 75 72 72 65 6e 74 20 70 6c 61   the.current pla
2e20: 74 66 6f 72 6d 20 28 69 2e 65 2e 2c 20 69 6e 20  tform (i.e., in 
2e30: 74 68 65 20 63 61 73 65 20 6f 66 20 63 72 6f 73  the case of cros
2e40: 73 2d 63 6f 6d 70 69 6c 61 74 69 6f 6e 29 20 61  s-compilation) a
2e50: 6e 64 20 73 6f 20 69 74 20 6d 61 79 20 62 65 0a  nd so it may be.
2e60: 6e 65 63 65 73 73 61 72 79 20 74 6f 20 62 6f 6f  necessary to boo
2e70: 74 73 74 72 61 70 20 61 20 72 75 6e 6e 61 62 6c  tstrap a runnabl
2e80: 65 20 54 63 6c 6b 69 74 20 66 69 72 73 74 2e 0a  e Tclkit first..
2e90: 0a 4b 69 74 44 4c 4c 20 6d 6f 75 6e 74 73 20 74  .KitDLL mounts t
2ea0: 68 65 20 56 46 53 20 66 6f 72 20 65 76 65 72 79  he VFS for every
2eb0: 20 69 6e 74 65 72 70 72 65 74 65 72 20 74 68 61   interpreter tha
2ec0: 74 20 63 61 6c 6c 73 20 54 63 6c 5f 49 6e 69 74  t calls Tcl_Init
2ed0: 28 29 2e 20 20 54 68 65 20 73 79 73 74 65 6d 0a  ().  The system.
2ee0: 56 46 53 20 74 68 61 74 20 69 73 20 63 72 65 61  VFS that is crea
2ef0: 74 65 64 20 61 74 20 62 75 69 6c 64 20 74 69 6d  ted at build tim
2f00: 65 20 69 73 20 6d 6f 75 6e 74 65 64 20 61 74 20  e is mounted at 
2f10: 2f 2e 4b 49 54 44 4c 4c 5f 54 43 4c 2e 20 20 41  /.KITDLL_TCL.  A
2f20: 64 64 69 74 69 6f 6e 61 6c 6c 79 2c 0a 69 66 20  dditionally,.if 
2f30: 74 68 65 72 65 20 69 73 20 61 20 5a 49 50 20 66  there is a ZIP f
2f40: 69 6c 65 20 61 70 70 65 6e 64 65 64 20 74 6f 20  ile appended to 
2f50: 74 68 65 20 44 4c 4c 20 69 74 20 77 69 6c 6c 20  the DLL it will 
2f60: 62 65 20 6d 6f 75 6e 74 65 64 20 61 74 20 2f 2e  be mounted at /.
2f70: 4b 49 54 44 4c 4c 5f 55 53 45 52 0a 61 6e 64 20  KITDLL_USER.and 
2f80: 69 66 20 74 68 65 72 65 20 69 73 20 61 20 5a 49  if there is a ZI
2f90: 50 20 66 69 6c 65 20 61 70 70 65 6e 64 65 64 20  P file appended 
2fa0: 74 6f 20 74 68 65 20 65 78 65 63 75 74 61 62 6c  to the executabl
2fb0: 65 20 69 74 20 77 69 6c 6c 20 62 65 20 6d 6f 75  e it will be mou
2fc0: 6e 74 65 64 20 61 74 0a 2f 2e 4b 49 54 44 4c 4c  nted at./.KITDLL
2fd0: 5f 41 50 50 2e 20 20 41 6c 6c 20 56 46 53 65 73  _APP.  All VFSes
2fe0: 20 74 68 61 74 20 61 72 65 20 6d 6f 75 6e 74 65   that are mounte
2ff0: 64 20 68 61 76 65 20 74 68 65 20 22 6c 69 62 22  d have the "lib"
3000: 20 73 75 62 2d 64 69 72 65 63 74 6f 72 79 20 61   sub-directory a
3010: 70 70 65 6e 64 65 64 0a 74 6f 20 74 68 65 20 69  ppended.to the i
3020: 6e 74 65 72 70 72 65 74 65 72 73 20 22 61 75 74  nterpreters "aut
3030: 6f 5f 70 61 74 68 22 20 76 61 72 69 61 62 6c 65  o_path" variable
3040: 2e 0a                                            ..