;;; Guile VM program functions ;;; Copyright (C) 2001 Free Software Foundation, Inc. ;;; Copyright (C) 2005 Ludovic Courtès ;;; ;;; This program is free software; you can redistribute it and/or modify ;;; it under the terms of the GNU General Public License as published by ;;; the Free Software Foundation; either version 2 of the License, or ;;; (at your option) any later version. ;;; ;;; This program is distributed in the hope that it will be useful, ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;;; GNU General Public License for more details. ;;; ;;; You should have received a copy of the GNU General Public License ;;; along with this program; if not, write to the Free Software ;;; Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA ;;; Code: (define-module (system vm program) #:export (make-program arity:nargs arity:nrest arity:nlocs arity:nexts make-binding binding:name binding:extp binding:index binding:start binding:end source:addr source:line source:column source:file program-bindings program-sources program-properties program-property program-documentation program-name program-arity program-external-set! program-meta program-objcode program? program-objects program-module program-base program-external)) (dynamic-call "scm_init_programs" (dynamic-link "libguile")) (define arity:nargs car) (define arity:nrest cadr) (define arity:nlocs caddr) (define arity:nexts cadddr) (define (make-binding name extp index start end) (list name extp index start end)) (define (binding:name b) (list-ref b 0)) (define (binding:extp b) (list-ref b 1)) (define (binding:index b) (list-ref b 2)) (define (binding:start b) (list-ref b 3)) (define (binding:end b) (list-ref b 4)) (define (source:addr source) (car source)) (define (source:line source) (vector-ref (cdr source) 0)) (define (source:column source) (vector-ref (cdr source) 1)) (define (source:file source) (vector-ref (cdr source) 2)) (define (program-property prog prop) (assq-ref (program-properties proc) prop)) (define (program-documentation prog) (assq-ref (program-properties prog) 'documentation)) (define (program-bindings-as-lambda-list prog) (let ((bindings (program-bindings prog)) (nargs (arity:nargs (program-arity prog))) (rest? (not (zero? (arity:nrest (program-arity prog)))))) (if (not bindings) (if rest? (cons (1- nargs) 1) (list nargs)) (let ((args (map binding:name (list-head bindings nargs)))) (if rest? (apply cons* args) args))))) (define (write-program prog port) (format port "#" (or (program-name prog) (let ((s (program-sources prog))) (and (not (null? s)) (cdar s))) (number->string (object-address prog) 16)) (program-bindings-as-lambda-list prog)))