File: README

package info (click to toggle)
clisp 1%3A2.49-8.1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 45,160 kB
  • sloc: lisp: 79,960; ansic: 48,257; xml: 26,814; sh: 12,846; fortran: 7,286; makefile: 1,456; perl: 164
file content (146 lines) | stat: -rw-r--r-- 5,535 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146

        README for CLISP FastCGI interface module
        http://clisp.alma.com

        John Hinsdale, Alma Mater Software, Inc.
        hin@alma.com

        $Id: README,v 1.3 2008/06/29 17:51:01 sds Exp $

This CLISP module provides an interface with the FastCGI protocol,
which implements a fully CGI-compatible process model for running Web
server back-end scripts.  See http://www.fastcgi.com

This README is organized as follows:

        (1) System requirements
        (2) Building the module
        (3) Using the module

Each section follows.

        (1) SYSTEM REQUIREMENTS
            -------------------

You will need to:

    - Know how to compile CLISP from source code (the binaries do
      not contain the extra modules compiled in).

    - Understand FastCGI by reading up on it at http://www.fastcgi.com

    - Download the FastCGI developer's kit, build it, and install it
      See http://www.fastcgi.com  Win32 users should see
          http://www.caraveo.com/fastcgi/

    - Upgrade your Web server to speak FastCGI.  For Apache, this
      means getting and installing the module "mod_fastcgi" and then
      configuring your Web server to use it.  I personally compile
      it in statically with Apache and then just add
		Addhandler fastcgi-script .fcgi
      to my .conf file.  Then I make symbolic links to my "foo.cgi" to
      also point to "foo.fcgi" and invoke the appropriate URL.

    - Re-compile your CLISP to use this module (see (2) below).

    - If you have existing CLISP CGI scripts, you will need to make
      some slight modifications as to how the do input and output,
      so that they will work both as CGIs and as "FastCGIs".


        (2) BUILDING THE MODULE
            -------------------

As of ver. 2.31, CLISP comes with the module in the source distribution.
The module is in the subdirectory "modules/fastcgi".

Run (or re-run) CLISP configure, adding the option
    "--with-module=fastcgi"
If you have build CLISP already:
$ cd build-dir && make MODULES=fastcgi

Re-compile and install CLISP.  Note you have to use the "full" linking
set to get the extra modules (e.g., "clisp -K full").  You'll know you
have it installed when you can do "(DESCRIBE 'FASTCGI:ACCEPT)" and get
something.

        (3) USING THE MODULE
            ----------------

Most CGI programs work by doing input/output with the Web server via
the following channels:

	(a) environment variables (e.g., "HTTP_USER_AGENT" is the
	    set by the Web server to name the browser used

	(b) reading from standard input (i.e., to get input data in
            a "method=POST" request

	(c) writing an HTTP response document (usually "Content-type:
	    text/html") to the standard output, for eventual transmission
	    back to the browser client

	(d) writing error messages to the standard error, usually captured
	    by the Web server and logged in its log files.

The FastCGI module involves replacing calls the standard routines to
do the above with calls in the FASTCGI package.  These calls will then
work exactly as before when the program is invoked as a CGI, but will
also work when invoked as a FastCGI.

Here is how to do each of the above using this module:

	(a) To get an environment variable, use (FASTCGI:GETENV var),
            e.g., (setf browser (fastcgi:getenv "HTTP_USER_AGENT"))
            instead of the regular operating system's getenv() call.

	(b) To read the entirety of the standard input, usually what
	    one does, use FASTCGI:SLURP-STDIN, e.g.
	    (setf stdin (fastcgi:slurp-stdin))

	(c) To print output, instead of writing to the stream
	    *standard-output* using normal Lisp I/O function, instead
            call (FASTCGI:WRITE-STDOUT string).  If you want to use
            FORMAT, then you can use (FASTCGI:WRITE-STDOUT (format ...))
            For convenient, there is a function (FASTCGI:OUT ...) that
            will print multiple arguments.

	(d) Same as above, but use FASTCGI:WRITE-STDERR.

In addition to the above, it is also useful to test if the script is
running in CGI mode or in "FastCGI mode".  This is useful if you have
installed the (same) script under two different names (e.g., "foo.cgi"
and "foo.fcgi") to have the Web server launch it differently based on
its name.  In that situation, any links you generate back to the same
script you will want to make to the CGI or FastCGI depending on how
the script was launched.  The way to test for this is to call
(FASTCGI:IS-CGI) which will return T iff the script is running in CGI
mode.

A complete example follows.  Try installing the program below under
the name "foo.cgi" to run it as CGI and also (perhaps via a symbolic
link) as "foo.fcgi" to run it as FastCGI, assuming that is how your
Web server is set up.  Reload the page a few times under CGI mode and
then under FastCGI.  Make sure that the mode reported by the script is
what you expected.  Notice how much faster it is under FastCGI and
then Email me and tell me whether this all was worth it.  :)

#-----------------  Cut here ------
#!/usr/local/bin/clisp -q -L en_US -K full

(defun nl () (format nil "~%"))

(do ((count 1 (1+ count)))
    ((not (fastcgi:accept)) nil)

    (fastcgi:out "Content-type: text/plain" (nl) (nl))
    (fastcgi:out
     "I am running in mode: " (if (fastcgi:is-cgi) "CGI" "FastCGI") (nl)
     "This is execution no.: " count (nl)
     "The browser string is '" (fastcgi:getenv "HTTP_USER_AGENT") "'" (nl))

    (fastcgi:finish))
#-----------------  Cut here ------


                *   *   *