Annotation of OpenXM/src/kan96xx/Doc/httpd-asir.sm1, Revision 1.13
1.13 ! takayama 1: %% $OpenXM: OpenXM/src/kan96xx/Doc/httpd-asir.sm1,v 1.12 2001/08/23 00:16:55 takayama Exp $
1.1 takayama 2: %% http server by sm1
1.2 takayama 3:
1.12 takayama 4: [(parse) (httpd.sm1) pushfile] extension pop
5:
1.2 takayama 6: /httpd.port 1200 def
1.11 takayama 7: /httpd.image.name (kobeuniv2.jpg) def
8: /httpd.image.type (jpeg) def
1.8 takayama 9:
1.4 takayama 10: /httpd.initialization
11: %% Put initialization codes here.
12: [
1.5 takayama 13: ("Asirweb version 0.80. "+
1.4 takayama 14: " Risa/Asir oxasir version "+rtostr(version());)
15: ] cat
16: def
1.8 takayama 17:
1.1 takayama 18: [(parse) (oxasir.sm1) pushfile] extension
19: (oxasir.started) boundp {
20: } {
1.6 takayama 21: %% Initialize oxasir.
1.1 takayama 22: [(x^2-1) (x)] fctr pop
1.5 takayama 23: oxasir.ccc oxmathcap
24: oxasir.ccc oxsetmathcap
1.1 takayama 25: } ifelse
26:
1.12 takayama 27: /webasir { asirweb } def
1.5 takayama 28: /asirweb {
1.7 takayama 29: [/rrr ] pushVariables
30: [
31: %% This procedure to generate port number might fail.
32: [(oxGenPass)] extension . (integer) dc /rrr set
33: rrr << rrr 20000 idiv 20000 mul >> sub /rrr set
34: /httpd.port 1200 rrr add def
35: httpd.port message
36:
1.6 takayama 37: [(sleep 3; netscape -geometry 800x500 http://localhost:)
38: httpd.port toString
39: ( &)] cat system
1.5 takayama 40: httpd ;
1.7 takayama 41: ] pop
42: popVariables
1.5 takayama 43: } def
44:
1.1 takayama 45:
1.2 takayama 46: /httpd_action {
1.5 takayama 47: [/in-httpd /ff /httpd.com /httpd.result /sss
1.6 takayama 48: /sss.engine /sss.web /err
1.13 ! takayama 49: /oxserver.vname
1.3 takayama 50: ] pushVariables
1.2 takayama 51: [
1.1 takayama 52: {
1.5 takayama 53: [(sm1.socket) (select) [httpd.server.fd 0 get -1]] extension
54: %% wait for ever
55: [(sm1.socket) (read) [httpd.server.fd 0 get ]] extension /ff set
1.1 takayama 56: ff length 0 eq {
57: (connection is closed.) message
58: }
1.4 takayama 59: {
1.1 takayama 60: (------------ start ----------------------) message
61: ff message
62: (-----------------------------------------) message
1.11 takayama 63: ff 1 copy askToSendFile /httpd.sendFile set
64: httpd.sendFile tag 0 eq {
65: ff removeGET webstringToAscii /httpd.com set
66: } {
67: /httpd.com (NONE) def
68: } ifelse
69: [(httpd.com=) httpd.com] cat message
70: (httpd.sendFile=) messagen httpd.sendFile message
1.1 takayama 71: (------------ end ----------------------) message
72: ( ) message
1.4 takayama 73: httpd.serial 0 eq {
74: /httpd.com httpd.initialization def
75: } { } ifelse
1.11 takayama 76: httpd.sendFile tag 0 eq { }
77: {
78: httpd.sendFile httpd.image.type send-image
79: exit %% exit the loop LOOP-A
80: } ifelse
1.3 takayama 81: httpd.com metaCommand {
1.8 takayama 82: httpd.textarea.valid {
1.13 ! takayama 83: /oxserver.vname
! 84: [Oxserver_history_variable httpd.serial toString] cat
! 85: def
1.8 takayama 86: oxasir.ccc
1.13 ! takayama 87: %% original (if (1) {) httpd.com (; };)
! 88: [(if (1) {)
! 89: oxserver.vname (=) httpd.com
! 90: (; };)
! 91: oxserver.vname (;)
! 92: ] cat
1.8 takayama 93: oxexecutestring ;
94: }{
95: send-page-warning exit
96: } ifelse
1.6 takayama 97: [(oxReq) oxasir.ccc SM_dupErrors ] extension pop
1.5 takayama 98:
1.6 takayama 99: [(oxReq) oxasir.ccc SM_popCMO ] extension pop
1.5 takayama 100: [(oxReq) oxasir.ccc SM_popString ] extension pop
101: [(flush)] extension pop
102: %% Select inputs for interruption.
103: %% Wait by the spin lock.
104: {
105: [(oxMultiSelect) [oxasir.ccc] 1] extension 1 get 0 get
106: /sss.engine set
107: [(sm1.socket) (mselect)
108: [[httpd.server.fd 0 get] 1]
109: ] extension 0 get /sss.web set
110: /sss [sss.engine sss.web] def
111: sss.engine { exit } { } ifelse
112: sss.web { exit } { } ifelse
113: } loop
114: sss message
115:
116: sss 0 get {
1.6 takayama 117: [(oxGet) oxasir.ccc] extension /err set
1.5 takayama 118: [(oxGet) oxasir.ccc] extension /httpd.result set
119: %% oxasir.ccc oxpopstring /httpd.result set
120: } {
121: oxasir.ccc oxreset
122: oxasir.ccc ("computation is interrupted.";) oxexecutestring ;
123: oxasir.ccc oxpopstring
124: /httpd.result set
125: exit
126: } ifelse
1.3 takayama 127: (------------- result -------------) message
128: httpd.result message
129: (----------------------------------) message
130: ( ) message
1.6 takayama 131:
132: err message
133: err [ ] eq {
134: /httpd.history
135: httpd.history
136: [10 (string) dc
137: (/**** ) httpd.serial toString ( ****/)
138: 10 (string) dc
139: httpd.com
1.8 takayama 140: (;) %% add extra ;
1.6 takayama 141: ] cat
142: append
143: def
144: } {
145: oxasir.ccc cleanErrors
146: [httpd.result 10 (string) dc err toString] cat
147: /httpd.result set
148: } ifelse
149:
1.4 takayama 150: [httpd.serial 0 eq { } {
151: (<title> asirweb </title> )
152: (<font color="blue"> Input-) httpd.serial toString
153: (: </font> )
1.9 takayama 154: httpd.com preformatHTML (<br>)
1.4 takayama 155: } ifelse
1.3 takayama 156: (<font color="green"> Output-) httpd.serial toString
157: (: </font> )
1.11 takayama 158: (<a href="http://localhost:) httpd.port toString
159: (/?msg=httpdAsirMeta+Pretty+) httpd.serial toString
160: ("> (in pretty format) </a>)
161: %%(<a href=") httpd.image.name ("> (in pretty format) </a>) %%test
1.9 takayama 162: httpd.result preformatHTML
1.11 takayama 163: httpd.result.history httpd.result append /httpd.result.history set
1.3 takayama 164: ] cat
1.11 takayama 165: send-page-3 exit %% exit the loop LOOP-A
1.5 takayama 166: } { exit } ifelse %% metaCommand
1.1 takayama 167: } ifelse
1.11 takayama 168: } loop %% LOOP-A
1.2 takayama 169: ] pop
170: popVariables
1.1 takayama 171: } def
172:
173:
1.11 takayama 174:
1.3 takayama 175: /httpd.asirman
176: ("http://www.math.sci.kobe-u.ac.jp/OpenXM/1.1.3/doc/asir2000/html-jp/man_toc.html")
177: def
178: /httpd.asirman.index
179: ("http://www.math.sci.kobe-u.ac.jp/OpenXM/1.1.3/doc/asir2000/html-jp/man_262.html#SEC262")
180: def
1.4 takayama 181: /httpd.asir.intro
182: ("http://www.math.sci.kobe-u.ac.jp/~taka/asir-book-html/main")
183: def
1.3 takayama 184: /send-menu-1 {
185:
1.4 takayama 186: (FILE:) sendln
1.3 takayama 187: [$<a href="http://localhost:$ httpd.port toString
1.4 takayama 188: $/?msg=httpdAsirMeta+quit"> Shutdown the asir server. </a>, $
1.3 takayama 189: ] cat sendln
1.5 takayama 190: %% [$<a href="http://localhost:$ httpd.port toString
191: %% $/?msg=httpdAsirMeta+interrupt"> interrupt </a>, $
192: %% ] cat sendln
193: [$<a href="http://localhost:$ httpd.port toString
194: $/?msg=httpdAsirMeta+save"> save. </a>, $
195: ] cat sendln
1.4 takayama 196: ( <spacer type=horizontal size=80> ) sendln
1.3 takayama 197:
1.4 takayama 198: (HELP:) sendln
1.3 takayama 199: [(<font color="red">
1.4 takayama 200: <a href=) httpd.asirman ( > AsirManual (Ja) </a> </font>, )] cat sendln
1.3 takayama 201: [(<font color="purple">
1.4 takayama 202: <a href=) httpd.asirman.index ( > Index (Ja) </a> </font>, )] cat sendln
203: [(<font color="blue">
204: <a href=) httpd.asir.intro ( > Intro (Ja) </a> </font>, )] cat sendln
1.3 takayama 205: } def
1.1 takayama 206:
1.5 takayama 207: /send-page-save {
208: [/in-send-page-save /i] pushVariables
209: [
210: (HTTP/0.9 200 OK) sendln
211: (Connection: close) sendln
1.8 takayama 212: (Content-Type: text/plain) sendln
1.5 takayama 213: 0 sendln
1.8 takayama 214: (/* Saved the following to sm1out.txt */) sendln
215: (/* Save the following by your browser as a text file. */) sendln
1.5 takayama 216:
217: 0 1 httpd.history length 1 sub {
218: /i set
219: httpd.history i get sendln
220: } for
1.8 takayama 221: ( end$) sendln
1.5 takayama 222: 0 sendln
223: [(flush)] extension
224: [(PrintDollar) 1] system_variable
225: httpd.history output
226: [(PrintDollar) 0] system_variable
227: ] pop
228: popVariables
229: } def
230:
1.3 takayama 231:
232: /metaCommand {
233: /arg1 set
1.11 takayama 234: [/in-metaCommand /msg /result /msg2 /nn] pushVariables
1.3 takayama 235: [
236: /msg arg1 def
237: /result 1 def
1.11 takayama 238: msg 1 copy toTokensBySpace /msg2 set
239: msg2 length 3 eq {
240: msg2 0 get (httpdAsirMeta) eq
241: msg2 1 get (Pretty) eq and
242: {
243: msg2 2 get . (integer) dc /nn set
244:
245: %%BUG: This part should be rewritten.
246: %% Reformat the "nn"-th result by tex and send it.
247: httpd.result.history nn get message
248: httpd.image.name httpd.image.type send-image
249: %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
250:
251: /result 0 def
252: } { } ifelse
253: }{ } ifelse
1.3 takayama 254: msg (httpdAsirMeta quit) eq {
1.8 takayama 255: oxasir.ccc oxshutdown
1.3 takayama 256: send-page-bye
257: quit
1.5 takayama 258: /result 0 def
259: } { } ifelse
260: msg (httpdAsirMeta save) eq {
261: send-page-save
262: /result 0 def
263: } { } ifelse
264: msg (httpdAsirMeta interrupt) eq {
265: oxasir.ccc oxreset
266: (Interrupted! <br>) send-page-3
1.3 takayama 267: /result 0 def
268: } { } ifelse
269: /arg1 result def
270: ] pop
271: popVariables
272: arg1
273: } def
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>