386 lines
12 KiB
Scheme
386 lines
12 KiB
Scheme
;;; Module definitions for the scsh regexp system.
|
|
;;; This is a sleazy modularisation -- we just load everything into
|
|
;;; scsh-level-0, and export from there.
|
|
;;; -Olin <shivers@ai.mit.edu> 8/98
|
|
|
|
;; From Scheme 48, only here temporarily
|
|
|
|
(define-structure external-util (export immutable-copy-string)
|
|
(open scheme
|
|
primitives ;copy-bytes!
|
|
features) ;immutable? make-immutable!
|
|
(begin
|
|
(define (immutable-copy-string string)
|
|
(if (immutable? string)
|
|
string
|
|
(let ((copy (copy-string string)))
|
|
(make-immutable! copy)
|
|
copy)))
|
|
|
|
; Why isn't this available elsewhere?
|
|
|
|
(define (copy-string string)
|
|
(let* ((length (string-length string))
|
|
(new (make-string length #\?)))
|
|
(copy-bytes! string 0 new 0 length)
|
|
new))))
|
|
|
|
(define-interface posix-regexps-interface
|
|
(export make-regexp
|
|
(regexp-option :syntax)
|
|
regexp?
|
|
regexp-match
|
|
|
|
match?
|
|
match-start
|
|
match-end
|
|
match-submatches
|
|
))
|
|
|
|
(define-structures ((posix-regexps posix-regexps-interface)
|
|
(posix-regexps-internal (export make-match)))
|
|
(open scheme define-record-types finite-types external-calls
|
|
signals
|
|
external-util)
|
|
(files regexp))
|
|
|
|
(define-interface basic-re-interface
|
|
(export (re-dsm? (proc (:value) :boolean))
|
|
(make-re-dsm (proc (:value :exact-integer :exact-integer) :value))
|
|
(re-dsm:body (proc (:value) :value))
|
|
(re-dsm:pre-dsm (proc (:value) :exact-integer))
|
|
(re-dsm:tsm (proc (:value) :exact-integer))
|
|
(re-dsm:posix (proc (:value) :value))
|
|
(set-re-dsm:posix (proc (:value :value) :unspecific))
|
|
((re-dsm:post-dsm re-dsm) (proc (:value) :exact-integer))
|
|
(open-dsm (proc (:value) (some-values :value :exact-integer)))
|
|
|
|
(re-seq? (proc (:value) :boolean))
|
|
(really-make-re-seq (proc (:value :exact-integer :value) :value))
|
|
(make-re-seq/tsm (proc (:value :exact-integer) :value))
|
|
((re-seq make-re-seq) (proc (:value) :value))
|
|
(re-seq:elts (proc (:value) :value))
|
|
(re-seq:tsm (proc (:value) :exact-integer))
|
|
(re-seq:posix (proc (:value) :value))
|
|
(set-re-seq:posix (proc (:value :value) :unspecific))
|
|
|
|
(re-choice? (proc (:value) :boolean))
|
|
(really-make-re-choice (proc (:value :exact-integer :value) :value))
|
|
(make-re-choice/tsm (proc (:value :exact-integer) :value))
|
|
((make-re-choice re-choice) (proc (:value) :value))
|
|
(re-choice:elts (proc (:value) :value))
|
|
(re-choice:tsm (proc (:value) :exact-integer))
|
|
(re-choice:posix (proc (:value) :value))
|
|
(set-re-choice:posix (proc (:value :value) :unspecific))
|
|
|
|
(re-repeat? (proc (:value) :boolean))
|
|
(really-make-re-repeat (proc (:exact-integer
|
|
:value :value
|
|
:exact-integer :value)
|
|
:value))
|
|
(make-re-repeat/tsm (proc (:exact-integer :value :value :exact-integer )
|
|
:value))
|
|
((re-repeat make-re-repeat)
|
|
(proc (:exact-integer :value :value) :value))
|
|
((re-repeat:from re-repeat:tsm)
|
|
(proc (:value) :exact-integer))
|
|
(re-repeat:to (proc (:value) :value))
|
|
((re-repeat:body re-repeat:posix)
|
|
(proc (:value) :value))
|
|
(set-re-repeat:posix (proc (:value :value) :unspecific))
|
|
|
|
(re-submatch? (proc (:value) :boolean))
|
|
(really-make-re-submatch (proc (:value :exact-integer :exact-integer :value)
|
|
:value))
|
|
(make-re-submatch/tsm (proc (:value :exact-integer :exact-integer) :value))
|
|
((make-re-submatch re-submatch)
|
|
(proc (:value &opt :exact-integer :exact-integer) :value))
|
|
|
|
(re-submatch:body (proc (:value) :value))
|
|
((re-submatch:pre-dsm re-submatch:tsm re-submatch:post-dsm)
|
|
(proc (:value) :exact-integer))
|
|
(re-submatch:posix (proc (:value) :value))
|
|
(set-re-submatch:posix (proc (:value :value) :unspecific))
|
|
|
|
(re-string? (proc (:value) :boolean))
|
|
((make-re-string re-string) (proc (:string) :value))
|
|
(re-string:chars (proc (:value) :string))
|
|
(set-re-string:chars (proc (:value :string) :unspecific))
|
|
(re-string:posix (proc (:value) :value))
|
|
(set-re-string:posix (proc (:value :value) :unspecific))
|
|
|
|
re-trivial
|
|
(re-trivial? (proc (:value) :boolean))
|
|
|
|
(re-char-set? (proc (:value) :boolean))
|
|
((make-re-char-set re-char-set) (proc (:value) :value))
|
|
(re-char-set:cset (proc (:value) :value))
|
|
(set-re-char-set:cset (proc (:value :value) :unspecific))
|
|
(re-char-set:posix (proc (:value) :value))
|
|
(set-re-char-set:posix (proc (:value :value) :unspecific))
|
|
|
|
re-empty
|
|
(re-empty? (proc (:value) :boolean))
|
|
re-bos re-eos
|
|
re-bol re-eol
|
|
|
|
((re-bos? re-eos? re-bol? re-eol? re-any?)
|
|
(proc (:value) :boolean))
|
|
|
|
re-any
|
|
re-nonl
|
|
|
|
(regexp? (proc (:value) :boolean))
|
|
(re-tsm (proc (:value) :exact-integer))
|
|
|
|
;; These guys can be in code produced by RX expander.
|
|
(flush-submatches (proc (:value) :value))
|
|
(uncase (proc (:value) :value))
|
|
(uncase-char-set (proc (:value) :value))
|
|
(uncase-string (proc (:string) :value))
|
|
))
|
|
|
|
|
|
;;; These guys were made obsolete by the new SRE package and exist for
|
|
;;; backwards compatibility only.
|
|
(define-interface re-old-funs-interface
|
|
(export
|
|
(string-match (proc (:value :string &opt :exact-integer) :value))
|
|
(make-regexp (proc (:string) :value))
|
|
(regexp-exec (proc (:value :string &opt :exact-integer) :value))
|
|
(->regexp (proc (:value) :value))
|
|
(regexp-quote (proc (:string) :value))))
|
|
|
|
|
|
(define-interface re-internals-interface
|
|
;; These are constructors for the Scheme unparser
|
|
(export
|
|
(make-re-string/posix (proc (:string :string :vector) :value))
|
|
((make-re-seq/posix make-re-choice/posix)
|
|
(proc (:value :exact-integer :string :vector) :value))
|
|
(make-re-char-set/posix (proc (:value :string :vector) :value))
|
|
(make-re-repeat/posix (proc (:exact-integer :value :value :exact-integer :string :vector)
|
|
:value))
|
|
(make-re-dsm/posix (proc (:value :exact-integer :exact-integer :string :vector)
|
|
:value))
|
|
(make-re-submatch/posix (proc (:value :exact-integer :exact-integer :string :vector) :value))))
|
|
|
|
|
|
(define re-match-internals-interface
|
|
(export (regexp-match:string (proc (:value) :string))
|
|
(regexp-match:submatches (proc (:value) :vector))))
|
|
|
|
|
|
(define-interface posix-re-interface
|
|
(export (regexp->posix-string (proc (:value) :string)) ; posixstr.scm
|
|
(posix-string->regexp (proc (:string) :value)) ; spencer
|
|
))
|
|
|
|
(define-interface re-subst-interface
|
|
(export
|
|
(regexp-substitute (proc (:value :value &rest :value) :value))
|
|
(regexp-substitute/global (proc (:value :value :string &rest :value) :value))))
|
|
|
|
(define-interface re-folders-interface
|
|
(export
|
|
(regexp-fold (proc (:value (proc (:exact-integer :value :value) :value)
|
|
:value
|
|
:string
|
|
&opt (proc (:exact-integer :value) :value)
|
|
:exact-integer)
|
|
:value))
|
|
(regexp-fold-right (proc (:value (proc (:value :exact-integer :value) :value)
|
|
:value
|
|
:string
|
|
&opt (proc (:exact-integer :value) :value)
|
|
:exact-integer)
|
|
:value))
|
|
(regexp-for-each (proc (:value (proc (:value) :unspecific)
|
|
:string &opt :exact-integer)
|
|
:unspecific))))
|
|
|
|
(define-interface re-level-0-interface
|
|
(compound-interface posix-re-interface
|
|
basic-re-interface
|
|
(export (regexp-match? (proc (:value) :boolean))
|
|
(match:start (proc (:value &opt :exact-integer) :value))
|
|
(match:end (proc (:value &opt :exact-integer) :value))
|
|
(match:substring (proc (:value &opt :exact-integer) :value))
|
|
(regexp-search (proc (:value :string &opt :exact-integer)
|
|
:value))
|
|
(regexp-search? (proc (:value :string &opt :exact-integer)
|
|
:boolean))
|
|
(sre->regexp (proc (:value) :value))
|
|
(regexp->sre (proc (:value) :value))
|
|
(simplify-regexp (proc (:value) :value))
|
|
)))
|
|
|
|
|
|
(define-structures ((re-level-0 re-level-0-interface)
|
|
(re-match-internals re-match-internals-interface)
|
|
(re-internals re-internals-interface)
|
|
(sre-syntax-tools (export (if-sre-form :syntax)
|
|
sre-form?
|
|
parse-sre parse-sres
|
|
regexp->scheme
|
|
static-regexp?))
|
|
(standard-char-sets (export nonl-chars word-chars))
|
|
(sre-internal-syntax-tools (export expand-rx)))
|
|
(open defrec-package
|
|
weak
|
|
;; re-posix-parsers ; regexp->posix-string
|
|
let-opt
|
|
sort ; Posix renderer
|
|
conditionals
|
|
define-record-types
|
|
defrec-package
|
|
receiving
|
|
scsh-utilities
|
|
(subset srfi-1 (fold every fold-right))
|
|
srfi-14
|
|
error-package
|
|
ascii
|
|
primitives ; JMG add-finalizer!
|
|
define-record-types ; JMG debugging
|
|
external-calls
|
|
srfi-13 ; string-fold
|
|
posix-regexps
|
|
scheme)
|
|
|
|
(files re-low re simp re-high
|
|
parse posixstr spencer re-syntax)
|
|
|
|
(begin (define-syntax if-sre-form
|
|
(lambda (exp r c)
|
|
(if (sre-form? (cadr exp) r c)
|
|
(caddr exp)
|
|
(cadddr exp)))))
|
|
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
|
|
;;; Stuff that could appear in code produced by (rx ...)
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(define-interface rx-lib-interface
|
|
(compound-interface (export coerce-dynamic-regexp
|
|
coerce-dynamic-charset
|
|
spec->char-set
|
|
flush-submatches
|
|
uncase
|
|
uncase-char-set
|
|
uncase-string)
|
|
re-internals-interface))
|
|
|
|
(define-structure rx-lib rx-lib-interface
|
|
(open re-internals
|
|
conditionals
|
|
re-level-0
|
|
(subset srfi-1 (fold))
|
|
srfi-14
|
|
error-package
|
|
ascii
|
|
scheme)
|
|
(files rx-lib)
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(define-interface rx-syntax-interface (export (rx :syntax)))
|
|
|
|
(define-structure rx-syntax rx-syntax-interface
|
|
(open re-level-0
|
|
srfi-14
|
|
rx-lib
|
|
standard-char-sets
|
|
scheme)
|
|
(for-syntax (open sre-internal-syntax-tools scheme))
|
|
(begin (define-syntax rx expand-rx))
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(define-interface re-match-syntax-interface
|
|
(export (let-match :syntax)
|
|
(if-match :syntax)
|
|
(match-cond :syntax)))
|
|
|
|
(define-structure re-match-syntax re-match-syntax-interface
|
|
(for-syntax (open scheme
|
|
signals)) ; For ERROR
|
|
(open re-level-0 scheme)
|
|
(access signals) ; for ERROR
|
|
(files re-match-syntax))
|
|
|
|
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
(define-structure re-old-funs re-old-funs-interface
|
|
(open re-level-0 error-package receiving scheme)
|
|
(files oldfuns)
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
|
|
|
|
(define-structure re-subst re-subst-interface
|
|
(open re-level-0
|
|
re-match-internals
|
|
posix-regexps
|
|
(subset srfi-1 (fold))
|
|
scsh-level-0 ; write-string
|
|
srfi-13 ; string-copy!
|
|
scheme)
|
|
(files re-subst)
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
|
|
(define-structure re-folders re-folders-interface
|
|
(open re-level-0 let-opt conditionals error-package scheme)
|
|
(files re-fold)
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
|
|
(define-interface re-exports-interface
|
|
(compound-interface re-level-0-interface
|
|
rx-syntax-interface
|
|
re-subst-interface
|
|
re-match-syntax-interface
|
|
re-folders-interface))
|
|
|
|
(define-structure re-exports re-exports-interface
|
|
(open rx-syntax
|
|
re-level-0
|
|
re-subst
|
|
re-match-syntax
|
|
re-folders)
|
|
; (optimize auto-integrate)
|
|
)
|
|
|
|
|
|
;;; File Exports
|
|
;;; ---- -------
|
|
;;; parse sre->regexp regexp->sre
|
|
;;; parse-sre parse-sres regexp->scheme
|
|
;;; char-set->in-pair static-regexp?
|
|
;;; posixstr regexp->posix-string
|
|
;;; re-high compile-regexp regexp-search regexp-search?
|
|
;;; re-subst regexp-substitute regexp-substitute/global
|
|
;;; re-low match:start match:end match:substring
|
|
;;; CRE record, new-cre
|
|
;;; cre-search cre-search?
|
|
;;; re-syntax sre-form? if-sre-form expand-rx
|
|
;;; re.scm The ADT. flush-submatches uncase uncase-char-set
|
|
;;; char-set-full? char-set-empty?
|
|
;;; re-char-class? static-char-class?
|
|
;;; rx-lib coerce-dynamic-regexp coerce-dynamic-charset spec->char-set
|
|
;;; simp simplify-regexp
|
|
;;; spencer posix-string->regexp
|