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 ..