scsh-0.6/scheme/prescheme/interface.scm

89 lines
1.9 KiB
Scheme
Raw Permalink Normal View History

1999-09-14 08:45:02 -04:00
; Copyright (c) 1993-1999 by Richard Kelsey and Jonathan Rees. See file COPYING.
(define-interface prescheme-interface
(export ((if begin lambda letrec quote set!
define define-syntax let-syntax
and cond case do let let* or
quasiquote
;syntax-rules
) :syntax) ; no delay
;; letrec-syntax -- not yet implemented
(goto :syntax)
(external :syntax)
((define-enumeration define-external-enumeration enum) :syntax)
((name->enumerand enumerand->name) :syntax) ; loadtime only
not
eq?
+ - * = < ; /
<= > >=
abs
expt
quotient remainder
; floor numerator denominator
; real-part imag-part
; exp log sin cos tan asin acos atan sqrt
; angle magnitude make-polar make-rectangular
min max
char=? char<?
;; Data manipulation
make-vector vector-length
vector-ref vector-set!
make-string string-length
string-ref string-set!
deallocate
null-pointer?
values call-with-values
current-input-port current-output-port current-error-port
open-input-file open-output-file
close-output-port close-input-port
read-char peek-char read-integer
write-char newline write-string write-integer
force-output
(errors :syntax)
error-string
ascii->char char->ascii
shift-left arithmetic-shift-right logical-shift-right
bitwise-and bitwise-ior bitwise-xor bitwise-not
unspecific
error
))
; memory (malloc and free)
(define-interface ps-memory-interface
(export allocate-memory
deallocate-memory
unsigned-byte-ref unsigned-byte-set!
word-ref word-set!
address?
null-address null-address?
address+ address- address-difference
address= address< address<= address> address>=
address->integer integer->address
copy-memory! memory-equal?
char-pointer->string char-pointer->nul-terminated-string
read-block write-block))
(define-interface ps-receive-interface
(export receive))