utils.rkt: Add map-sexp.

This commit is contained in:
Sergiu Ivanov 2020-12-06 21:59:28 +01:00
parent e3efbb8f65
commit f80dc7f28e
3 changed files with 27 additions and 3 deletions

View file

@ -2,7 +2,8 @@
@(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 Listof String))) Any AnyValues Listof String Sexp Number
cast)))
@title[#:tag "utils"]{dds/utils: Various Utilities} @title[#:tag "utils"]{dds/utils: Various Utilities}
@ -155,6 +156,19 @@ Reads any value from string.
(string->any "(or b (not a))") (string->any "(or b (not a))")
]} ]}
@defproc[(map-sexp [func (-> Any Any)] [sexp Any]) Any]{
Given a @racket[Sexp], applies the @racket[func] to any object which is not
a list.
@racket[map-sexp] will not check whether @racket[func] is indeed applicable to
every non-list element of @racket[sexp]. If this is not the case, a contract
violation for func will be generated.
@examples[#:eval utils-evaluator
(map-sexp (λ (x) (add1 (cast x Number))) '(1 2 (4 10) 3))
]}
@section{Additional graph utilities} @section{Additional graph utilities}
@section{Pretty printing} @section{Pretty printing}

View file

@ -11,7 +11,6 @@
(provide (provide
;; Functions ;; Functions
(contract-out [read-org-sexp (-> string? (listof any/c))] (contract-out [read-org-sexp (-> string? (listof any/c))]
[map-sexp (-> procedure? any/c any/c)]
[unorg (-> string? (listof any/c))] [unorg (-> string? (listof any/c))]
[unstringify-pairs (-> (listof (general-pair/c string? any/c)) [unstringify-pairs (-> (listof (general-pair/c string? any/c))
(listof (general-pair/c symbol? any/c)))] (listof (general-pair/c symbol? any/c)))]

View file

@ -5,7 +5,7 @@
(provide Symbol VariableMapping (provide Symbol VariableMapping
eval-with eval1-with eval-with eval1-with
extract-symbols extract-symbols
any->string stringify-variable-mapping string->any any->string stringify-variable-mapping string->any map-sexp
;; Syntax ;; Syntax
auto-hash-ref/explicit auto-hash-ref/:) auto-hash-ref/explicit auto-hash-ref/:)
@ -174,3 +174,14 @@
[("#f") #f] [("#f") #f]
[((? list?)) (map handle-org-booleans datum)] [((? list?)) (map handle-org-booleans datum)]
[(_) datum]) [(_) datum])
(: map-sexp (-> (-> Any Any) Any Any))
(define (map-sexp func sexp)
(match sexp
[(? list?) (map ((curry map-sexp) func) sexp)]
[datum (func datum)]))
(module+ test
(test-case "map-sexp"
(check-equal? (map-sexp (λ (x) (add1 (cast x Number))) '(1 2 (4 10) 3))
'(2 3 (5 11) 4))))