utils.rkt: Copy over extract-symbols.
This commit is contained in:
parent
66c76a6173
commit
9e65f07ce0
3 changed files with 38 additions and 3 deletions
|
@ -2,7 +2,7 @@
|
||||||
@(require scribble/example racket/sandbox
|
@(require scribble/example racket/sandbox
|
||||||
(for-label racket graph "../utils.rkt"
|
(for-label racket graph "../utils.rkt"
|
||||||
(only-in typed/racket/base
|
(only-in typed/racket/base
|
||||||
Any AnyValues)))
|
Any AnyValues Listof)))
|
||||||
|
|
||||||
@title[#:tag "utils"]{dds/utils: Various Utilities}
|
@title[#:tag "utils"]{dds/utils: Various Utilities}
|
||||||
|
|
||||||
|
@ -107,6 +107,17 @@ Note that only one expression can be supplied in the body.
|
||||||
|
|
||||||
@section{Analysis of quoted expressions}
|
@section{Analysis of quoted expressions}
|
||||||
|
|
||||||
|
@defproc[(extract-symbols [form Any]) (Listof Symbol)]{
|
||||||
|
|
||||||
|
Produces a list of symbols appearing in the quoted expression
|
||||||
|
passed in the first argument.
|
||||||
|
|
||||||
|
@examples[#:eval utils-evaluator
|
||||||
|
(extract-symbols '(1 (2 3) x (y z 3)))
|
||||||
|
]
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@section{Org-mode interoperability}
|
@section{Org-mode interoperability}
|
||||||
|
|
||||||
Org-mode supports laying out the output of code blocks as tables, which is very
|
Org-mode supports laying out the output of code blocks as tables, which is very
|
||||||
|
|
|
@ -10,8 +10,7 @@
|
||||||
|
|
||||||
(provide
|
(provide
|
||||||
;; Functions
|
;; Functions
|
||||||
(contract-out [extract-symbols (-> any/c list?)]
|
(contract-out [any->string (-> any/c string?)]
|
||||||
[any->string (-> any/c string?)]
|
|
||||||
[stringify-variable-mapping (-> variable-mapping? string-variable-mapping?)]
|
[stringify-variable-mapping (-> variable-mapping? string-variable-mapping?)]
|
||||||
[string->any (-> string? any/c)]
|
[string->any (-> string? any/c)]
|
||||||
[read-org-sexp (-> string? (listof any/c))]
|
[read-org-sexp (-> string? (listof any/c))]
|
||||||
|
|
25
utils.rkt
25
utils.rkt
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
(provide Symbol VariableMapping
|
(provide Symbol VariableMapping
|
||||||
eval-with eval1-with
|
eval-with eval1-with
|
||||||
|
extract-symbols
|
||||||
;; Syntax
|
;; Syntax
|
||||||
auto-hash-ref/explicit auto-hash-ref/:)
|
auto-hash-ref/explicit auto-hash-ref/:)
|
||||||
|
|
||||||
|
@ -99,3 +100,27 @@
|
||||||
(define ht2 #hash((a . 1) (b . 2)))
|
(define ht2 #hash((a . 1) (b . 2)))
|
||||||
(check-equal? (auto-hash-ref/: ht2 (+ :a (* 2 :b)))
|
(check-equal? (auto-hash-ref/: ht2 (+ :a (* 2 :b)))
|
||||||
5)))
|
5)))
|
||||||
|
|
||||||
|
;;; ==============================
|
||||||
|
;;; Analysis of quoted expressions
|
||||||
|
;;; ==============================
|
||||||
|
|
||||||
|
;;; Produces a list of symbols appearing in the quoted expression
|
||||||
|
;;; passed in the first argument.
|
||||||
|
(: extract-symbols (-> Any (Listof Symbol)))
|
||||||
|
(define (extract-symbols form)
|
||||||
|
(: extract-rec (-> Any (Listof Any)))
|
||||||
|
(define (extract-rec form)
|
||||||
|
(match form
|
||||||
|
[(? symbol?) (list form)]
|
||||||
|
[(? list?)
|
||||||
|
(flatten (for/list : (Listof Any)
|
||||||
|
([x form])
|
||||||
|
(extract-symbols x)))]
|
||||||
|
[else '()]))
|
||||||
|
(cast (extract-rec form) (Listof Symbol)))
|
||||||
|
|
||||||
|
(module+ test
|
||||||
|
(test-case "extract-symbols"
|
||||||
|
(check-equal? (extract-symbols '(1 (2 3) x (y z 3)))
|
||||||
|
'(x y z))))
|
||||||
|
|
Loading…
Reference in a new issue