71 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Scheme
		
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Scheme
		
	
	
	
| ; Copyright (c) 1993, 1994 Richard Kelsey and Jonathan Rees.  See file COPYING.
 | |
| 
 | |
| 
 | |
| ; Deal with shadowed variables.
 | |
| 
 | |
| ; When a variable is shadowed by a variable, split the existing shared
 | |
| ; location into two replacement locations.
 | |
| 
 | |
| ; name (structure-ref p name) (define name ...) within a single template
 | |
| ; will lose big.
 | |
| 
 | |
| ;(define *replaced-locations* '()) ;alist of (old rep ((uid ...) . new))
 | |
| 
 | |
| (define (shadow-location! old p-uids new replacement)
 | |
|   (if (location-defined? old)
 | |
|       (set-contents! replacement (contents old)))
 | |
|   (set-location-id! old
 | |
| 		    (vector replacement p-uids new))
 | |
|   (set-location-defined?! old #f))  ;so that exceptions will be raised
 | |
| 
 | |
| (define maybe-replace-location
 | |
|   (let ((memv memv))
 | |
|     (lambda (loc p-uid)			;Package's unique id
 | |
|       (let ((foo (location-id loc)))
 | |
| 	(if (vector? foo)
 | |
| 	    (maybe-replace-location
 | |
| 	     (if (memv p-uid (vector-ref foo 1))
 | |
| 		 (vector-ref foo 2)
 | |
| 		 (vector-ref foo 0))
 | |
| 	     p-uid)
 | |
| 	    loc)))))
 | |
| 
 | |
| ; Exception handler:
 | |
| 
 | |
| (define (deal-with-replaced-variables succeed)
 | |
|   (lambda (opcode args)
 | |
|     (primitive-catch
 | |
|      (lambda (cont)
 | |
|        (let* ((loc (car args))
 | |
| 	      (tem (continuation-template cont))
 | |
| 	      (index (code-vector-ref (template-code tem)
 | |
| 				      (- (continuation-pc cont) 1))))
 | |
| 	 (if (eq? (template-ref tem index) loc)
 | |
| 	     (let* ((p-uid (do ((env (continuation-env cont)
 | |
| 				     (vector-ref env 0)))
 | |
| 			       ((not (vector? env)) env)))
 | |
| 		    (new (maybe-replace-location loc p-uid)))
 | |
| 	       (if (eq? new loc)
 | |
| 		   (signal-exception opcode args)
 | |
| 		   (begin (template-set! tem index new)
 | |
| 			  (signal 'note "Replaced location" loc new p-uid)
 | |
| 			  (if (location-defined? new)
 | |
| 			      (succeed new (cdr args))
 | |
| 			      (signal-exception opcode
 | |
| 						(cons new (cdr args)))))))
 | |
| 	     (error "lossage in deal-with-replaced-variables"
 | |
| 		    loc index)))))))
 | |
| 
 | |
| (let ((op/global (enum op global))
 | |
|       (op/set-global! (enum op set-global!)))
 | |
| 
 | |
|   (define-exception-handler op/global
 | |
|     (deal-with-replaced-variables
 | |
|        (lambda (loc more-args)
 | |
| 	 (contents loc))))
 | |
| 
 | |
|   (define-exception-handler op/set-global!
 | |
|     (deal-with-replaced-variables
 | |
|        (lambda (loc more-args)
 | |
| 	 (set-contents! loc (car more-args))))))
 |