2005-02-14 17:19:09 -05:00
|
|
|
! Copyright (C) 2004 Chris Double.
|
|
|
|
!
|
|
|
|
! Redistribution and use in source and binary forms, with or without
|
|
|
|
! modification, are permitted provided that the following conditions are met:
|
|
|
|
!
|
|
|
|
! 1. Redistributions of source code must retain the above copyright notice,
|
|
|
|
! this list of conditions and the following disclaimer.
|
|
|
|
!
|
|
|
|
! 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
! this list of conditions and the following disclaimer in the documentation
|
|
|
|
! and/or other materials provided with the distribution.
|
|
|
|
!
|
|
|
|
! THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
|
|
|
! INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
|
|
! FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
! DEVELOPERS AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
! SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
! PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
|
|
! OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
|
|
! WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
|
|
! OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
|
|
! ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
!
|
|
|
|
! A Smalltalk-like browser that runs in the httpd server using
|
|
|
|
! cont-responder facilities.
|
|
|
|
!
|
|
|
|
IN: browser-responder
|
2005-06-19 17:50:35 -04:00
|
|
|
USING: html cont-responder kernel io namespaces words lists
|
|
|
|
io strings inspector kernel prettyprint words http parser
|
2005-05-02 00:18:34 -04:00
|
|
|
errors unparser listener hashtables memory
|
2005-04-25 19:54:21 -04:00
|
|
|
sequences ;
|
2005-02-14 17:19:09 -05:00
|
|
|
|
|
|
|
: <browser> ( allow-edit? vocab word -- )
|
|
|
|
#! An object for storing the current browser
|
|
|
|
#! user interface state.
|
|
|
|
<namespace> [
|
|
|
|
"current-word" set
|
|
|
|
"current-vocab" set
|
|
|
|
"allow-edit?" set
|
|
|
|
] extend ;
|
|
|
|
|
|
|
|
: write-vocab-list ( -- )
|
|
|
|
#! Write out the HTML for the list of vocabularies
|
|
|
|
<select name= "vocabs" style= "width: 200" size= "20" onchange= "document.forms.main.submit()" select>
|
|
|
|
vocabs [
|
|
|
|
dup "current-vocab" get [ "" ] unless* = [
|
|
|
|
"<option selected>" write
|
|
|
|
] [
|
|
|
|
"<option>" write
|
|
|
|
] ifte
|
|
|
|
chars>entities write
|
|
|
|
"</option>\n" write
|
|
|
|
] each
|
|
|
|
</select> ;
|
|
|
|
|
|
|
|
: write-word-list ( vocab -- )
|
|
|
|
#! Write out the HTML for the list of words in a vocabulary.
|
|
|
|
<select name= "words" style= "width: 200" size= "20" onchange= "document.forms.main.submit()" select>
|
|
|
|
words [
|
2005-07-19 04:23:33 -04:00
|
|
|
word-name dup "current-word" get [ "" ] unless* = [
|
2005-02-14 17:19:09 -05:00
|
|
|
"<option selected>" write
|
|
|
|
] [
|
|
|
|
"<option>" write
|
|
|
|
] ifte
|
|
|
|
chars>entities write
|
|
|
|
"</option>\n" write
|
|
|
|
] each
|
|
|
|
</select> ;
|
|
|
|
|
|
|
|
: write-editable-word-source ( vocab word -- )
|
|
|
|
#! Write the source in a manner allowing it to be edited.
|
|
|
|
<textarea name= "eval" rows= "30" cols= "80" textarea>
|
2005-04-19 20:28:01 -04:00
|
|
|
[
|
2005-02-14 17:19:09 -05:00
|
|
|
>r words r> swap [ over swap dup word-name rot = [ see ] [ drop ] ifte ] each drop
|
2005-06-19 18:53:58 -04:00
|
|
|
] string-out chars>entities write
|
2005-02-14 17:19:09 -05:00
|
|
|
</textarea> <br/>
|
|
|
|
"Accept" button ;
|
|
|
|
|
|
|
|
: write-word-source ( vocab word -- )
|
|
|
|
#! Write the source for the given word from the vocab as HTML.
|
|
|
|
<namespace> [
|
2005-04-16 00:23:27 -04:00
|
|
|
"allow-edit?" get [ "Edit" [ "edit-state" on ] quot-href <br/> ] when
|
2005-02-14 17:19:09 -05:00
|
|
|
"edit-state" get [
|
|
|
|
write-editable-word-source
|
|
|
|
] [
|
|
|
|
2dup swap unit search [
|
|
|
|
[
|
|
|
|
>r words r> swap [ over swap dup word-name rot = [ see ] [ drop ] ifte ] each drop
|
|
|
|
] with-simple-html-output
|
|
|
|
] when
|
|
|
|
] ifte
|
|
|
|
] bind drop ;
|
|
|
|
|
|
|
|
: write-vm-statistics ( -- )
|
|
|
|
#! Display statistics about the vm.
|
|
|
|
<pre> room. </pre> ;
|
|
|
|
|
|
|
|
: write-browser-body ( -- )
|
|
|
|
#! Write out the HTML for the body of the main browser page.
|
|
|
|
<table width= "100%" table>
|
|
|
|
<tr>
|
|
|
|
<td> "<b>Vocabularies</b>" write </td>
|
|
|
|
<td> "<b>Words</b>" write </td>
|
|
|
|
<td> "<b>Source</b>" write </td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td valign= "top" style= "width: 200" td> write-vocab-list </td>
|
|
|
|
<td valign= "top" style= "width: 200" td> "current-vocab" get write-word-list </td>
|
|
|
|
<td valign= "top" td> "current-vocab" get "current-word" get write-word-source </td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
write-vm-statistics ;
|
|
|
|
|
|
|
|
: flatten ( tree - list )
|
|
|
|
#! Flatten a tree into a list.
|
|
|
|
dup f = [
|
|
|
|
] [
|
|
|
|
dup cons? [
|
|
|
|
dup car flatten swap cdr flatten append
|
|
|
|
] [
|
|
|
|
[ ] cons
|
|
|
|
] ifte
|
|
|
|
] ifte ;
|
|
|
|
|
|
|
|
: word-uses ( word -- list )
|
|
|
|
#! Return a list of vocabularies that the given word uses.
|
2005-03-05 14:45:23 -05:00
|
|
|
word-def flatten [ word? ] subset [
|
2005-02-14 17:19:09 -05:00
|
|
|
word-vocabulary
|
|
|
|
] map ;
|
|
|
|
|
|
|
|
: vocabulary-uses ( vocab -- list )
|
|
|
|
#! Return a list of vocabularies that all words in a vocabulary
|
|
|
|
#! uses.
|
2005-05-14 21:15:50 -04:00
|
|
|
words [ word-uses ] map prune ;
|
2005-02-14 17:19:09 -05:00
|
|
|
|
|
|
|
: build-eval-string ( vocab to-eval -- string )
|
|
|
|
#! Build a string that can evaluate the string 'to-eval'
|
|
|
|
#! by first doing an 'IN: vocab' and a 'USE:' of all
|
|
|
|
#! necessary vocabs for existing words in that vocab.
|
2005-07-17 14:48:55 -04:00
|
|
|
[ >r "IN: " % dup % "\n" %
|
|
|
|
vocabulary-uses [ "USE: " % % "\n" % ] each
|
|
|
|
r> % "\n" % ] make-string ;
|
2005-02-14 17:19:09 -05:00
|
|
|
|
|
|
|
: show-parse-error ( error -- )
|
|
|
|
#! Show an error page describing the parse error.
|
|
|
|
[
|
|
|
|
<html>
|
|
|
|
<head> <title> "Parse error" write </title> </head>
|
|
|
|
<body>
|
|
|
|
swap [ write ] with-simple-html-output
|
|
|
|
<a href= a> "Ok" write </a>
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
] show drop drop ;
|
|
|
|
|
|
|
|
: eval-string ( vocab to-eval -- )
|
|
|
|
#! Evaluate the 'to-eval' within the given vocabulary.
|
|
|
|
build-eval-string [
|
|
|
|
parse call
|
|
|
|
] [
|
|
|
|
[
|
|
|
|
show-parse-error
|
|
|
|
drop
|
|
|
|
] when*
|
|
|
|
] catch ;
|
|
|
|
|
|
|
|
: browser-url ( vocab word -- url )
|
|
|
|
#! Given a vocabulary and word as strings, return a browser
|
|
|
|
#! URL which, when requested, will display the source to that
|
|
|
|
#! word.
|
|
|
|
[
|
2005-07-17 14:48:55 -04:00
|
|
|
".?word=" % url-encode %
|
|
|
|
"&vocab=" % url-encode %
|
2005-02-14 17:19:09 -05:00
|
|
|
] make-string ;
|
|
|
|
|
|
|
|
: browse ( <browser> -- )
|
|
|
|
#! Display a Smalltalk like browser for exploring/modifying words.
|
|
|
|
[
|
|
|
|
[
|
|
|
|
<html>
|
|
|
|
<head>
|
2005-02-20 19:47:08 -05:00
|
|
|
<title>
|
|
|
|
"Factor Browser - " write
|
|
|
|
"current-vocab" get write
|
|
|
|
" - " write
|
|
|
|
"current-word" get write
|
|
|
|
</title>
|
2005-05-19 20:08:05 -04:00
|
|
|
<style>
|
|
|
|
"A:link { text-decoration:none}\n" write
|
|
|
|
"A:visited { text-decoration:none}\n" write
|
|
|
|
"A:active { text-decoration:none}\n" write
|
|
|
|
"A:hover, A.nav:hover { border: 1px solid black; text-decoration: none; margin: 0px }\n" write
|
|
|
|
"A { margin: 1px }" write
|
|
|
|
</style>
|
2005-02-14 17:19:09 -05:00
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<form name= "main" action= method= "post" form>
|
|
|
|
write-browser-body
|
|
|
|
</form>
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
] show [
|
|
|
|
"allow-edit?" get [
|
|
|
|
"eval" get [
|
2005-04-16 00:23:27 -04:00
|
|
|
"eval" off
|
2005-02-14 17:19:09 -05:00
|
|
|
"Editing has been disabled." show-message-page
|
|
|
|
] when
|
|
|
|
] unless
|
|
|
|
"allow-edit?" get "allow-edit?" set
|
|
|
|
] extend
|
|
|
|
] bind [
|
|
|
|
"allow-edit?" get
|
|
|
|
"vocabs" get
|
|
|
|
"words" get
|
|
|
|
"eval" get dup [ "vocabs" get swap eval-string ] [ drop ] ifte
|
|
|
|
[
|
|
|
|
"vocabs" get dup [ ] [ drop "unknown" ] ifte "words" get dup [ ] [ drop "unknown" ] ifte browser-url
|
|
|
|
forward-to-url
|
2005-02-20 19:47:08 -05:00
|
|
|
] show-final
|
2005-02-14 17:19:09 -05:00
|
|
|
] bind <browser> ;
|
|
|
|
|
|
|
|
: browser-responder ( allow-edit? -- )
|
|
|
|
#! Start the Smalltalk-like browser.
|
|
|
|
"query" get dup [
|
|
|
|
dup >r "vocab" swap assoc r> "word" swap assoc
|
|
|
|
] [
|
|
|
|
drop "browser-responder" "<browser>"
|
|
|
|
] ifte <browser> browse ;
|
|
|
|
|
|
|
|
! "browser-edit" [ t browser-responder ] install-cont-responder
|