home *** CD-ROM | disk | FTP | other *** search
/ Usenet 1994 January / usenetsourcesnewsgroupsinfomagicjanuary1994.iso / answers / tcl-faq / part2 < prev    next >
Text File  |  1993-12-17  |  53KB  |  1,511 lines

  1. Newsgroups: comp.lang.tcl,comp.answers,news.answers
  2. Path: senator-bedfellow.mit.edu!bloom-beacon.mit.edu!usc!howland.reston.ans.net!math.ohio-state.edu!caen!malgudi.oar.net!chemabs!lvirden
  3. From: lwv26@cas.org (Larry W. Virden)
  4. Subject: FAQ: comp.lang.tcl Frequently Asked Questions (2/5)
  5.     (Last updated: December 17, 1993)
  6. Message-ID: <tcl.p2_756137861@cas.org>
  7. Followup-To: comp.lang.tcl
  8. Summary: A regular posting of the comp.lang.tcl Frequently Asked Questions 
  9.     (FAQ) and their answers.  This is the second of five parts.
  10.     This part covers the how-to questions and answers.
  11. Originator: lwv26@srv01s4
  12. Keywords: tcl, expect, extended tcl, wish, tk
  13. Sender: lvirden@cas.org
  14. Supersedes: <tcl.p2_753975163@cas.org>
  15. Reply-To: lvirden@cas.org (Larry W. Virden)
  16. Organization: Chemical Abstracts Service
  17. References: <tcl.p1_756137861@cas.org>
  18. Date: Fri, 17 Dec 1993 14:17:56 GMT
  19. Approved: news-answers-request@MIT.Edu
  20. Expires: Fri, 28 Jan 1994 14:17:41 GMT
  21. Lines: 1487
  22. Xref: senator-bedfellow.mit.edu comp.lang.tcl:9439 comp.answers:3072 news.answers:15930
  23.  
  24. Archive-name: tcl-faq/part2
  25. Version: 4.4
  26. Last-modified: December 17, 1993
  27.  
  28. Please do not be offended if I neglect to acknowledge your contribution
  29. to this FAQ!  I sometimes forget to put an attribution in.  I especially
  30. try to add them if it appears that there is further experimentation or
  31. debugging being done though.
  32.  
  33.     For more information concerning Tcl (see "tcl-faq/part1"),
  34. (see "tcl-faq/part3"), (see "tcl-faq/part4"), or (see "tcl-faq/part5").
  35.  
  36. Index of questions:
  37.  
  38. VIII. Questions on building Tcl and friends on your system:
  39.     Q8A. Is there anywhere I can find help with the details of getting 
  40.         Tcl to work on my machine?
  41.     Q8B. Why does the link step says that some of the functions Tcl,
  42.         needs are missing when I am trying to build it?
  43.     Q8C. Has anyone built Tcl 6 on an RS/6000 AIX 3.1? 
  44.     Q8D. Has anyone gotten Tcl to compile under HP-UX?
  45.     Q8E. Has anyone gotten Tcl to compile under VMS?
  46.     Q8F. What does it take to get Tcl to compile under SCO Unix?
  47.     Q8G. Why do I get format and scan errors when I run tclTest
  48.         (NeXT, AIX, etc.)?
  49.     Q8H. Why do I get lots of errors under Irix 4.0.1 when I run
  50.         tclTest?
  51.     Q8I. Does anyone else have problems with Tcl on a Cray?
  52.     Q8J. Does anyone know how to get Tk to run on a SparcBook or other
  53.         laptop with a limited number of colors?
  54.     Q8K. What does it take to get Tcl/Tk to compile on 386bsd/Linux 
  55.         or other POSIX/ANSI C systems not already supported?
  56.     Q8L. Can anyone help me build tcl 6.7 under NextStep 3.0?
  57.     Q8M. Why do I get a parse error in tkInit.c when I try to compile
  58.         Tk on my Irix machine?
  59.     Q8N. What do I need to do to install Tcl 7.x/Tk 3.x on NeXTSTEP 3.1?
  60.     Q8O. Why can't I print the draft of the Tcl/Tk book?
  61.  
  62. IX.  How, in Tcl, can I XXX:
  63.     Q9A. get association lists or property lists?
  64.     Q9B. call one proc with the multi parameter value returned by 
  65.         another proc?
  66.     Q9C. pass an array into a proc?
  67.     Q9D. pipe output of a command back into a Tcl parsing procedure?
  68.     Q9E. merge extended Tcl into other programs such as wish or expect?
  69.     Q9F. delete a procedure from within a script?
  70.     Q9G. get parray to recognize an array variable I have created
  71.         via upvar?
  72.     Q9H. get more than 7 digits of double precision?
  73.     Q9I. grab the command line whenever a non-built-in call is made?
  74.     Q9J. get or set an environment variable?
  75.     Q9K. use numbers with leading zeroes?
  76.     Q9L. find the command line arguments to my application?
  77.     Q9M. put comments in my script, for example in a case statement?
  78.     Q9N. redirect stdin or stdout safely, including binary data?
  79.     Q9O. trap signals, and other more Unix specific functions?
  80.     Q9P. get quoted strings to work the way I want?
  81.     Q9Q. share procedures between multiple tcl applications?
  82.  
  83. X.  How, in Tk, can I XXX:
  84.     A. Question on starting Tk applications
  85.  
  86.     Q10.A.1. get my wish application to execute - I just get a wish prompt!
  87.     Q10.A.2. ,using a machine with less than 8 bit color, run?
  88.     Q10.A.3. set X11 resources for a wish application in an 
  89.         app-defaults file?
  90.     Q10.A.4. specify bitmap patterns on the command line instead of 
  91.         as a file name?
  92.     Q10.A.5. get a Motif user interface?
  93.     Q10.A.6. get an OpenLook user interface?
  94.     Q10.A.7. get Tk 3.3 to even start - I get security error messages.
  95.  
  96.     B. Questions on Tk applications and the keyboard
  97.  
  98.     Q10.B.1. change the default class bindings?
  99.     Q10.B.2. delete a binding?
  100.     Q10.B.3. change a binding while it is being executed?
  101.     Q10.B.4. bind the arrow key on my Sun keyboard?
  102.     Q10.B.5. get root's mouse bindings to work in my Tk application?
  103.  
  104.     C. Questions on Tk and X11 interactions
  105.  
  106.     Q10.C.1. get an application to also use libXt?
  107.     Q10.C.2. change the X11 cursor?
  108.     Q10.C.3. raise or lower a window?
  109.     Q10.C.4. re-map a withdrawn window id?
  110.     Q10.C.5. use Tk in a subwindow of a non-Tk X11 application?
  111.     Q10.C.6. bind <Enter> and <Leave> to a frame containing other widgets?
  112.  
  113.     D. Questions on Tk listboxes
  114.  
  115.     Q10.D.1. resize a listbox?
  116.     Q10.D.2. select two items that are not adjacent in the listbox at 
  117.         one time?
  118.     Q10.D.3. select items in more than one Tk listbox at a time?
  119.     Q10.D.4. avoid fractional white space at the end of a resizable listbox?
  120.  
  121.     E. Questions on Tk canvases
  122.  
  123.     Q10.E.1. get output from a Tk canvas?
  124.     Q10.E.2. fill a canvas which is bounded by lines as opposed to a
  125.         shape like a polygon, oval, etc.?
  126.     Q10.E.3. raise/lower canvas window objects or draw graphics onto a 
  127.         window object inside a canvas?
  128.     Q10.E.4. detect when the canvas has been resized?
  129.  
  130.     F. Other questions
  131.  
  132.     Q10.F.1. get the name of my own interpreter?
  133.     Q10.F.2. get -relief to work on my text widgets?
  134.     Q10.F.3. create a scrollable window of buttons?
  135.     Q10.F.4. pack a text widget so that it can be resized interactively?
  136.     Q10.F.5. create a widget with an upper case name?
  137.     Q10.F.6. create equal sized buttons?
  138.     Q10.F.7. vertically stack radio buttons aligning regardless of font?
  139.  
  140. End of FAQ Index
  141.  
  142. ----------------------------------------------------------------------
  143.  
  144. ------------------------------
  145.  
  146. From: -VIII- Questions on building Tcl and friends on your system
  147. Subject: -Q8A- Is there anywhere I can find help with the details of 
  148.         getting Tcl to work on my machine?
  149.  
  150. A8A. Glad you asked!  Look in the Tcl distribution for the file called
  151. "porting.notes".  This will contain a collection of notes that various people
  152. have provided about porting Tcl to various machines and operating systems.
  153. There are also a file called "README" which should be read FIRST - before
  154. doing anything else with the code (this should always be one's first
  155. step with any package).  Finally, there is a "changes" file which details
  156. what has changed since the last release - be sure to read this to see
  157. what might need to change in your programs.
  158.  
  159. ------------------------------
  160.  
  161. From: -VIII- Questions on building Tcl and friends on your system
  162. Subject: -Q8B- Why does the link step says that some of the functions Tcl,
  163.         needs are missing when I am trying to build it?
  164.  
  165. A8B. Did you run the "config" program first, by doing a "csh ./config" or
  166. equivalent?  Without doing this, things such as strtoul or strerror
  167. are sometimes mentioned as missing.
  168.  
  169. Tcl includes equivalents for at least the following functions and include files
  170. which may not be found on some systems:
  171.  
  172. dirent.h       limits.h          stdlib.h         string.h
  173.  
  174. opendir.c      strerror.c     strstr.c         strtol.c        strtoul.c
  175.  
  176. strtod.c
  177.  
  178. ------------------------------
  179.  
  180. From: -VIII- Questions on building Tcl and friends on your system
  181. Subject: -Q8C- Has anyone built Tcl 6 on an RS/6000 AIX 3.1? 
  182.  
  183. A8C. See porting notes - especially the note about strtoul.
  184.  
  185. One user got Tcl to compile with a few minor source modifications
  186. (for example, duplicate case statements for errno and signal symbols in 
  187. tclUnixStr.c). 
  188.  
  189. A few other problems arose in the tests.  One is caused by AIX printf
  190. not formatting %#x and %#o correctly when the value to be printed is
  191. zero:  they print "0x0" and "00" instead of "0" and "0" respectively.
  192. This was reported as not a problem in earlier releases.  No fixes have
  193. been posted.
  194.  
  195. Finally, a problem occurs in open.test.  test 13.6 hangs because "cat"
  196. on the RS6000 is unbuffered.  A workaround is to change the execution
  197. of "cat" in open.test to do a "cat -u".
  198.  
  199. Dov Grobgeld <dov@menora.weizmann.ac.il> provided info on creating Tcl
  200. and Tk shared libraries under AIX 3.1.5:
  201.  
  202. For Tcl:
  203.  
  204. cc -o tkshar.o *.o -bE:tclshar.exp -bM:SRE -berok -lX11 -lm
  205. ar r libtclshr tclshar.o
  206.  
  207. For Tk:
  208.  
  209. cc -o tkshar.o *.o -bE:tkshar.exp -bM:SRE -berok -Ltcl -lX11 -lm -ltclshr
  210. ar r libtkshr tkshar.o
  211.  
  212. where tckshar.exp and tkshar.exp had lists of the external functions.
  213.  
  214. There are also problems with fonts on AIX and the IBM.  A patch is needed
  215. from IBM to fix the X server so that fonts are working
  216.  
  217. ------------------------------
  218.  
  219. From: -VIII- Questions on building Tcl and friends on your system
  220. Subject: -Q8D- Has anyone gotten Tcl to compile under HP-UX?
  221.  
  222. A8D. See the porting notes.
  223.  
  224. ------------------------------
  225.  
  226. From: -VIII- Questions on building Tcl and friends on your system
  227. Subject: -Q8E- Has anyone gotten Tcl to compile under VMS?
  228.  
  229. A8E. Information from jkimball@src.honeywell.com (John Kimball) on
  230. May 4, 1993 was that he had gotten Tcl 6.7 and Tk 3.2 ported to VMS
  231. 5.5.  See the catalog for the file information.
  232.  
  233. ------------------------------
  234.  
  235. From: -VIII- Questions on building Tcl and friends on your system
  236. Subject: -Q8F- What does it take to get Tcl to compile under SCO Unix?
  237.  
  238. A8F. Add a "#undef select" to tkEvent.c, and remove the reference to 
  239. TK_EXCEPTION around line 460 of main.c.
  240.  
  241. Tk uses its own scheme for allocating the border colors for its 3D
  242. widgets, which causes problems when running TK on a system with
  243. "PseudoColor" display class, and a 16-cell colormap.
  244.  
  245. If you can't go to eight bitplanes, you can instead start the server
  246. with a "-static" (Xsco) or "-analog" (Xsight) option, making the
  247. display class become "StaticColor".  This makes the entire colormap
  248. read-only, and it will return the color that most closely maps to the
  249. desired color as possible.
  250.  
  251. This information is from Keith Amann <Keith_Amann@stortek.com>
  252.  
  253. ------------------------------
  254.  
  255. From: -VIII- Questions on building Tcl and friends on your system
  256. Subject: -Q8G- Why do I get format and scan errors when I run tclTest
  257.         (NeXT, AIX, etc.)?
  258.  
  259. A8G. That's a problem (scanf/printf) many systems seem to have.  Don't
  260. worry too much about it - just don't use these 'advanced' features.  If
  261. you're hacking C, you'll have the same problems.
  262.  
  263. ------------------------------
  264.  
  265. From: -VIII- Questions on building Tcl and friends on your system
  266. Subject: -Q8H- Why do I get lots of errors under Irix 4.0.1 when I run
  267.         tclTest?
  268.  
  269. A8H. There's a bug in the 4.0.1 optimizer that's fixed in 4.0.2.
  270. Compile tclVar.c using -O0 (no optimization).
  271.  
  272. ------------------------------
  273.  
  274. From: -VIII- Questions on building Tcl and friends on your system
  275. Subject: -Q8I- Does anyone else have problems with Tcl on a Cray?
  276.  
  277. A8I. See the porting notes for a set of changes mentioned.  Also,
  278. Booker C. Bense <benseb@grumpy.sdsc.edu> reports that version 3.0.1.6
  279. has some real problems with char pointers, causing Tcl to crash.  Using
  280. version 3.0.2.1, things are much better, except for a minor formatting
  281. problem and serious problems with scan.
  282.  
  283. ------------------------------
  284.  
  285. From: -VIII- Questions on building Tcl and friends on your system
  286. Subject: -Q8J- Does anyone know how to get Tk to run on a SparcBook or other
  287.         laptop with a limited number of colors?
  288.  
  289. A8J. On a SparcBook, if you start openwin (the OpenWindows server starting
  290. command) as:
  291.  
  292. openwin -dev "/dev/fb staticvis"
  293.  
  294. you get a static visual color model that Tk copes with better than the
  295. default.  Some things are ugly, but not as ugly as monochrome.
  296.  
  297. ------------------------------
  298.  
  299. From: -VIII- Questions on building Tcl and friends on your system
  300. Subject: -Q8K- What does it take to get Tcl/Tk to compile on 386bsd/Linux 
  301.         or other Posix/ANSI C systems not already supported?
  302.  
  303. A8K. Patches for 386BSD were posted to comp.lang.tcl back in Nov. 1992 to
  304. alt.sources.  See one of the ftp archive sites for this group for them.
  305. Basically, there were some setting of defines and a few places where 
  306. const char * had to be used in place of char *.  
  307.  
  308. ------------------------------
  309.  
  310. From: -VIII- Questions on building Tcl and friends on your system
  311. Subject: -Q8L- Can anyone help me build tcl 6.7 under NextStep 3.0?
  312.  
  313. A8L. Put #include <sys/time.h> near the top of tclUnixAZ.c.
  314. Thanks to Michael B. Johnson <wave@media.mit.edu>.
  315.  
  316. ------------------------------
  317.  
  318. From: -VIII- Questions on building Tcl and friends on your system
  319. Subject: -Q8M- Why do I get a parse error in tkInit.c when I try to compile
  320.         Tk on my Irix machine?
  321.  
  322. A8M. Jon Knight <J.P.Knight@loughborough.ac.uk> reports that the version of
  323. Irix that he is using doesn't define a uid_t.  One needs to define one 
  324. somewhere (or comment out the lines causing the problems) to get the compile
  325. to continue.
  326.  
  327. ------------------------------
  328.  
  329. From: -VIII- Questions on building Tcl and friends on your system
  330. Subject: -Q8N- What do I need to do to install Tcl 7.1/Tk 3.4 on NeXTSTEP 3.1?
  331.  
  332. Numerous folk have contributed to the following - I have given up
  333. trying to figure out who contributed what - sorry!
  334.  
  335.  
  336. The notes in the 'porting.notes' file are slightly wrong for NS 3.2.  To
  337. compile a multi-architecture, fully optimized tcl7.3 under NS3.2 (BTW:
  338. NS3.2 is mostly posix-compliant;  unlike NS3.1):
  339.  
  340. {the following notes are for use in csh)
  341.  
  342. 1. Run configure with predefined CPP:
  343.         (setenv CPP 'cc -E';setenv ; ./configure)
  344.  
  345. 2. Edit Makefile:
  346.         - add tmpnam.o to COMPAT_OBJS, and remove strtod.o (is there any
  347. reason to use the compat version of strtod() over the one included in the
  348. NeXT-supplied libraries?)
  349.                 COMPAT_OBJS = getcwd.o waitpid.o tmpnam.o
  350.         - add '-m' to MATH_LIBS
  351.                 MATH_LIBS = -m -lm
  352.         - add '-O2 -arch m68k -arch i386' to CFLAGS
  353.                 CFLAGS = -O2 -arch i386 -arch m68k
  354.  
  355. Later, Michael B. Johnson <wafe@media.mit.edu) indicated that the 
  356. reason you use the compatibility version of strtod() is because
  357. NeXT's is buggy.  You have to rename
  358. the compat's version to something like tclStrtod() and then
  359. modify the few references to strtod() so that you can include
  360. Tcl in a dynamically loaded bundle like an InterfaceBuilder palette.
  361.  
  362. Also, make sure you have -arch m68k in your CFLAGS (if of course that
  363. is the case) since that avoids problems in pre-3.2 systems.
  364.  
  365.  
  366. ------------------------------
  367.  
  368. From: -VIII- Questions on building Tcl and friends on your system
  369. Subject: -Q8O- Why can't I print the draft of the Tcl/Tk book?
  370.  
  371. A8O.  From ouster@cs.Berkeley.EDU (John Ousterhout):
  372.  
  373. Here's my form letter that seems to explain most of the problems people
  374. have had printing parts of the book:
  375.  
  376. Some old versions of the Transcript spooler software cannot properly
  377. handle encapsulated Postscript files within another Postscript file
  378. when they do page reversal.  They tend to garble the page structure of
  379. the file, causing an error at the point of the first EPS file.  Part
  380. II of the Tcl book has lots of EPS files embedded in it, one for
  381. each screen dump.  If your printer cannot print this file I suggest
  382. checking to see if page reversal is enabled for your printer.  If
  383. so, try asking your local system wizard to disable it for you;  this
  384. should allow the file to print.  Or, find some other way to dump the
  385. Postscript file directly to the printer without going through the
  386. spooling software (e.g. perhaps you can simply cat it to the printer's
  387. serial port).
  388.  
  389. Others have suggested:
  390.  
  391.  The embedded pictures have CR as the line separator instead of LF and
  392.  this may be causing the problem. Try translating them to LFs ...
  393.  
  394.    tr '\015' '\012' <book.p2.ps >fixedbook.p2.ps
  395.  
  396. and:
  397.  
  398.  This is not the original poster's problem but in countries using A4
  399.  paper and on a particular printer, the Dataproducts LZR1260E, the frame
  400.  size causes the printing to be stretched vertically. This happens with
  401.  other Framemaker generated documents by the way. A PS interpreter bug
  402.  no doubt. The fix is to edit the dimensions for A4 paper. This shell
  403.  script does both fixes.
  404.  
  405. #!/bin/sh
  406. cat $1 | tr '\015' '\012' | sed '/FMDOCUMENT$/s/612 792/595 842/'
  407.  
  408. ------------------------------
  409.  
  410. From: -IX-  How, in Tcl, can I XXX:
  411. Subject: -Q9A- association lists or property lists?
  412.  
  413. A9A. Use Extended Tcl arrays or keyed lists.
  414.  
  415. For example, if you did a:
  416.  
  417. keylset ttyFields ttyName tty1a
  418. keylset ttyFields baudRate 57600
  419. keylset ttyFields parity strip
  420.  
  421. And then an "echo $ttyFields", you'd get:
  422.  
  423.     {ttyName tty1a} {baudRate 57600} {parity strip}
  424.  
  425. ------------------------------
  426.  
  427. From: -IX-  How, in Tcl, can I XXX:
  428. Subject: -Q9B- call one proc with the multi parameter value returned by 
  429.         another proc?
  430.  
  431. A9B. Assuming y requires multiple args and x returns multiple words, use 
  432.     Tcl's eval command :
  433.  
  434.     eval y [x]
  435.  
  436. ------------------------------
  437.  
  438. From: -IX-  How, in Tcl, can I XXX:
  439. Subject: -Q9C- pass an array into a proc?
  440.  
  441. A9C. Use upvar rather than try to use global variables when possible.  If
  442. the function is event driven, you are forced to use global variables.
  443.  
  444.  
  445. # print elements of an array
  446. proc show_array arrayName {
  447.     upvar $arrayName myArray
  448.  
  449.     foreach element [array names myArray] {
  450.        puts stdout "${arrayName}($element) =  $myArray($element)"
  451.     }
  452. }
  453.  
  454. set arval(0) zero
  455. set arval(1) one
  456. show_array arval
  457.  
  458.  
  459. To return an array from a procedures, just take the array name in as an
  460. argument, as above.  Any changes you make in the array will be made in
  461. the parent's array as well.
  462.  
  463. Extended Tcl introduces a concept called keyed lists which are arrays
  464. made out of lists of key-value pairs and can be passed by value to routines,
  465. over networks, etc.
  466.  
  467. ------------------------------
  468.  
  469. From: -IX-  How, in Tcl, can I XXX:
  470. Subject: -Q9D- pipe output of a command back into a Tcl parsing 
  471.         procedure?
  472.  
  473. A9D. For example, to grep a pattern out of a range of files, one might
  474. do:
  475.  
  476. karl@NeoSoft.com (Karl Lehenbauer) writes:
  477.  
  478. set files [glob /home/cole/stats/*]
  479.  
  480. proc parseInfo { site } {
  481.    global files
  482.  
  483. #
  484. # site is chosen from a listbox earlier
  485. #
  486.    set in [open [concat "|/usr/bin/grep $site $files"] r]
  487.  
  488.    while {[gets $in line]>-1} {
  489.       puts stderr $line
  490.    }
  491.    catch {close $in}
  492. }
  493.  
  494. One thing:  the matching strings are _not_ returned in directory order.
  495.  
  496. But what if I want to check the return code AND use the output of 
  497. the command?  kennykb@dssv01.crd.ge.com (Kevin B. Kenny) writes:
  498.  
  499. if [catch {exec ls} data] {
  500.         # The exec got an error, and $errorCode has its termination status
  501. } else {
  502.         # The exec succeeded
  503. }
  504. # In any case, `data' contains all the output from the child process.
  505.  
  506. Note that Karl Lehenbauer adds that errorCode will be a list containing
  507. three elements, the string "CHILDSTATUS", the process ID of the child,
  508. and the exit status of the child.
  509.  
  510. ------------------------------
  511.  
  512. From: -IX-  How, in Tcl, can I XXX:
  513. Subject: -Q9E- merge extended Tcl into other programs such as wish or expect?
  514.  
  515. A9E. The latest version of extended Tcl, tclX 6.7c, has been enhanced to
  516. make it easier to incorporate into applications.
  517.  
  518. ------------------------------
  519.  
  520. From: -IX-  How, in Tcl, can I XXX:
  521. Subject: -Q9F- delete a procedure from within a script?
  522.  
  523. A9F. rename procedureName ""
  524.  
  525. ------------------------------
  526.  
  527. From: -IX-  How, in Tcl, can I XXX:
  528. Subject: -Q9G- get parray to recognize an array variable I have created
  529.         via upvar?
  530.  
  531. A9G. Right now (June, 1992) upvar doesn't allow you to attach to an
  532. individual element of an array.  This is considered a bug by 
  533. Mr. Ousterhout and has been place on a bug list.
  534.  
  535. ------------------------------
  536.  
  537. From: -IX-  How, in Tcl, can I XXX:
  538. Subject: -Q9H- get more than 7 digits of double precision ?
  539.  
  540. A9H. Modify the tclExpr.c module to use %lf instead of %g.
  541.  
  542. ------------------------------
  543.  
  544. From: -IX-  How, in Tcl, can I XXX:
  545. Subject: -Q9I- grab the command line whenever a non-built-in call is made?
  546.  
  547. A9I. The procedure "unknown" is called automatically with arguments 
  548. containing the command and its arguments for any command that couldn't be 
  549. found.  In fact, Tcl and Extended Tcl use this feature to provide demand
  550. loaded commands, and even entire libraries.
  551.  
  552. So by modifying the unknown procedure you can provide your own extended
  553. functionality, or even remove the demand loading capability if you so
  554. desire.
  555.  
  556. ------------------------------
  557.  
  558. From: -IX-  How, in Tcl, can I XXX:
  559. Subject: -Q9J- get or set an environment variable?
  560.  
  561. A9J. By using something like the following.
  562.  
  563. set olddisplay $env(DISPLAY)
  564. set env(DISPLAY) unix:0
  565.  
  566. Thanks to "Joel Fine" <joel@cs.berkeley.edu> for the answer.
  567.  
  568. ------------------------------
  569.  
  570. From: -IX-  How, in Tcl, can I XXX:
  571. Subject: -Q9K- use numbers with leading zeroes?
  572.  
  573. A9K. Dave Morriss was recently having problems because he was trying
  574. to do something like:
  575.  
  576. set index [expr [exec date +%W]%[llength $pop_server_list]]
  577.  
  578. but during the 9th and 9th week of the year, he got errors - 08 and 09
  579. are not valid octal numbers in Tcl.
  580.  
  581. Some of the solutions provided were:
  582.  
  583. From George A. Howlett <george.howlett@att.com>, we got:
  584.  
  585. set wknum [format "%g" [exec date +%W]]
  586. set index [expr [exec $wknum%[llength $pop_server_list]]
  587.  
  588. From Fred Feirtag <feirtag@wave.nrl.navy.mil> :
  589.  
  590. set index [expr (1[exec date +%W]-100)%[llength $pop_server_list]]
  591.  
  592. From Dan R. Schenck <schendr@Texaco.COM>:
  593.  
  594. set index [expr [string trimleft [exec date +%W] 0]%[llength $pop_server_list]]
  595.  
  596. ------------------------------
  597.  
  598. From: -IX-  How, in Tcl, can I XXX:
  599. Subject: -Q9L- find the command line arguments to my application?
  600.  
  601. A9L.  If you are using extended Tcl or Expect, you will find the parameters in
  602. the Tcl variable argv as a list.  Note that in extended Tcl, the name of 
  603. the program is in the Tcl variable programName and NOT in argv[0].  Thanks to
  604. brad@NeoSoft.com (Brad Morrison) and bachww@rtsg.mot.com (Bud Bach) for
  605. this answer.
  606.  
  607. ------------------------------
  608.  
  609. From: -IX-  How, in Tcl, can I XXX:
  610. Subject: -Q9M- put comments in my script, for example in a case statement?
  611.  
  612. A9M. You can't have comments where you have them.  Move the comments inside
  613. of the "{" for the case that you want.  Your code should read:
  614.  
  615. case 1 {
  616.   -1    {
  617.         #
  618.         # Cannot find information sought
  619.         #
  620.         exit 2
  621.         }
  622.    0    {
  623.         #
  624.         # Error in arguments
  625.         #
  626.         exit 1
  627.         }
  628.    default    {
  629.         #
  630.         # Desired information found
  631.         #
  632.         exit 0
  633.         }
  634. }
  635.  
  636. Thanks to gwlester@cpu.com (Gerald W. Lester).
  637.  
  638. ------------------------------
  639.  
  640. From: -IX-  How, in Tcl, can I XXX:
  641. Subject: -Q9N- redirect stdin or stdout safely, including binary data?
  642.  
  643. A9N. With Extended Tcl you can safely do stuff like:
  644.  
  645.         set infp [open "|compress -dc $fileName"]
  646.         set outfp [open "|gzip -c $newFileName" w]
  647.  
  648.         copyfile $infp $outfp
  649.  
  650. Thanks to karl@NeoSoft.com (Karl Lehenbauer) for the code example.
  651.  
  652. ------------------------------
  653.  
  654. From: -IX-  How, in Tcl, can I XXX:
  655. Subject: -Q9O- trap signals, and other more Unix specific functions?
  656.  
  657. A9O. Extended Tcl offers many of these types of functions.  For instance,
  658. extended Tcl has the 'signal' command:
  659.  
  660.         signal action siglist [command]
  661.  
  662.         where action is one of "default", "ignore", "error", "trap", "get",
  663.         plus the POSIX "block" and "unblock" actions (available only on
  664.         POSIX systems, of course).  Siglist is a list of either the symbolic
  665.         or numeric Unix signal (the SIG prefix is optional).  Command is your
  666.         error handler (or a simple {puts stdout "Don't press *that* key!"}  :-)
  667.  
  668. "trap" does what you expect, and I find "error" and "get" to be
  669. extremely useful in interactive programs which demand keyboard
  670. traversal.
  671.  
  672. Extended Tcl also has things like fork, etc.
  673.  
  674. Answer by brad@NeoSoft.com (Brad Morrison).
  675.  
  676. ------------------------------
  677.  
  678. From: -X-  How, in Tcl, can I XXX:
  679. Subject: -Q9P- get quoted strings to work the way I want?
  680.  
  681. A long article dealing with the issues can be found at
  682. ftp://harbor.ecn.purdue.edu/pub/tcl/docs/README.programmer
  683.  
  684. Here are some short answers:
  685.  
  686. Q. I'm trying to build up a command for later execution but am
  687. having trouble with variable values that include whitespace
  688. or special characters.
  689.  
  690. A. The safest way to build up commands is to use the list command
  691. so that you can keep track of the list structure.  Avoid using
  692. double quotes because you can end up with an extra trip through
  693. the evaluator.  We'll illustrate this with a command to create
  694. a button that prints out the label on the button when you click it.
  695.     Wrong answer #1:
  696.     button $myname -text $label -command "puts stdout $label"
  697.     Why? because if $label has whitespace then the puts command will
  698.     be passed the wrong number of arguments.  If $label has $ or [ ]
  699.     characters, they will be interpreted instead of printed.
  700.     Good answer #2:
  701.     button $myname -text $label -command [list puts stdout $label]
  702.     Why? because list will properly quote the value of $label
  703.  
  704. Q. I'm trying to build up a command for later execution but am
  705. having trouble getting some variables to evaluate now, and some
  706. to evaluate later when the command is run.
  707.  
  708. A. The cleanest way to do this is to define a procedure that hides
  709. the use of the variables at run time, and then build up a call to
  710. that procedure using the list command as described previously.  (You
  711. can even define the procedure on the fly.  It will have global scope
  712. even it if is created within another procedure.)
  713.     Wrong answer #1:
  714.     button $myname -text $label -command \
  715.         [list puts stdout $ArrayOfDynamicStuff($label)]
  716.     Why? The array value will be substituted when the button is created,
  717.     not later on when the button is clicked.  Also, note that the
  718.     command is executed at the global scope, so it is not necessary
  719.     to include a "global ArrayOfDynamicStuff" in the command.
  720.     Wrong answer #2 (backquotes and list):
  721.     button $myname -text $label -command \
  722.         [list puts stdout \$ArrayOfDynamicStuff($label)]
  723.     Why? Here the list command and the backquote of $ are fighting with
  724.     each other.  The command ends up being something like:
  725.         puts stdout {$ArrayOfDynamicStuff(foo)}
  726.     which prevents the substitution of the value of the array element.
  727.     Dubious answer #3 (backquotes and double-quotes):
  728.     button $myname -text $label -command \
  729.         "puts stdout \$ArrayOfDynamicStuff($label)"
  730.     Why? This only works if the value of $label has no special characters
  731.     or whitespace.
  732.     Clean answer #4 (proc):
  733.     proc doit { i } {
  734.         global ArrayOfDynamicStuff
  735.         puts stdout $ArrayOfDynamicStuff($i)
  736.     }
  737.     button $myname -text $label -command [list doit $label]
  738.     Why? Using little TCL procs for your button commands is a good habit
  739.     because it eliminates most needs for fancy quoting, and it
  740.     makes it easier to tweak the button command later on.
  741.  
  742. Q. I'm trying to pass along a variable number of args to another procedure
  743. but I'm having trouble getting the $args to expand right.
  744.  
  745. A. Avoid using eval and double quotes because that results in
  746. an extra trip through the interpreter.  The eval command will do
  747. a concat of its arguments if there are more than one, so that
  748. pretty much eliminates the need to group things with double quotes.
  749. Let's extend the button example:
  750.     Wrong answer #1:
  751.     proc mybutton { myname label args } {
  752.         button $myname -text $label -command [list puts stdout $label] $args
  753.     }
  754.     Why? All the extra arguments to mybutton are grouped into one list element
  755.     that is but into the value of $args.  However, the button command
  756.     expects to see individual arguments, not a sub-list.
  757.     Wrong answer #2:
  758.     proc mybutton { myname label args } {
  759.         eval "button $myname -text $label -command [list puts stdout $label] $args"
  760.     }
  761.     Why? The double quotes allow expansion of $label as well as $args, so if
  762.     $label has any whitespace, the button command will be malformed
  763.     Good answer #3:
  764.     proc mybutton { myname label args } {
  765.         set cmd {button $myname -text $label -command [list puts stdout $label]}
  766.         eval $cmd $args
  767.     }
  768.     Why? Eval will first concatenate its two arguments and then run the
  769.     result through the interpreter.  Think of this as stripping off the
  770.     outer curly braces from $cmd and $arg and making a single list
  771.     with all the elements of both.  $label will be evaluated exactly
  772.     once, so the puts command will remain good, and whatever went into
  773.     args will also be processed exactly one time.
  774.  
  775. Q. Why do I get a syntax error in an if/while/for statement?
  776. A. You may have written something like
  777.     wish: set foo bar
  778.     wish: if {$foo == bar} {puts stdout bar}
  779.     syntax error in expression "$foo == bar"
  780.  
  781. in which bar is interpreted as neither a string nor a variable, since
  782. strings as operands in expressions MUST be surrounded by double quotes
  783. or braces. 
  784.  
  785. Change to
  786.     wish: if {$foo == "bar"} {puts stdout bar}
  787. or
  788.     wish: if {$foo == {bar}} {puts stdout bar}
  789.  
  790. always in expressions, depending on if you want expansion performed or
  791. not. 
  792.  
  793. Contributed by "Jesper Blommaskog" <d9jesper@dtek.chalmers.se>
  794.  
  795. ------------------------------
  796.  
  797. From: -X-  How, in Tcl, can I XXX:
  798. Subject: -Q9Q- share procedures between multiple tcl applications?
  799.  
  800. A9Q.  Rather than sourceing the files explicitly, build a tcl library:
  801.  
  802. Step 1.  Put the files in a common directory
  803.  
  804. Step 2.  Build the tclIndex for the "library".  I use a Makefile with
  805. a convention like:
  806.  
  807. install.index:
  808.         (cd ${DESTDIR}/tclscripts/lib; \
  809.         echo 'source /usr/local/lib/tcl/init.tcl;\
  810.      auto_mkindex . *.tk' | tcl ; exit 0)
  811.  
  812. Step 3. Modify your tcl scripts to reference the library:
  813.  
  814. e.g.:
  815.  
  816. # local additions
  817. lappend auto_path /usr/local/lib/tcl_local $env(RDS_TCL_SCRIPTS)/lib
  818.  
  819. Now, as soon as your script tried to reference a procedure in the library,
  820. the "unknown" command autoloads the procedure for you.
  821.  
  822. Contributed by Joe VanAndel <vanandel@ncar.ucar.edu>
  823.  
  824. ------------------------------
  825.  
  826. From: -X-  How, in Tk, can I XXX:
  827. Subject: -Q10.A.1- get my wish application to execute - I just get a
  828.         wish prompt!  Or I just get error msgs about permission
  829.         denied, not found, etc.
  830.  
  831. A10.A.1. Most systems require a full pathname to the interpreter.  
  832. So you cannot start a wish script out as 
  833.  
  834. #! wish -f
  835.  
  836. Likewise, many Unix systems have a maximum length of characters that you can
  837. put on a #! line.  If you exceed this, you do not get the behaviour you
  838. expect.  So do not try to put something like:
  839.  
  840. #! /projects/somethingbig/bin/sun4/wish -f
  841.  
  842. followed by your wish code.  Keep the lines short - under 32 characters is
  843. recommended.
  844.  
  845. Finally, on some machines, white space after the -f causes a problem.  Be
  846. sure that the -f are the last characters on the first line of the file.
  847.  
  848. ------------------------------
  849.  
  850. From: -X-  How, in Tk, can I XXX:
  851. Subject: -Q10.A.2- ,using a machine with less than 8 bit color, run?
  852.  
  853. A10.A.2. Tk doesn't behave very well with less than 8-bit color screens.  To
  854. try to use it, find all the places in the Tk/wish source where 
  855. DefaultDepthOfScreen is invoked to test the number of bit-planes.  Change all
  856. of these to pretend there is just 1 bit-plane, or call a procedure which
  857. monitors a Tcl variable so that it is configurable, and you should be okay.
  858.  
  859. Another alternative is to see if the server you are using has alternative
  860. visual / color models, such as static visual, etc.  One of the alternatives
  861. may allow Tk to work better.
  862.  
  863. Thanks to "Nathaniel Borenstein" <nsb@thumper.bellcore.com> for this info!
  864.  
  865. ------------------------------
  866.  
  867. From: -X-  How, in Tk, can I XXX:
  868. Subject: -Q10.A.3- set X11 resources for a wish application in an 
  869.         app-defaults file?
  870.  
  871. A10.A.3. Read the documentation for the option command.
  872. Then you should consider something like the following - assume the program
  873. name is xwf.
  874.  
  875. The following are two general purpose functions to put into a library:
  876.  
  877. # envVal envValName
  878. #   Looks up the envValName environment variable and returns its
  879. #   value, or {} if it does not exists
  880. proc envVal {envValName} {
  881.   global env
  882.   if [info exists env($envValName)] {return $env($envValName)} {return {}}
  883. }
  884.  
  885. # loadAppDefaults classNameList ?priority?
  886. #   Searches for the app-default files corresponding to classNames in
  887. #   the order specified by X Toolkit Intrinsics, and loads them with
  888. #   the priority specified (default: startupFile).
  889. proc loadAppDefaults {classNameList {priority startupFile}} {
  890.   set filepath "[split [envVal XUSERFILESEARCHPATH] :] \
  891.         [envVal XAPPLRESDIR] \
  892.         [split [envVal XFILESEARCHPATH] :] \
  893.         /usr/lib/X11"
  894.   foreach i $classNameList {
  895.     foreach j $filepath {
  896.       if {[file exists $j/$i]} {
  897.     option readfile $j/$i $priority; break
  898.       }
  899.     }
  900.   }
  901. }
  902.  
  903. # Now, here is what you would put into xwf:
  904.  
  905. option add Tk.BoldFont "*-lucida sans-Bold-R-Normal-*-100-*" widgetDefault
  906. loadAppDefaults {xwf XWF} userDefault
  907.  
  908. This sets a program default, then load any defaults specified in the user's
  909. default resources and finally any site or general app-defaults resource.  
  910. Of course, you would want to add some xwf command line handling to allow 
  911. the user to override things at execution time.
  912.  
  913. ------------------------------
  914.  
  915. From: -X-  How, in Tk, can I XXX:
  916. Subject: -Q10.A.4- specify bitmap patterns on the command line instead of 
  917.         just as a file name?
  918.  
  919. A10.A.4. You can not, at least as of June, 1992.
  920.  
  921. ------------------------------
  922.  
  923. From: -X-  How, in Tk, can I XXX:
  924. Subject: -Q10.A.5- get a Motif user interface?
  925.  
  926. A10.A.5. Tk does not currently use the Xt toolkit, so a strict adherence
  927. to Motif via the libXm.a routines is not possible.  However, the authors
  928. of Tk prefer the Motif style of user interface, so you will find that Tk
  929. makes quite an attempt to implement a Motif-like interface.
  930.  
  931. ------------------------------
  932.  
  933. From: -X-  How, in Tk, can I XXX:
  934. Subject: -Q10.A.6- get an OpenLook user interface?
  935.  
  936. A10.A.6. Unfortunately, Tk does not currently use either XView or Xt based
  937. widgets in its user interface, so an OpenLook compliant (or even
  938. similar) interface is probably not easily achievable in the near future.
  939.  
  940. ------------------------------
  941.  
  942. From: -X-  How, in Tk, can I XXX:
  943. Subject: -Q10.A.7- get Tk 3.3 to even start - I get security error messages.
  944.  
  945. A10.A.7.  Alternate forms of this question often mention that Tk 3.3 send
  946. is broken, or ask how to use xauth.
  947.  
  948. Under Tk 3.3, the X11 xauth security mechanism is used.  While this
  949. provides more security, it does require the user to do a bit more
  950. setup.  The user needs to create an Xauthority file (typically
  951. $HOME/.Xauthority) and then restart the X server with the
  952. -auth argument, along with the name of the Xauthority file created.
  953. Read the X11 documentation for your system for the details on how to
  954. use xauth or comparable software to create the authority files needed.
  955. An intro to xauth is available as
  956. ftp://harbor.ecn.purdue.edu/pub/tcl/docs/Xauthority .
  957.  
  958. Also note that you can configure Tk to not depend on xauth by modifying
  959. the tk3.3/Makefile.in to comment out the following:
  960.  
  961. # To turn off the security checks that disallow incoming sends when
  962. # the X server appears to be insecure, reverse the comments on the
  963. # following lines:
  964. #SECURITY_FLAGS =
  965. SECURITY_FLAGS = -DTK_NO_SECURITY
  966.  
  967. ------------------------------
  968.  
  969. From: -X-  How, in Tk, can I XXX:
  970. Subject: -Q10.B.1- change the default class bindings?
  971.  
  972. A10.B.1. All default class bindings for Tk widgets are initialized in
  973. $tk_library/tk.tcl.  Use this file as a guide to implement new
  974. bindings.  For instance, the following code duplicates Button 1's
  975. drag-select facility in Button 3 for all listboxes:
  976.  
  977. bind Listbox <3> {%W select from [%W nearest %y]}
  978. bind Listbox <B3-Motion> {%W select to [%W nearest %y]}
  979.  
  980. ------------------------------
  981.  
  982. From: -X-  How, in Tk, can I XXX:
  983. Subject: -Q10.B.2- delete a binding?
  984.  
  985. A10.B.2. Give an empty-string command to the "bind" invocation.  For
  986. example, to disable the Delete key in all entry fields:
  987.  
  988.     bind Entry <Delete> {}
  989.  
  990. ------------------------------
  991.  
  992. From: -X-  How, in Tk, can I XXX:
  993. Subject: -Q10.B.3- change a binding while it is being executed?
  994.  
  995. A10.B.3. As of June, 1992, this was not a safe thing to do in Tk.  It was
  996. put on the bug list by John Ousterhout to be fixed in a future version.
  997.  
  998. The solution for now is not to change the bindings, but to change
  999. something in the code they execute.  For example, keep a state variable
  1000. that indicates which binding you'd like, but always have the binding
  1001. call a given procedure.  Then that procedure checks the variable and
  1002. executes one piece of code or another.  Or, you could just make the
  1003. binding's command "eval $cmd" and then change the variable "cmd"
  1004. depending on your application's state.
  1005.  
  1006. ------------------------------
  1007.  
  1008. From: -X-  How, in Tk, can I XXX:
  1009. Subject: -Q10.B.4- bind the arrow key on my Sun keyboard?
  1010.  
  1011. A10.B.4. You have to call it <Left> rather than <R10>.  Under X11, keys are
  1012. referred to by their keysym.  One can use either xmodmap -pk or the xev
  1013. program to determine what the keysym a particular key on a keyboard is
  1014. currently generating.
  1015.  
  1016. If the keysym that is being used is not known by Tk, you may have to edit
  1017. its ks_names.h file.  There is a note in this file that indicates that
  1018. one should not edit it - but this is where the keysym must be for it to
  1019. be recognized.
  1020.  
  1021. Thanks to Wayne Christopher <faustus@CS.Berkeley.EDU> for this
  1022. note.
  1023.  
  1024. ------------------------------
  1025.  
  1026. From: -X-  How, in Tk, can I XXX:
  1027. Subject: -Q10.B.5- get root's mouse bindings to work in my Tk application?
  1028.  
  1029. A10.B.5. Some window managers, such as mwm, define mouse button bindings
  1030. which cause Tk some problems.  Try saving off the window manager's startup
  1031. file (something like /.mwmrc for instance) and then copy in a startup
  1032. file from a login id that works.  Thanks to brad@NeoSoft.com (Brad Morrison)
  1033. for this invaluable tip!
  1034.  
  1035. ------------------------------
  1036.  
  1037. From: -X-  How, in Tk, can I XXX:
  1038. Subject: -Q10.C.1- get an application to also use libXt?
  1039.  
  1040. A10.C.1. Tk2.1 and Xt have different X connections, and XtAppNextEvent will
  1041. block is there is nothing coming from the X connection.  One way
  1042. of fixing this is get the connection number of Tk using
  1043.  
  1044.    ConnectionNumber(Tk_Display(tk_window));
  1045.  
  1046. and using XtAddInput to register this with the Xt event handler.  The
  1047. callback procedure for XtAddInput wrapper procedure that runs
  1048. Tk_OneEvent(1).  There might be problems with Tk file sources which
  1049. aren't registered with Xt.
  1050.  
  1051. Thanks to joe@astro.as.utexas.edu (Joe Wang) for this information.
  1052.  
  1053. ------------------------------
  1054.  
  1055. From: -X-  How, in Tk, can I XXX:
  1056. Subject: -Q10.C.2- change the X11 cursor?
  1057.  
  1058. A10.C.2. Here is a tip from mgc@cray.com (M. G. Christenson).
  1059.  
  1060. Look at /usr/include/X11/cursorfont.h for a list of available cursors.
  1061. You can use the names in there by removing the 'XC_'.  
  1062.  
  1063. Here's a little proc I use to make my entire application go 'busy'
  1064. while it's doing something. Just call it with the commands you want to
  1065. execute, and the watch cursor will be displayed for the time it takes
  1066. the commands to complete.  Note that any new windows will have their
  1067. normal cursor.
  1068.  
  1069. proc busy {cmds} {
  1070.     global errorInfo
  1071.  
  1072.     set busy {.app .root}
  1073.     set list [winfo children .]
  1074.     while {$list != ""} {
  1075.     set next {}
  1076.     foreach w $list {
  1077.         set class [winfo class $w]
  1078.         set cursor [lindex [$w config -cursor] 4]
  1079.         if {[winfo toplevel $w] == $w || $cursor != ""} {
  1080.         lappend busy [list $w $cursor]
  1081.         }
  1082.         set next [concat $next [winfo children $w]]
  1083.     }
  1084.     set list $next
  1085.     }
  1086.  
  1087.     foreach w $busy {
  1088.     catch {[lindex $w 0] config -cursor watch}
  1089.     }
  1090.  
  1091.     update idletasks
  1092.  
  1093.     set error [catch {uplevel eval [list $cmds]} result]
  1094.     set ei $errorInfo
  1095.  
  1096.     foreach w $busy {
  1097.     catch {[lindex $w 0] config -cursor [lindex $w 1]}
  1098.     }
  1099.  
  1100.     if $error {
  1101.     error $result $ei
  1102.     } else {
  1103.     return $result
  1104.     }
  1105. }
  1106.  
  1107. ------------------------------
  1108.  
  1109. From: -X-  How, in Tk, can I XXX:
  1110. Subject: -Q10.C.3- raise or lower a window?
  1111.  
  1112. A10.C.3. This is on the (semi-infinite) list of things to be done in the future.
  1113. If you have the time, please go ahead and add it and submit the code and all
  1114. will be grateful.
  1115.  
  1116. ------------------------------
  1117.  
  1118. From: -X-  How, in Tk, can I XXX:
  1119. Subject: -Q10.C.4- re-map a withdrawn window id?
  1120.  
  1121. A10.C.4. Use wm deiconify <windowid>.
  1122.  
  1123. ------------------------------
  1124.  
  1125. From: -X-  How, in Tk, can I XXX:
  1126. Subject: -Q10.C.5- use Tk in a subwindow of a non-Tk X11 application?
  1127.  
  1128. A10.C.5. From faustus@CS.Berkeley.EDU (Wayne A. Christopher):
  1129.  
  1130. [C]reate the Tk toplevel window but don't map it (wm withdraw).  Then
  1131. re-parent the window to be a subwindow of your other one and then map
  1132. it.  I have done this when the Tk application is a separate process,
  1133. but if it's the same process I think you will get into trouble with the
  1134. event loop, since each toolkit wants control.
  1135.  
  1136. ------------------------------
  1137.  
  1138. From: -X-  How, in Tk, can I XXX:
  1139. Subject: -Q10.C.6- bind <Enter> and <Leave> to a frame containing 
  1140.     other widgets?
  1141.  
  1142. A10.C.6. From John Ousterhout, ouster@cs.Berkeley.EDU):
  1143.  
  1144. Each <Enter> or <Leave> event has a "detail" field, which you can access
  1145. from bindings with "%d".  If the detail is "NotifyInferior" it means the
  1146. pointer has moved into or out of a child window (so it's really still in
  1147. the area of the window receiving the event).  You should be able to check
  1148. the detail in your scripts and ignore events with a detail of NotifyInferior.
  1149. Check the Xlib documentation for Enter/Leave events for complete
  1150. information on the detail field.
  1151.  
  1152.  
  1153. ------------------------------
  1154.  
  1155. From: -X-  How, in Tk, can I XXX:
  1156. Subject: -Q10.D.1- resize a listbox?
  1157.  
  1158. A10.D.1. Use wm min/maxsize - in a uniform manner.  Here is a resizable listbox:
  1159.  
  1160.         #!/usr/local/bin/wish -f
  1161.         wm minsize . 20 20
  1162.         wm maxsize . 1152 900
  1163.         pack append . [listbox .l -borderwidth 2 -relief raised] {expand fill}
  1164.  
  1165. Doing the same with the text widget brings its resizing under control too.
  1166.  
  1167. Thanks to "John C Ellson" <ellson@ontap.att.com).
  1168.  
  1169. ------------------------------
  1170.  
  1171. From: -X-  How, in Tk, can I XXX:
  1172. Subject: -Q10.D.2- select two items that are not adjacent in the listbox at 
  1173.         one time?
  1174.  
  1175. A10.D.2.  See Marc R. Ewing's Listbox.patch for a way to modify Tk to allow
  1176. selection of non-contiguous entries.
  1177.  
  1178. ------------------------------
  1179.  
  1180. From: -X-  How, in Tk, can I XXX:
  1181. Subject: -Q10.D.3- select items in more than one Tk listbox at a time?
  1182.  
  1183. A10.D.3. The default for Tk's listbox widget exports its selection as the
  1184. X selection.  There can only be one of these at a time.
  1185.  
  1186. To turn off this behavior in Tk, use the -exportselection false when
  1187. you create the listbox.  Or, use the
  1188.  
  1189. option add *Listbox.exportselection false
  1190.  
  1191. command in the beginning of your script.
  1192.  
  1193. Thanks to David Herron <david@davids.mmdf.com> for this tip.
  1194.  
  1195. ------------------------------
  1196.  
  1197. From: -X-  How, in Tk, can I XXX:
  1198. Subject: -Q10.D.4- avoid fractional white space at the end of a resizable
  1199.         listbox?
  1200.  
  1201. A10.D.4. First, let's state the problem more clearly. I want to make a
  1202. resizable listbox and I don't want to constrain it by setting a
  1203. minimum size. So I pack it with fill expand, I use it to set the grid
  1204. (so that resizing the window always gives me whole lines) and I set an
  1205. initial geometry of 1x1 to override the default. However what I get
  1206. is... (run the code below for a demo and try to resize)
  1207.  
  1208. listbox .l -geom 1x1 -setgrid 1 -yscrollcommand ".s set" -relief sunken -bd 2
  1209. scrollbar .s -command ".l yview"
  1210. pack .s -side right -fill y
  1211. pack .l -side top -fill both -expand 1
  1212. .l insert end one two three four five six seven eight nine ten "THE END"
  1213.  
  1214. ...a situation where the partially filled listbox has a blank
  1215. half-line at the bottom even if there are more items in the list. This
  1216. is very confusing because it fools the user into thinking that there
  1217. is nothing else beyond what's visible. Why does it happen?
  1218.  
  1219. Now for the answer.
  1220.     Look at the window as it is created, before the resizing. See that
  1221. poor, tiny little scrollbar squeezed in that microscopic window? It,
  1222. too, requests a minimum size, and it so happens that the starting
  1223. geometry for the listbox (i.e. the situation referred to as "1x1")
  1224. receives some free fractional space at the bottom. And you never get
  1225. rid of it, since the resizing is constrained to be in whole
  1226. characters.
  1227.  
  1228. The thing to do is to define the initial layout in such a way that the
  1229. widget that has -setgrid actually displays an integer number of lines
  1230. and columns. In the above example, setting -geom 1x2 does the trick.
  1231.  
  1232. Thanks to Frank Stajano <fms@cam-orl.co.uk> for this tip.
  1233.  
  1234. ------------------------------
  1235.  
  1236. From: -X-  How, in Tk, can I XXX:
  1237. Subject: -Q10.E.1- get output from a Tk canvas?
  1238.  
  1239. A10.E.1. The latest Tk has a save suboption on canvas which allows one
  1240. to create a file describing the canvas.  The default output is Encapsulated
  1241. Postscript, but there is an xpm3 suboption as well.
  1242.  
  1243. ------------------------------
  1244.  
  1245. From: -X-  How, in Tk, can I XXX:
  1246. Subject: -Q10.E.2- fill a canvas which is bounded by lines as opposed to a
  1247.         shape like a polygon, oval, etc.?
  1248.  
  1249. A10.E.2. No, you have to at least use a polygon if you want to fill an area
  1250. bounded by some lines.
  1251.  
  1252. ------------------------------
  1253.  
  1254. From: -X-  How, in Tk, can I XXX:
  1255. Subject: -Q10.E.3- raise/lower canvas window objects or draw graphics onto a 
  1256.         window object inside a canvas?
  1257.  
  1258. A10.E.3. You can't yet. 
  1259.  
  1260. "Jesper Blommaskog" <d9jesper@dtek.chalmers.se>.
  1261.  
  1262. ------------------------------
  1263.  
  1264. From: -X-  How, in Tk, can I XXX:
  1265. Subject: -Q10.E.4- detect when the canvas has been resized?
  1266.  
  1267. A10.E.4. From Nathanial Pryce <np@hpl.hp.co.uk>:
  1268.  
  1269. > I have a window with a canvas containing some stuff that logically
  1270. > fills the canvas (say, a chess board or a map of the world). I want
  1271. > this toplevel window to be resizable and of course, when the win is
  1272. > resized, I want the stuff inside the canvas to be scaled
  1273. > accordingly. Now, I can manage the scaling of the stuff, but what
  1274. > I'm having trouble with is DETECTING that I should do it. How can I
  1275. > be notified that the window has been resized?
  1276.  
  1277. Nat's answer is:
  1278.  
  1279. You need to bind a command to the Configure event, like this:
  1280.  
  1281.     proc config {w h} {
  1282.        puts stdout ".canvas - width = $w, height = $h"
  1283.     }
  1284.  
  1285.     bind .canvas <Configure> "config %w %h"
  1286.  
  1287.  
  1288. .canvas - width = 224, height = 251
  1289. .canvas - width = 224, height = 151
  1290. .canvas - width = 224, height = 243
  1291. # and so forth
  1292.  
  1293. ------------------------------
  1294.  
  1295. From: -X-  How, in Tk, can I XXX:
  1296. Subject: -Q10.F.1- get the name of my own interpreter?
  1297.  
  1298. A10.F.1. george.howlett@att.com (George A. Howlett) points us to the winfo manual
  1299. page - winfo name . gets the name of the current application.
  1300.  
  1301. ------------------------------
  1302.  
  1303. From: -X-  How, in Tk, can I XXX:
  1304. Subject: -Q10.F.2- get -relief to work on my text widgets?
  1305.  
  1306. A10.F.2. From Owen Rees <rtor@ansa.co.uk>, we find out that we must:
  1307.  
  1308. "[m]ake the border width non-zero as in"
  1309.  
  1310.    text .t -width 20 -height 20 -relief sunken -borderwidth 4
  1311.  
  1312. ------------------------------
  1313.  
  1314. From: -X-  How, in Tk, can I XXX:
  1315. Subject: -Q10.F.3- create a scrollable window of buttons?
  1316.  
  1317. A10.F.3. There are at least two ways to do this.  First, there is a hypertext
  1318. widget that one can get from the Tcl User Contributed Code Archive -
  1319. (see "tcl-faq/part4") and (see "tcl-faq/part5") for details -
  1320.  which provides such a facility.
  1321.  
  1322. And here is some sample code from 
  1323. "Michael Moore" <mdm@stegosaur.cis.ohio-state.edu> which shows a way to 
  1324. do this using just Tk.
  1325.  
  1326. #! /bin/wish -f
  1327. #
  1328. # This demonstrates how to create a scrollable canvas with mutliple
  1329. # buttons.
  1330. #
  1331. # Author : Michael Moore
  1332. # Date   : November 17, 1992
  1333. #
  1334.  
  1335. #
  1336. # This procedure obtains all the items with the tag "active"
  1337. # and prints out their ids.
  1338.  
  1339. proc multi_action {} {
  1340.     set list [.frame.canvas find withtag "active"]
  1341.     puts stdout "Active Item Ids : "
  1342.     foreach item $list {
  1343.     puts stdout $item
  1344.     }
  1345. }
  1346.  
  1347. # This simulates the toggling of a command button...
  1348. # Note that it only works on a color display as is right now
  1349. # but the principle is the same for b&w screens.
  1350. proc multi_activate {num id} {
  1351.     
  1352.     set tags [.frame.canvas gettags $id]
  1353.     if {[lsearch $tags "active"] != -1} {
  1354.     .frame.canvas dtag $id "active"
  1355.     .frame.canvas.button$num configure \
  1356.         -background "#060" \
  1357.         -activebackground "#080" 
  1358.     } else {
  1359.     .frame.canvas addtag "active" withtag $id
  1360.     .frame.canvas.button$num configure \
  1361.         -background "#600" \
  1362.         -activebackground "#800"
  1363.     }
  1364.  
  1365. proc setup {} {
  1366.      frame .frame
  1367.  
  1368.      scrollbar .frame.scroll \
  1369.          -command ".frame.canvas yview" \
  1370.          -relief raised
  1371.  
  1372.      canvas .frame.canvas \
  1373.          -yscroll ".frame.scroll set" \
  1374.          -scrollregion {0 0 0 650} \
  1375.          -relief raised \
  1376.      -confine false \
  1377.      -scrollincrement 25
  1378.  
  1379.      pack append .frame \
  1380.          .frame.scroll    {left frame center filly} \
  1381.          .frame.canvas    {left frame center fillx filly}
  1382.  
  1383.      pack append .\
  1384.          .frame   {left frame center fillx filly}
  1385.  
  1386.      button .frame.canvas.action  \
  1387.          -relief raised \
  1388.          -text "Action" \
  1389.      -command "multi_action"
  1390.      .frame.canvas create window 1 25 \
  1391.      -anchor w \
  1392.          -window .frame.canvas.action
  1393.      for {set i 2} {$i < 26} {incr i} {
  1394.      button .frame.canvas.button$i  \
  1395.         -relief raised \
  1396.         -background "#060" \
  1397.         -foreground wheat \
  1398.         -activebackground "#080" \
  1399.         -activeforeground wheat \
  1400.         -text "Button $i" 
  1401.      set id [.frame.canvas create window 1 [expr $i*25] \
  1402.         -anchor w \
  1403.         -window .frame.canvas.button$i]
  1404.      .frame.canvas.button$i configure \
  1405.         -command "multi_activate $i $id"
  1406.     }
  1407. }
  1408.  
  1409. setup
  1410.  
  1411. ------------------------------
  1412.  
  1413. From: -X-  How, in Tk, can I XXX:
  1414. Subject: -Q10.F.4- pack a text widget so that it can be resized interactively?
  1415.  
  1416. A10.F.4. From Spencer W. Thomas <spencer@med.umich.edu> we find that we need to:
  1417.  
  1418. wm minsize . 0 0
  1419. text .text
  1420. pack append . .text {fill expand}
  1421.  
  1422. ------------------------------
  1423.  
  1424. From: -X-  How, in Tk, can I XXX:
  1425. Subject: -Q10.F.5- create a widget with an upper case name?
  1426.  
  1427. A10.F.5. During a recent revision of Tk, things were changed so that names
  1428. beginning with a capital letter are reserved for class names.  Specific
  1429. instances of widgets must begin with a lower case letter.  This enables
  1430. X11 resource definitions to distinguish between a class and instance.
  1431.  
  1432. ------------------------------
  1433.  
  1434. From: -X-  How, in Tk, can I XXX:
  1435. Subject: -Q10.F.6- create equal sized buttons?
  1436.  
  1437. A10.F.6. Recently, Micael Salmon <etxmesa@eos.ericsson.se> posted:
  1438.  
  1439. In article <1993Jun23.065417.4302@ericsson.se>, I write:
  1440. |> I am currently working on yet another tn3270 emulator and I have run
  1441. |> into a problem with creating equal sized buttons. I have created an
  1442. |> array of buttons for PF and cursor keys and I would now like to make
  1443. |> them all the same size. Arranging them into columns was not
  1444. |> a problem but when I add bitmaps the buttons lose their horizontal
  1445. |> alignment. What I tried was to read the height and width of the buttons
  1446. |> using winfo, determine the largest and then use pads to force them to
  1447. |> be the same size, this doesn't seem to work. The technique of using
  1448. |> pre-set height and width doesn't seem applicable when using a mixture
  1449. |> of bitmaps and text as the size in pixels of a text button is font
  1450. |> dependent. All suggestions welcome.
  1451.  
  1452. Jim Wight <J.K.Wight@newcastle.ac.uk> suggested using reqheight and reqwidth
  1453. and then specifying padx and pady in the pack command for each button.
  1454. Jim says:
  1455. I think it only fair to point out that it was Tuomas J Lukka
  1456. <lukka@klaava.Helsinki.FI> who suggested the use of reqwidth and reqheight when I asked how to get over the deficiencies in my first attempt at a solution
  1457. that I posted to this group.
  1458.  
  1459. Since you're all agog I might as well post the final solution (more or less)
  1460. that I mailed to Michael.
  1461.  
  1462. frame .frame1
  1463. frame .frame2
  1464. button .frame1.a -text "pretty long button text"
  1465. button .frame1.b -text "short one"
  1466. button .frame2.c -bitmap "@/usr/include/X11/bitmaps/xlogo32"
  1467. button .frame2.d -text "tiny"
  1468.  
  1469. set long [winfo reqwidth .frame1.a]
  1470. set short [winfo reqwidth .frame1.b]
  1471. set medium [winfo reqwidth .frame2.c]
  1472. set tiny [winfo reqwidth .frame2.d]
  1473. set pady [expr [winfo reqheight .frame2.c]-[winfo reqheight .frame2.d]]
  1474.  
  1475. pack append .frame1 .frame1.a "filly pady $pady"
  1476. pack append .frame1 .frame1.b "fillx padx [expr $long-$short] filly pady $pady"pack append .frame2 .frame2.c "fillx padx [expr $long-$medium] filly"
  1477. pack append .frame2 .frame2.d "fillx padx [expr $long-$tiny] filly pady $pady"
  1478. pack append . .frame1 {left} .frame2 {left}
  1479.  
  1480.  
  1481. ------------------------------
  1482.  
  1483. From: -X-  How, in Tk, can I XXX:
  1484. Subject: -Q10.F.7- vertically stack radio buttons aligning regardless of font?
  1485.  
  1486. A10.F.7.  Till Brychcy <brychcy@informatik.tu-muenchen.de> provides
  1487. the following example:
  1488.  
  1489.  
  1490.     radiobutton .times -text Times -anchor w
  1491.     radiobutton .helvetica -text Helvetica -anchor w
  1492.     radiobutton .courier -text Courier -anchor w
  1493.     pack .times .helvetica .courier -side top -fill x
  1494.  
  1495. Note that you are using anchor west in the widgets themselves, and not in
  1496. the packer.  This lets the packer produce full width buttons.
  1497.  
  1498.  
  1499. ------------------------------
  1500.  
  1501. End of comp.lang.tcl Frequently Asked Questions (2/5)
  1502. *****************************************************
  1503. -- 
  1504. :s Great net resources sought...
  1505. :s Larry W. Virden                 INET: lvirden@cas.org
  1506. :s Personal: 674 Falls Place,   Reynoldsburg, OH 43068-1614
  1507. The task of an educator should be to irrigate the desert not clear the forest.
  1508.