File: gcl_cmpbind.lsp

package info (click to toggle)
gcl27 2.7.1-13
  • links: PTS
  • area: main
  • in suites: sid
  • size: 30,888 kB
  • sloc: lisp: 211,946; ansic: 52,944; sh: 9,347; makefile: 647; tcl: 53; awk: 52
file content (88 lines) | stat: -rw-r--r-- 2,951 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
;;; CMPBIND  Variable Binding.
;;;
;; Copyright (C) 1994 M. Hagiya, W. Schelter, T. Yuasa
;; Copyright (C) 2024 Camm Maguire

;; This file is part of GNU Common Lisp, herein referred to as GCL
;;
;; GCL is free software; you can redistribute it and/or modify it under
;;  the terms of the GNU LIBRARY GENERAL PUBLIC LICENSE as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
;; 
;; GCL 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 Library General Public 
;; License for more details.
;; 
;; You should have received a copy of the GNU Library General Public License 
;; along with GCL; see the file COPYING.  If not, write to the Free Software
;; Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.


(in-package :compiler)

(si:putprop 'bds-bind 'set-bds-bind 'set-loc)

;;; Those functions that call the following binding functions should
;;; rebind the special variables,
;;; *vs*, *clink*, *ccb-vs*, and *unwind-exit*.

(defvar *new-env* nil)

(defun c2bind (var)
  (case (var-kind var)
        (LEXICAL
         (when (var-ref-ccb var)
	   (wt-nl)
	   (clink (var-ref var))
	   (setf (var-ref-ccb var) (ccb-vs-push))))
        (SPECIAL
	 (setq *bds-used* t)
         (wt-nl "bds_bind(" (vv-str (var-loc var)) ",") (wt-vs (var-ref var))
         (wt ");")
         (push 'bds-bind *unwind-exit*))
        (t
	 (wt-nl "V" (var-loc var) "=")
	 (wt (or (cdr (assoc (var-kind var) +to-c-var-alist+)) (baboon)))
	 (wt "(") (wt-vs (var-ref var)) (wt ");"))))

(defun c2bind-loc (var loc)
  (case (var-kind var)
        (LEXICAL
         (cond ((var-ref-ccb var)
                (wt-nl)
                (clink (var-ref var) loc)
                (setf (var-ref-ccb var) (ccb-vs-push)))
               (t
                (wt-nl) (wt-vs (var-ref var)) (wt "= " loc ";"))))
        (SPECIAL
	 (setq *bds-used* t)
         (wt-nl "bds_bind(" (vv-str (var-loc var)) "," loc ");")
         (push 'bds-bind *unwind-exit*))
        (t
	 (wt-nl "V" (var-loc var) "= ")
	 (let ((wtf (cdr (assoc (var-kind var) +wt-loc-alist+))))
	   (unless wtf (baboon))
	   (funcall wtf loc))
	 (wt ";"))))

(defun c2bind-init (var init)
  (case (var-kind var)
        (LEXICAL
         (cond ((var-ref-ccb var)
                (let* ((loc (list 'vs (var-ref var)))
		       (*value-to-go* loc))
		  (c2expr* init))
                (clink (var-ref var))
                (setf (var-ref-ccb var) (ccb-vs-push)))
               ((let ((*value-to-go* (list 'vs (var-ref var))))
                     (c2expr* init)))))
        (SPECIAL
         (let* ((loc `(cvar ,(cs-push t))) (*value-to-go* loc))
	   (c2expr* init)
	   (c2bind-loc var loc)))
	(t
	 (let ((*value-to-go* (list 'var var nil)))
	   (unless (assoc (var-kind var) +wt-loc-alist+) (baboon));FIXME???
	   (c2expr* init)))))