News for scm_call_N and scm_apply_N.
[bpt/guile.git] / INSTALL
diff --git a/INSTALL b/INSTALL
index 1caf0eb..271c1da 100644 (file)
--- a/INSTALL
+++ b/INSTALL
@@ -1,3 +1,20 @@
+Guile Installation Guide
+Copyright (c) 1996, 1997, 1998, 1999, 2000 Free software Foundation, Inc.
+
+   Permission is granted to anyone to make or distribute verbatim copies
+   of this document as received, in any medium, provided that the
+   copyright notice and permission notice are preserved,
+   and that the distributor grants the recipient permission
+   for further redistribution as permitted by this notice.
+
+   Permission is granted to distribute modified versions
+   of this document, or of portions of it,
+   under the above conditions, provided also that they
+   carry prominent notices stating who last changed them,
+   and that any new or changed statements about the activities
+   of the Free Software Foundation are approved by the Foundation.
+
+
 Brief Installation Instructions ===========================================
 
 To build Guile on unix, there are two basic steps:
@@ -6,7 +23,8 @@ To build Guile on unix, there are two basic steps:
        2. Type "make", to build the package.
 
 Generic instructions for configuring and compiling GNU distributions
-are included below.
+are included below.  (For instructions how to install SLIB, the scheme
+procedure library, see below.)
 
 
 Special Instructions For Some Systems =====================================
@@ -33,64 +51,125 @@ NetBSD: Perry Metzger says, "Guile will build under NetBSD only using
     gmake -- the native make will not work.  (gmake is in our package
     system, so this will not be a problem when we packagize 1.3.)"
 
-What You Get ==============================================================
 
-The `configure' script examines your system, and adapts Guile to
-compile and run on it.
+Flags Accepted by Configure ===============================================
 
-The `make' command builds several things:
-- An executable file `guile/guile', which is an interactive shell for
-  talking with the Guile Scheme interpreter.
-- An object library `libguile/.libs/libguile.a', containing the Guile Scheme
-  interpreter, ready to be linked into your programs.
+If you run the configure script with no arguments, it should examine
+your system and set things up appropriately.  However, there are a few
+switches specific to Guile you may find useful in some circumstances.
 
-To install Guile, type `make install'.  This installs the executable
-and libraries mentioned above, as well as Guile's header files and
-Scheme libraries.
 
-Make also builds shared libraries, on systems that support them.
-Because of the nature of shared libraries, before linking against
-them, you should probably install them; `make install' takes care of
-this.
+--enable-maintainer-mode
 
+  If you have automake, autoconf, and libtool installed on your
+  system, this switch causes configure to generate Makefiles which
+  know how to automatically regenerate configure scripts, makefiles,
+  and headers, when they are out of date.  The README file says which
+  versions of those tools you will need.
 
-Flags Accepted by Configure ===============================================
 
-If you run the configure script with no arguments, it should examine
-your system and set things up appropriately.  However, there are a few
-switches specific to Guile you may find useful in some circumstances.
+--with-threads  ---  Build with thread support
+
+  Build a Guile executable and library that supports cooperative
+  threading.  If you use this switch, Guile will also build and
+  install the QuickThreads non-preemptive threading library,
+  libqthreads, which you will need to link into your programs after
+  libguile.  When you use `guile-config', you will pick up all
+  neccessary linker flags automatically.
+
+  Cooperative threads are not yet thoroughly tested; once they are,
+  they will be enabled by default.  The interaction with blocking I/O
+  is pretty ad hoc at the moment.  In our experience, bugs in the
+  thread support do not affect you if you don't actually use threads.
+
+
+--with-modules  ---  Specify statically linked `modules'
+
+  Guile can dynamically load `plugin modules' during runtime, using
+  facilities provided by libtool.  Not all platforms support this,
+  however.  On these platforms, you can statically link the plugin
+  modules into libguile when Guile itself is build.  XXX - how does
+  one specify the modules?
+
+
+--enable-deprecated=LEVEL  ---  Control the inclusion of deprecated features.
+
+  You can select between different behaviours via the LEVEL argument:
+  a value of "no" will omit all deprecated features and you will get
+  "undefined reference", "variable unbound" or similar errors when you
+  try to use them.  All other values will include all deprecated
+  features.  The LEVEL argument is used to determine the default value
+  for the environment variable GUILE_WARN_DEPRECATED.  See the README
+  for more information.
+
+  The default is to get a vague warning at program exit if deprecated
+  features were used:
+
+  --enable-deprecated=yes
+  --enable-deprecated=summary
+
+  To get a detailed warning at first use of a deprecated feature:
+
+  --enable-deprecated=detailed
+
+  To get no warnings:
+
+  --enable-deprecated=shutup
 
---enable-maintainer-mode --- If you have automake, autoconf, and
-libtool installed on your system, this switch causes configure to
-generate Makefiles which know how to automatically regenerate
-configure scripts, makefiles, and headers, when they are out of date. 
-The README file says which versions of those tools you will need.
+  To omit deprecated features completely and irrevokably:
 
---with-threads --- Build a Guile executable and library that supports
-cooperative threading.  If you use this switch, Guile will also build
-and install the QuickThreads non-preemptive threading library,
-libqt.a, which you will need to link into your programs after
-libguile.a.  That is, you should pass the switches -lguile -lqt to your
-linker.
+  --enable-deprecated=no
 
-Cooperative threads are not yet thoroughly tested; once they are, they
-will be enabled by default.  The interaction with blocking I/O is
-pretty ad hoc at the moment.  In our experience, bugs in the thread
-support do not affect you if you don't actually use threads.
 
---enable-dynamic-linking --- Build a Guile executable and library
-providing Scheme functions which can load a shared library and
-initialize it, perhaps thereby adding new functions to Guile.  This
-feature is enabled by default; you only need to use this option (as
-`--enable-dynamic-linking=no') if you want to build a Guile which does
-not support dynamic linking.
+--disable-shared  ---  Do not build shared libraries.
+--disable-static  ---  Do not build static libraries.
 
