1 ;;; Guile Scheme specification
3 ;; Copyright (C) 2001 Free Software Foundation, Inc.
5 ;;;; This library is free software; you can redistribute it and/or
6 ;;;; modify it under the terms of the GNU Lesser General Public
7 ;;;; License as published by the Free Software Foundation; either
8 ;;;; version 3 of the License, or (at your option) any later version.
10 ;;;; This library is distributed in the hope that it will be useful,
11 ;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
12 ;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 ;;;; Lesser General Public License for more details.
15 ;;;; You should have received a copy of the GNU Lesser General Public
16 ;;;; License along with this library; if not, write to the Free Software
17 ;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 (define-module (language scheme compile-tree-il)
22 #:use-module (language tree-il)
23 #:export (compile-tree-il))
28 ;;; compile-env := (MODULE LEXICALS . EXTERNALS)
29 (define (cenv-module env)
32 ((and (pair? env) (module? (car env))) (car env))
33 (else (error "bad environment" env))))
35 (define (cenv-lexicals env)
38 ((pair? env) (cadr env))
39 (else (error "bad environment" env))))
41 (define (cenv-externals env)
44 ((pair? env) (cddr env))
45 (else (error "bad environment" env))))
47 (define (make-cenv module lexicals externals)
48 (cons module (cons lexicals externals)))
52 (let ((props (source-properties x)))
53 (and (not (null? props))
56 (define (compile-tree-il x e opts)
57 (save-module-excursion
59 (and=> (cenv-module e) set-current-module)
60 (let* ((x (sc-expand x 'c '(compile load eval)))
61 (cenv (make-cenv (current-module)
62 (cenv-lexicals e) (cenv-externals e))))
63 (values x cenv cenv)))))