From mboxrd@z Thu Jan 1 00:00:00 1970 Path: main.gmane.org!not-for-mail From: Arno Peters Newsgroups: gmane.lisp.guile.user Subject: Re: evaluating a file with out side effects Date: Mon, 2 Jun 2003 22:45:37 +0200 Sender: guile-user-bounces+guile-user=m.gmane.org@gnu.org Message-ID: <20030602204537.GA3841@duronbox> References: <20030602002527.66382.qmail@web20501.mail.yahoo.com> NNTP-Posting-Host: main.gmane.org Mime-Version: 1.0 Content-Type: multipart/mixed; boundary="===============95760944586686236==" X-Trace: main.gmane.org 1054586869 5349 80.91.224.249 (2 Jun 2003 20:47:49 GMT) X-Complaints-To: usenet@main.gmane.org NNTP-Posting-Date: Mon, 2 Jun 2003 20:47:49 +0000 (UTC) Original-X-From: guile-user-bounces+guile-user=m.gmane.org@gnu.org Mon Jun 02 22:47:44 2003 Return-path: Original-Received: from monty-python.gnu.org ([199.232.76.173]) by main.gmane.org with esmtp (Exim 3.35 #1 (Debian)) id 19MwDY-0001NE-00 for ; Mon, 02 Jun 2003 22:47:44 +0200 Original-Received: from localhost ([127.0.0.1] helo=monty-python.gnu.org) by monty-python.gnu.org with esmtp (Exim 4.20) id 19MwF9-0007iY-H5 for guile-user@m.gmane.org; Mon, 02 Jun 2003 16:49:23 -0400 Original-Received: from list by monty-python.gnu.org with tmda-scanned (Exim 4.20) id 19MwDW-0007HT-28 for guile-user@gnu.org; Mon, 02 Jun 2003 16:47:42 -0400 Original-Received: from mail by monty-python.gnu.org with spam-scanned (Exim 4.20) id 19MwDS-0007GX-9j for guile-user@gnu.org; Mon, 02 Jun 2003 16:47:38 -0400 Original-Received: from amsfep11-int.chello.nl ([213.46.243.20]) by monty-python.gnu.org with esmtp (Exim 4.20) id 19MwBg-0006wy-2C for guile-user@gnu.org; Mon, 02 Jun 2003 16:45:48 -0400 Original-Received: from duronbox.nosuchnet ([62.163.16.73]) by amsfep11-int.chello.nlESMTP <20030602204537.MUTT7516.amsfep11-int.chello.nl@duronbox.nosuchnet> for ; Mon, 2 Jun 2003 22:45:37 +0200 Original-Received: from arno by duronbox.nosuchnet with local (Exim 3.36 #1 (Debian)) id 19MwBV-00012c-00 for ; Mon, 02 Jun 2003 22:45:37 +0200 Original-To: guile-user@gnu.org In-Reply-To: <20030602002527.66382.qmail@web20501.mail.yahoo.com> User-Agent: Mutt/1.5.4i X-BeenThere: guile-user@gnu.org X-Mailman-Version: 2.1b5 Precedence: list List-Id: General Guile related discussions List-Help: List-Post: List-Subscribe: , List-Archive: List-Unsubscribe: , Errors-To: guile-user-bounces+guile-user=m.gmane.org@gnu.org Xref: main.gmane.org gmane.lisp.guile.user:2021 X-Report-Spam: http://spam.gmane.org/gmane.lisp.guile.user:2021 --===============95760944586686236== Content-Disposition: inline content-type: multipart/signed; micalg="pgp-sha1"; protocol="application/pgp-signature"; boundary="8GpibOaaTibBMecb" --8GpibOaaTibBMecb Content-Type: multipart/mixed; boundary="nFreZHaLTZJo0R7j" Content-Disposition: inline --nFreZHaLTZJo0R7j Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Sun, Jun 01, 2003 at 08:25:26PM -0400, Thomas Mulcahy wrote: > Hi, I'm attempting to use scheme to generate HTML for > a page like this: > http://okmij.org/ftp/Scheme/xml.scm > (See http://okmij.org/ftp/Scheme/xml.html for the HTML > version). > To do this, I need to evaluate the contents of a file > and get the result. The guile load procedure returns > unspecified however, instead of the result of > evaluating the file. I can see how it would be > possible to evaluate each s-expression in the file but > this seems a bit awkward and would have side effects > (definitions in the file might overwrite my own > definitions). What is the best way to do this? SSAX uses the function SRV:send-reply to display the list of fragments. At the end of xml.scm, you see: (define (generate-HTML Content) (SRV:send-reply (pre-post-order Content (generic-web-rules Content '())))) =20 (generate-HTML Content) Note that the variable Content in the last line contains the SXML expressions that are to be transformed into HTML. Perhaps these lines are missing from your file? You may run into some problems using SSAX with Guile directly from the CVS repository. I use the two attached files to integrate SSAX into Guile. Use these files if you like to get SSAX to work for you, they are hereby released into the public domain. Regards, --=20 Arno Peters --nFreZHaLTZJo0R7j Content-Type: text/plain; charset=us-ascii Content-Disposition: attachment; filename="myenv-guile.scm" Content-Transfer-Encoding: quoted-printable ; My Standard Scheme "Prelude" ; Version for SCM v5d2 ; $Id: myenv-scm.scm,v 1.2 2001/09/21 19:53:30 oleg Exp $ (use-modules (ice-9 slib)) ; Very SCM-specific definitions (defmacro define-macro (bindings . body) (if (pair? bindings) `(defmacro ,(car bindings) ,(cdr bindings) ,@body) (let ((rest (gensym))) `(defmacro ,bindings ,rest (apply ,@body ,rest))))) (define-macro (include file)=20 (if (equal? file "myenv.scm") '(begin #f) `(load ,file))) (define pp display) (define-macro (declare . x) '(begin #f)) ; Gambit-specific compiler-decl ; Support for let*-values form (require 'values) ; Like let* but allowing for multiple-value bindings (define-macro (let*-values bindings . body) (if (null? bindings) (cons 'begin body) (apply (lambda (vars initializer) (let ((cont=20 (cons 'let*-values=20 (cons (cdr bindings) body)))) (cond ((not (pair? vars)) ; regular let case, a single var `(let ((,vars ,initializer)) ,cont)) ((null? (cdr vars)) ; single var, see the prev case `(let ((,(car vars) ,initializer)) ,cont)) (else ; the most generic case `(call-with-values (lambda () ,initializer) (lambda ,vars ,cont)))))) (car bindings)))) ; A few convenient functions that are not SCM (define (with-input-from-string str thunk) (call-with-input-string str (lambda (port) (with-input-from-port port thunk)))) (define (open-input-string str) (call-with-current-continuation (lambda (k) (call-with-input-string str (lambda (port) (k port)))))) (define (with-output-to-string thunk) (call-with-output-string (lambda (port) (with-output-to-port port thunk)))) ; assert the truth of an expression (or of a sequence of expressions) ; ; syntax: assert ?expr ?expr ... [report: ?r-exp ?r-exp ...] ; ; If (and ?expr ?expr ...) evaluates to anything but #f, the result ; is the value of that expression. ; If (and ?expr ?expr ...) evaluates to #f, an error is reported. ; The error message will show the failed expressions, as well ; as the values of selected variables (or expressions, in general). ; The user may explicitly specify the expressions whose ; values are to be printed upon assertion failure -- as ?r-exp that ; follow the identifier 'report:' ; Typically, ?r-exp is either a variable or a string constant. ; If the user specified no ?r-exp, the values of variables that are ; referenced in ?expr will be printed upon the assertion failure. (define-macro (assert expr . others) ; given the list of expressions or vars, ; make the list appropriate for cerr (define (make-print-list prefix lst) (cond ((null? lst) '()) ((symbol? (car lst)) (cons #\newline (cons (list 'quote (car lst)) (cons ": " (cons (car lst) (make-print-list #\newline (cdr lst))))))) (else=20 (cons prefix (cons (car lst) (make-print-list "" (cdr lst))))))) ; return the list of all unique "interesting" ; variables in the expr. Variables that are certain ; to be bound to procedures are not interesting. (define (vars-of expr) (let loop ((expr expr) (vars '())) (cond ((not (pair? expr)) vars) ; not an application -- ignore ((memq (car expr)=20 '(quote let let* letrec let*-values lambda cond quasiquote case define do assert)) vars) ; won't go there (else ; ignore the head of the application (let inner ((expr (cdr expr)) (vars vars)) (cond=20 ((null? expr) vars) ((symbol? (car expr)) (inner (cdr expr) (if (memq (car expr) vars) vars (cons (car expr) vars)))) (else (inner (cdr expr) (loop (car expr) vars))))))))) (cond ((null? others) ; the most common case `(or ,expr (begin (cerr "failed assertion: " ',expr nl "bindings" ,@(make-print-list #\newline (vars-of expr)) nl) (error "assertion failure")))) ((eq? (car others) 'report:) ; another common case `(or ,expr (begin (cerr "failed assertion: " ',expr ,@(make-print-list #\newline (cdr others)) nl) (error "assertion failure")))) ((not (memq 'report: others)) `(or (and ,expr ,@others) (begin (cerr "failed assertion: " '(,expr ,@others) nl "bindings" ,@(make-print-list #\newline (vars-of (cons 'and (cons expr others)))) nl) (error "assertion failure")))) (else ; report: occurs somewhere in 'others' (let loop ((exprs (list expr)) (reported others)) (cond ((eq? (car reported) 'report:) `(or (and ,@(reverse exprs)) (begin (cerr "failed assertion: " ',(reverse exprs) ,@(make-print-list #\newline (cdr reported)) nl) (error "assertion failure")))) (else (loop (cons (car reported) exprs) (cdr reported))))))) ) =20 (define-macro (assure exp error-msg) `(assert ,exp report: ,error-msg)) (define (identify-error msg args . disposition-msgs) (let ((port (current-error-port))) (newline port) (display "ERROR" port) (display msg port) (for-each (lambda (msg) (display msg port)) (append args disposition-msgs)) (newline port))) ; like cout << arguments << args ; where argument can be any Scheme object. If it's a procedure ; (without args) it's executed rather than printed (like newline) (define (cout . args) (for-each (lambda (x) (if (procedure? x) (x) (display x))) args)) (define (cerr . args) (for-each (lambda (x) (if (procedure? x) (x (current-error-port)) (display x (current-error-port)))) args)) ;(##define-macro (nl) '(newline)) (define nl (string #\newline)) ; Some useful increment/decrement operators ; Note, ##fixnum prefix is Gambit-specific, it means that the ; operands assumed FIXNUM (as they ought to be anyway). ; This perfix could be safely removed: it'll leave the code just as ; correct, but more portable (and less efficient) ; Mutable increment (define-macro (++! x) `(set! ,x (+ 1 ,x))) ; Read-only increment (define-macro (++ x) `(+ 1 ,x)) ; Mutable decrement (define-macro (--! x) `(set! ,x (- ,x 1))) ; Read-only decrement (define-macro (-- x) `(- ,x 1)) ; Some useful control operators ; if condition is true, execute stmts in turn ; and return the result of the last statement ; otherwise, return #f (define-macro (when condition . stmts) `(and ,condition (begin ,@stmts))) =20 ; if condition is false execute stmts in turn ; and return the result of the last statement ; otherwise, return #t ; This primitive is often called 'unless' (define-macro (whennot condition . stmts) `(or ,condition (begin ,@stmts))) ; Execute a sequence of forms and return the ; result of the _first_ one. Like PROG1 in Lisp. ; Typically used to evaluate one or more forms with ; side effects and return a value that must be ; computed before some or all of the side effects happen. (define-macro (begin0 form . forms) (let ((var (gensym))) `(let ((,var ,form)) ,@forms ,var))) ; Prepend an ITEM to a LIST, like a Lisp macro PUSH ; an ITEM can be an expression, but ls must be a VAR (define-macro (push! item ls) `(set! ,ls (cons ,item ,ls))) ; Is str the empty string? ; string-null? str -> bool ; See Olin Shiver's Underground String functions (define-macro (string-null? str) `(zero? (string-length ,str))) ; assoc-primitives with a default clause ; If the search in the assoc list fails, the ; default action argument is returned. If this ; default action turns out to be a thunk, ; the result of its evaluation is returned. ; If the default action is not given, an error ; is signaled (define-macro (assq-def key alist . default-action-arg) (let ((default-action (if (null? default-action-arg) `(error "failed to assq key '" ,key "' in a list " ,alist) (let ((defact-symb (car default-action-arg))) `(if (procedure? ,defact-symb) (,defact-symb) ,defact-symb))))) `(or (assq ,key ,alist) ,default-action))) (define-macro (assv-def key alist . default-action-arg) (let ((default-action (if (null? default-action-arg) `(error "failed to assv key '" ,key "' in a list " ,alist) (let ((defact-symb (car default-action-arg))) `(if (procedure? ,defact-symb) (,defact-symb) ,defact-symb))))) `(or (assv ,key ,alist) ,default-action))) (define-macro (assoc-def key alist . default-action-arg) (let ((default-action (if (null? default-action-arg) `(error "failed to assoc key '" ,key "' in a list " ,alist) (let ((defact-symb (car default-action-arg))) `(if (procedure? ,defact-symb) (,defact-symb) ,defact-symb))))) `(or (assoc ,key ,alist) ,default-action))) ; Convenience macros to avoid quoting of symbols ; being deposited/looked up in the environment (define-macro (env.find key) `(%%env.find ',key)) (define-macro (env.demand key) `(%%env.demand ',key)) (define-macro (env.bind key value) `(%%env.bind ',key ,value)) ; Implementation of SRFI-0 ; Only feature-identifiers srfi-0 and scm ; assumed predefined (define-macro (cond-expand . clauses) (define feature-ids '(scm srfi-0)) (define (feature-req-satisfies? fr) ; does feature-request satisfies? (cond ((memq fr feature-ids) #t) ((not (pair? fr)) #f) ((eq? 'and (car fr)) (let loop ((clauses (cdr fr))) (or (null? clauses) (and (feature-req-satisfies? (car clauses)) (loop (cdr clauses)))))) ((eq? 'or (car fr)) (let loop ((clauses (cdr fr))) (and (pair? clauses) (or (feature-req-satisfies? (car clauses)) (loop (cdr clauses)))))) ((eq? 'not (car fr)) (not (feature-req-satisfies? (and (pair? (cdr fr)) (cadr fr))))) (else #f))) (let loop ((clauses clauses)) (if (null? clauses) '(error "Unfulfilled cond-expand") (let* ((feature-req (if (pair? (car clauses)) (caar clauses) (error " is not a list"))) (cmd-or-defs* (cons 'begin (cdar clauses)))) (cond ((and (eq? 'else feature-req) (null? (cdr clauses))) cmd-or-defs*) ((feature-req-satisfies? feature-req) cmd-or-defs*) (else (loop (cdr clauses)))))))) (define (parser-error port message . specialising-msgs) (apply cerr (cons message specialising-msgs)) (cerr nl) (exit 4)) (define (OS:file-length file) (stat:size (stat file))) --nFreZHaLTZJo0R7j Content-Type: text/plain; charset=us-ascii Content-Disposition: attachment; filename="sxml.scm" (define-module (sxml sxml) :use-module (srfi srfi-13)) (load "myenv-guile.scm") (load "char-encoding.scm") (load "look-for-str.scm") (load "input-parse.scm") (load "util.scm") (load "SSAX.scm") (load "SXML-tree-trans.scm") (load "SXML-to-HTML.scm") (load "SXML-to-HTML-ext.scm") (export-syntax let*-values) (export post-order SXML->HTML string->goodHTML entag enattr lookup-def nl list-intersperse make-navbar make-header make-footer pre-post-order post-order generic-web-rules SRV:send-reply ssax:make-parser ssax:make-elem-parser ssax:scan-Misc xml-token-kind xml-token-head assert-curr-char ssax:S-chars ssax:skip-S ssax:read-QName ssax:ncname-starting-char? ssax:read-external-id ssax:make-pi-parser ssax:skip-pi ssax:Prefix-XML ssax:complete-start-tag ssax:read-char-data ssax:assert-token when ssax:handle-parsed-entity ssax:predefined-parsed-entities cerr ) --nFreZHaLTZJo0R7j-- --8GpibOaaTibBMecb Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.2.2 (GNU/Linux) iD8DBQE+27dx8ADMpEVEv6ERAtB/AKDjYoVKZRb/XL1li1iGlk2fK9FtlwCgzeKJ /8jpZ1JZEsff9pjjcfqR7LQ= =zE9t -----END PGP SIGNATURE----- --8GpibOaaTibBMecb-- --===============95760944586686236== Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit _______________________________________________ Guile-user mailing list Guile-user@gnu.org http://mail.gnu.org/mailman/listinfo/guile-user --===============95760944586686236==--