-This option has no effect on systems that do not support shared
-libraries.
+  Normally, both static and shared libraries will be built if your
+  system supports them.
 
---disable-shared --- Do not build shared libraries.  Normally, Guile
-will build shared libraries if your system supports them.  Guile
-always builds static libraries.
+
+--enable-debug-freelist  ---  Enable freelist debugging.
+
+  This enables a debugging version of SCM_NEWCELL(), and also
+  registers an extra primitive, the setter
+  `gc-set-debug-check-freelist!'.
+
+  Configure with the --enable-debug-freelist option to enable the
+  gc-set-debug-check-freelist! primitive, and then use:
+
+  (gc-set-debug-check-freelist! #t)  # turn on checking of the freelist
+  (gc-set-debug-check-freelist! #f)  # turn off checking
+
+  Checking of the freelist forces a traversal of the freelist and a
+  garbage collection before each allocation of a cell.  This can slow
+  down the interpreter dramatically, so the setter should be used to
+  turn on this extra processing only when necessary.
+
+
+--enable-debug-malloc  ---  Enable malloc debugging.
+
+  Include code for debugging of calls to scm_must_malloc/realloc/free.
+
+  Checks that
+
+  1. objects freed by scm_must_free has been mallocated by scm_must_malloc
+  2. objects reallocated by scm_must_realloc has been allocated by
+     scm_must_malloc
+  3. reallocated objects are reallocated with the same what string
+
+  But, most importantly, it records the number of allocated objects of
+  each kind.  This is useful when searching for memory leaks.
+
+  A Guile compiled with this option provides the primitive
+  `malloc-stats' which returns an alist with pairs of kind and the
+  number of objects of that kind.
+
+
+--enable-guile-debug  ---  Include internal debugging functions
+--disable-arrays      ---  omit array and uniform array support
+--disable-posix       ---  omit posix interfaces
+--disable-networking  ---  omit networking interfaces
+--disable-regex       ---  omit regular expression interfaces
 
 
 Using Guile Without Installing It =========================================
@@ -113,16 +192,37 @@ or if you're using CSH or one of its variants:
   setenv GUILE_LOAD_PATH /home/jimb/guile-snap
 
 
-Building a Statically Linked Guile ========================================
+Installing SLIB ===========================================================
+
+In order to use SLIB from Guile you basically only need to put the
+`slib' directory _in_ one of the directories on Guile's load path.
+
+The standard installation is:
+
+  1. Obtain slib from http://www-swiss.ai.mit.edu/~jaffer/SLIB.html
+
+  2. Put it in Guile's data directory, that is the directory printed when
+     you type
+
+       guile-config info pkgdatadir
 
-Sometimes it's useful to build a statically-linked version of the
-Guile executable.  It's helpful in debugging, and for producing
-stand-alone executables for distribution to machines you don't
-control.
+     at the shell prompt.  This is normally `/usr/local/share/guile', so the
+     directory will normally have full path `/usr/local/share/guile/slib'.
 
-To do this, set the LDFLAGS environment variable to `-static' before
-you configure, or before you run the `make' command to build the
-executable.
+  3. Start guile as a user with write access to the data directory and type
+
+       (use-modules (ice-9 slib))
+
+     at the Guile prompt.  This will generate the slibcat catalog next to
+     the slib directory.
+
+SLIB's `require' is provided by the Guile module (ice-9 slib).
+
+Example:
+
+  (use-modules (ice-9 slib))
+  (require 'primes)
+  (prime? 7)
 
 
 Generic Instructions for Building Auto-Configured Packages ================
@@ -211,3 +311,4 @@ Makefile(s), the header file containing system-dependent definitions
 The file `configure.in' is used as a template to create `configure' by
 a program called `autoconf'.  You will only need it if you want to
 regenerate `configure' using a newer version of `autoconf'.
+