1998-04-10 06:59:06 -04:00
|
|
|
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
|
1996-09-27 06:29:02 -04:00
|
|
|
<html>
|
1998-04-10 06:59:06 -04:00
|
|
|
<head>
|
|
|
|
<title>Demo directory README (Version 3.99 - March 1998)</title>
|
|
|
|
</head>
|
|
|
|
|
|
|
|
<body bgcolor="#FFFFFF">
|
|
|
|
<h1><img src="STk-normal.gif"> Demo directory</h1>
|
|
|
|
|
|
|
|
<! Applet definition: This applet defines new function which can run a demo
|
|
|
|
using the SYSTEM function.
|
|
|
|
This is VERY DANGEROUS, but user can set security to a given level
|
|
|
|
when launching the browser.
|
|
|
|
Security is not yet finished and need some work
|
|
|
|
>
|
|
|
|
|
|
|
|
<script language="STk">
|
|
|
|
(lambda (parent url)
|
|
|
|
(eval '(define (Run x)
|
|
|
|
(system (string-append "../Src/test-stk " x "&")))
|
|
|
|
(global-environment))))
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<! ------------------------------------------------------------------------------>
|
|
|
|
<pre>
|
|
|
|
|
|
|
|
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
<h4>Content</h4>
|
|
|
|
<ul>
|
|
|
|
This directory contains the demo programs for <b>STk</b>.
|
|
|
|
There are several categories of demos available from here:
|
|
|
|
<ul>
|
|
|
|
<li> <a href="README.html#stk">STk demos</a>: They correspond to
|
|
|
|
program which don't use CLOS like object extension of
|
|
|
|
<b>STk</b>. These demo are quite simple and they often mimic
|
|
|
|
original Tcl/Tk demonstrations
|
|
|
|
<li> <a href="README.html#stklos">STklos demos</a>: These
|
|
|
|
demonstration programs use the STklos object Extension of
|
|
|
|
<B>STk</B>. The code of most of these demos has been kept short
|
|
|
|
to illustrate the basic of STklos programming.
|
|
|
|
<li> <a href="Html-Demos/main.html">Html demo</a>: This demo is
|
|
|
|
in fact an overview of STk/STklos that I have used once in a
|
|
|
|
presentation of STklos. The pages accessible from this link
|
|
|
|
present STk but also contains links or Scheme applets which
|
|
|
|
illustrate the kind of things that can be done with the STk
|
|
|
|
browser. Of course, to properly execute the applets contained
|
|
|
|
in theses pages, you need to run the STk Html browser
|
|
|
|
(see below).
|
|
|
|
|
|
|
|
</ul>
|
|
|
|
</ul>
|
|
|
|
<h4>Running demonstration programs without installing STk</h4>
|
|
|
|
<ul>
|
|
|
|
If you want to run a demo <STRONG>BEFORE</STRONG> a complete
|
|
|
|
installation of the <b>STk</b> package, you must use the shell
|
|
|
|
script <code>../Src/test-stk</code> in order to run the
|
|
|
|
interpreter (this shell script set some variables to run properly
|
|
|
|
the interpreter without installing it).
|
|
|
|
</ul>
|
|
|
|
<h4>Running demonstration programs in the STk web browser</h4>
|
|
|
|
<ul>
|
|
|
|
<b>STk</b> provides a simple Web browser which can be used to launch
|
|
|
|
the demo of this directory. If you are not running it now, you can
|
|
|
|
type the following command:
|
|
|
|
<pre> ../Src/test-stk -f S-scape README.html</pre>
|
|
|
|
at the shell prompt.
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<h2><a name="stk">1. STk demos</a></h2>
|
|
|
|
<h4>1.1 Basic STk demos</h4>
|
|
|
|
|
|
|
|
<UL>
|
|
|
|
<p><li>
|
|
|
|
<B><A name=hello>hello.stk</a></B>
|
|
|
|
<BR>
|
|
|
|
This is the traditional first program. This program creates a single button
|
|
|
|
that you can click on.
|
|
|
|
<BR>
|
|
|
|
<u>Run with </u>:
|
|
|
|
<a expr=(run "hello.stk")> ../Src/test-stk -f hello.stk </a>
|
|
|
|
<p><li>
|
|
|
|
<B><A name=browse>browse.stk</a></B>
|
|
|
|
<BR>
|
|
|
|
A simple Unix file browser. The code of this demo is less than a page.
|
|
|
|
<BR>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "browse.stk")>.../Src/test-stk -f browse.stk </A>
|
|
|
|
</UL>
|
|
|
|
|
|
|
|
<h4>1.2 Basics of STk programming</h4>
|
|
|
|
<UL>
|
|
|
|
<p><li>
|
|
|
|
<B>wtour.stk</B>
|
|
|
|
<BR>
|
|
|
|
This is a rewrite of the Tcl/Tk wtour2.0 in Scheme/STk. Use
|
|
|
|
the menus to navigate through different lessons. You can make
|
|
|
|
changes to the lesson source code; click on the Apply button
|
|
|
|
to see the results of the changes.
|
|
|
|
<BR>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "wtour.stk ../Contrib/STk-wtour")>
|
|
|
|
../Src/test-stk -f ./wtour.stk ../Contrib/STk-wtour
|
|
|
|
</A>
|
|
|
|
<BR><u>Comment</u>: This code is a contribution of <B>Suresh Srinivas</B>
|
|
|
|
<tt><ssriniva@cs.indiana.edu></tt>
|
|
|
|
</UL>
|
|
|
|
|
|
|
|
<h4>1.3 Client/Server Demos</h4>
|
|
|
|
<ul>
|
|
|
|
<p><li>
|
|
|
|
<b>server.stk</b>
|
|
|
|
<br>
|
|
|
|
A simple server showing how to use the socket package. It
|
|
|
|
creates an xterm window in which a read-eval-print-loop is
|
|
|
|
executed. When the window is closed or when an error occurs,
|
|
|
|
the socket is closed
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "-no -f server.stk")> ../Src/test-stk -no -f server.stk </A>
|
|
|
|
<p><li>
|
|
|
|
<b>mc-server.stk</b>
|
|
|
|
<br>
|
|
|
|
A multiple-clients server. On Unix, you can use several telnet
|
|
|
|
sessions to <I>discuss</I> with the server. Each discussion
|
|
|
|
has its own dedicated channel. Type <tt>(exit)</tt> at the <b>STk</b>
|
|
|
|
when you want to exit the demo.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(system "xterm -e ../Src/test-stk -load mc-server.stk &")>
|
|
|
|
../Src/test-stk -load mc-server.stk </A>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
|
|
<h4>1.4 Fun and Games</h4>
|
|
|
|
<ul>
|
|
|
|
<p><li>
|
|
|
|
<b>turtle.stk</b>
|
|
|
|
<br>
|
|
|
|
A Logo turtle package + some demo functions.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "turtle.stk")> ../Src/test-stk -f turtle.stk </A>
|
|
|
|
<p><li>
|
|
|
|
<b>hanoi.stk</b>
|
|
|
|
<br>
|
|
|
|
Hanoi towers animation.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "hanoi.stk")> ../Src/test-stk -f hanoi.stk </A>
|
|
|
|
<p><li>
|
|
|
|
<b>queens.stk</b>
|
|
|
|
<br>
|
|
|
|
The queens problem. You can do it yourself (and it will make
|
|
|
|
sure you follow the rules) or you can ask it to solve the
|
|
|
|
puzzle starting with a given board configuration.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "queens.stk")> ../Src/test-stk -f queens.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: This code is a contribution of <b>Grant
|
|
|
|
Edwards</b> <tt><grante@rosemount.com)></tt>
|
|
|
|
<p><li>
|
|
|
|
<b>stetris.stk</b>
|
|
|
|
<br>
|
|
|
|
This is a falling block game not unlike tetris(tm) :). It is
|
|
|
|
implemented in <b>STk</b> just to prove it can be done, and as a
|
|
|
|
challenge to TCLers. It starts slowly and becomes faster and
|
|
|
|
faster. Have fun.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "stetris.stk")> ../Src/test-stk -f stetris.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>:
|
|
|
|
This code is a contribution of <B>Harvey J. Stein</B>
|
|
|
|
<tt><hjstein@math.huji.ac.il></tt>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>ttt.stk</b>
|
|
|
|
<br>
|
|
|
|
A 3D Tic-Tac-Toe, where the board is 4x4x4, a 3 dimensional
|
|
|
|
board of four planes with four rows and four columns each.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "ttt.stk")> ../Src/test-stk -f ttt.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>:
|
|
|
|
This code is a contribution of <b>Edin "Dino" Hodzic</b>
|
|
|
|
<ehodzic@scu.edu>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
|
|
<h4>1.5 Misc </h4>
|
|
|
|
<ul>
|
|
|
|
<p><li>
|
|
|
|
<b>colormap.stk</b>
|
|
|
|
<br>
|
|
|
|
This is a simple color palette written in STk.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "colormap.stk")> ../Src/test-stk -f colormap.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: Note that this program is no more really useful since
|
|
|
|
<B>STk</B> offers now the function <tt>Tk:choose-color</tt>
|
|
|
|
which allow to choose a color by name or by value.
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>small-ed.stk</b>
|
|
|
|
<br>
|
|
|
|
A small editor to create enhanced text
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "small-ed.stk")> ../Src/test-stk -f small-ed.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>:
|
|
|
|
This editor use a <I>ad-hoc</I> format for saving file and was
|
|
|
|
used for the help buttons of various widgets in old versions
|
|
|
|
of <B>STk</B>. It will not be developed anymore since the
|
|
|
|
preferred format for help is now HTML.
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>showvars.stk</b>
|
|
|
|
<br>
|
|
|
|
A variable shower: this program shows the value of three
|
|
|
|
variables (named a,b and c) Changing the value of one of
|
|
|
|
these vars (with a <tt><b>set!</b></tt> for instance) will
|
|
|
|
redisplay its new value immediately.
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "-load showvars.stk")>
|
|
|
|
../Src/test-stk -load showvars.stk </A>
|
|
|
|
<br>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>inspector.stk</b>
|
|
|
|
<br>
|
|
|
|
A simple demo of the inspector on Tk widgets
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "inspector.stk")> ../Src/test-stk -f inspector.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>:
|
|
|
|
<STRONG> Does not work with this version of <I>STk</I>
|
|
|
|
<BR>A new version of the inspector is in practically finished and
|
|
|
|
will be soon released.</STRONG>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>term.stk</b>
|
|
|
|
<br>
|
|
|
|
A simple terminal emulator (a kind of xterm, but in a text widget).
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "term.stk")> ../Src/test-stk -f term.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: Users of <b>Glibc2 (aka libc6, or RedHat 5.0
|
|
|
|
users)</b>: This program has problems with new release of the
|
|
|
|
libc under Linux, if your shell has the line editing mode
|
|
|
|
set. To avoid the problem you can
|
|
|
|
<ul>
|
|
|
|
<li> disable the line editing mode of your shell
|
|
|
|
<li> set the SHELL variable to a dumb shell (e.g. ash)
|
|
|
|
<li> link STk with the old libc
|
|
|
|
<li> don't run the demo :-)
|
|
|
|
</ul>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
|
|
<! -------------------------------------------------------------------------->
|
|
|
|
|
|
|
|
<h2><a name="stklos">2. STklos demos</a></h2>
|
|
|
|
<ul>
|
|
|
|
All the standard Tk widgets have been wrapped in <b>STklos</b>
|
|
|
|
classes. As a result, in <b>STklos</b>, Tk widgets are seen as instances of
|
|
|
|
<b>STklos</b> classes.
|
|
|
|
<br> There are two kinds of <b>STklos</b> widgets:
|
|
|
|
<ul>
|
|
|
|
<li> <i>Simple widgets</i> which map one to one the Tk standard
|
|
|
|
widgets
|
|
|
|
|
|
|
|
<li> <i>Composite widgets</i> which are built from simple Tk
|
|
|
|
widgets (or even simpler composite widgets).
|
|
|
|
</ul>
|
|
|
|
Demonstration programs accessible from this page use indifferently
|
|
|
|
<i>simple widgets</i> and <i>composite widgets</i>.
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<h4>2.1 Basic STklos demos</h4>
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<p><li>
|
|
|
|
<b>hello.stklos</b>
|
|
|
|
<br>
|
|
|
|
This is a simple rewriting of the <a HREF=#hello>hello.stk</a>
|
|
|
|
demonstration in <b>STklos</b>
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "hello.stklos")> ../Src/test-stk -f hello.stklos </A>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>browse.stklos</b>
|
|
|
|
<br>
|
|
|
|
This is a simple rewriting of the <a HREF=#browse>browse.stk</a>
|
|
|
|
demonstration in <b>STklos</b>
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "browse.stklos")> ../Src/test-stk -f browse.stklos </A>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>stklos-demo.stklos</b>
|
|
|
|
A simple demo written in STklos.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "stklos-demo.stklos")>../Src/test-stk -f stklos-demo.stklos</a>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: What is interesting in this demo is not what
|
|
|
|
it does, nothing specially fancy, but how it is easy to
|
|
|
|
program, IMHO.
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>stklos-demo2.stklos</b>
|
|
|
|
Another simple demo written in STklos.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "stklos-demo2.stklos")>
|
|
|
|
../Src/test-stk -f stklos-demo2.stklos</a>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: Here again, what is interesting in this demo is not what
|
|
|
|
it does, nothing specially fancy, but how it is easy to
|
|
|
|
program, IMHO.
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<h4>2.2 STklos widgets</h4>
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<p><li>
|
|
|
|
<b>widget.stklos</b>
|
|
|
|
<br>
|
|
|
|
A tour of the Tk widgets. This demo shows all the Tk
|
|
|
|
widgets. This is a rewriting in STklos of the big Tcl/Tk demo
|
|
|
|
<tt>widget.tcl</tt>. For each widget demo accessible from this
|
|
|
|
program, you can see the source by just clicking the <tt>"See
|
|
|
|
code"</tt> button. You can modify the code and test your
|
|
|
|
modified version by clicking the button <tt>"Rerun demo"</tt>
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "widget.stk")> ../Src/test-stk -f widget.stk </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: This demo illustrate only the simple widgets
|
|
|
|
(the ones of the Tk library). For a <i>composite widgets</i>
|
|
|
|
demo look at the <tt>stklos-widgets.stklos</tt> program.
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>filebox.stklos</b>
|
|
|
|
<br>
|
|
|
|
This is a simple program which uses the <tt><File-box></tt>
|
|
|
|
<i>composite widget</i>. A <tt><File-box></tt> is a file requester
|
|
|
|
with file name completion (on the <tt>Tab</tt> key).This widget is
|
|
|
|
itself a composition of various composite widget classes.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "filebox.stklos")> ../Src/test-stk -f filebox.stklos </A>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>stklos-widgets.stklos</b>
|
|
|
|
<br>
|
|
|
|
A quick demo of some of the STklos <i>Composite widgets</i>
|
|
|
|
which are available in this release.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "stklos-widgets.stklos")>
|
|
|
|
../Src/test-stk -f stklos-widgets.stklos </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: This code is a contribution of <b>Drew Whitehouse</b>
|
|
|
|
<TT><Drew.Whitehouse@anu.edu.au></TT>.
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
|
|
<h4>2.3 STklos Applications</h4>
|
|
|
|
<ul>
|
|
|
|
<p><li>
|
|
|
|
<b>calc.stklos</b>
|
|
|
|
<br>
|
|
|
|
This is a simplistic calculator.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "calc.stklos")>../Src/test-stk -f calc.stklos </A>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>tkcolor.stklos</b>
|
|
|
|
<br>
|
|
|
|
This is a simple color picker written in <B>STklos</B>.
|
|
|
|
Clicking the left mouse button in the color box sets the text
|
|
|
|
color to the chosen color. Clicking the right button sets the
|
|
|
|
background color. The <i>Select</i> button sets the selection
|
|
|
|
to a string which can be used (by pasting it in an xterm window)
|
|
|
|
as argument of most X11 applications to set their foreground and
|
|
|
|
background color.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "tkcolor.stklos")>../Src/test-stk -f tkcolor.stklos </A>
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>amib.stklos</b>
|
|
|
|
<br>
|
|
|
|
<B>A</B> <B>M</B>ini <B>I</B>nterface <B>B</B>uilder.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "amib.stklos")> ../Src/test-stk -f amib.stklos </A>
|
|
|
|
<br>
|
|
|
|
<u>Comment</u>: The current version of AMIB allow you to:
|
|
|
|
<ul>
|
|
|
|
<li>place objects on a plane by drag and drop
|
|
|
|
<li>resize objects
|
|
|
|
<li>displace objects
|
|
|
|
<li>change all the slots of an object (color, font, value, ...)
|
|
|
|
<li>save an interface to reload it later in an application
|
|
|
|
</ul>
|
|
|
|
However it is far from a really usable interface builder (but
|
|
|
|
after all it is only a 600 lines of code application!!!!)
|
|
|
|
|
|
|
|
<p><li>
|
|
|
|
<b>S-scape.stklos</b>
|
|
|
|
<br>
|
|
|
|
The STk web browser. You are probably using it while seeing these lines.
|
|
|
|
<br>
|
|
|
|
<u>Run with</u>:
|
|
|
|
<A expr=(run "S-scape.stklos")> ../Src/test-stk -f S-scape.stklos </A>
|
|
|
|
</ul>
|
1996-09-27 06:29:02 -04:00
|
|
|
|
|
|
|
|
|
|
|
<hr>
|
1998-04-10 06:59:06 -04:00
|
|
|
<address><a href="mailto:eg@unice.fr">Erick Gallesio</a></address>
|
|
|
|
<!-- Created: Sun Mar 1 15:56:45 CET 1998 -->
|
|
|
|
<!-- hhmts start -->
|
|
|
|
Last modified: Mon Mar 9 19:15:46 CET 1998
|
|
|
|
<!-- hhmts end -->
|
|
|
|
</body>
|
|
|
|
</html>
|
1996-09-27 06:29:02 -04:00
|
|
|
|