File: dummy-interface.scm

package info (click to toggle)
scheme48 1.8%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 14,980 kB
  • ctags: 14,127
  • sloc: lisp: 76,272; ansic: 71,514; sh: 3,026; makefile: 637
file content (41 lines) | stat: -rw-r--r-- 943 bytes parent folder | download | duplicates (4)
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
; Copyright (c) 1993-2008 by Richard Kelsey and Jonathan Rees. See file COPYING.

; Interfaces are ignored.  Only dependencies are significant.

(define (make-indirect-interface name thunk)
  (thunk))

(define (make-simple-interface name items)
  (cons 'export items))

(define (make-compound-interface name . sigs)
  (cons 'compound-interface sigs))

; Types
(define :value ':value)
(define :syntax ':syntax)
(define :structure ':structure)
(define :procedure ':procedure)
(define :number ':number)
(define :type ':type)

(define-syntax proc
  (lambda (e r c) ''proc-lossage))

(define-syntax interface-of
  (lambda (e r c) ''interface-of-lossage))

(define (note-reference-to-interface! int thing)
  'int-lossage)

(define (interface-name int)
  'int-lossage)

(define (interface? int)
  (and (pair? int)
       (or (eq? 'export (car int))
	   (eq? 'compound-interface (car int)))))

(define (note-interface-name! int name)
  'int-lossage)