utils.scrbl: Add the documentation for types, eval-with, and eval1-with.
This commit is contained in:
parent
7f032c045a
commit
6cee8a49d9
1 changed files with 28 additions and 3 deletions
|
@ -1,6 +1,8 @@
|
||||||
#lang scribble/manual
|
#lang scribble/manual
|
||||||
@(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
|
||||||
|
Any AnyValues)))
|
||||||
|
|
||||||
@title[#:tag "utils"]{dds/utils: Various Utilities}
|
@title[#:tag "utils"]{dds/utils: Various Utilities}
|
||||||
|
|
||||||
|
@ -15,7 +17,21 @@ the package: evaluating sexps, manipulating lists,
|
||||||
(parameterize ([sandbox-output 'string]
|
(parameterize ([sandbox-output 'string]
|
||||||
[sandbox-error-output 'string]
|
[sandbox-error-output 'string]
|
||||||
[sandbox-memory-limit 50])
|
[sandbox-memory-limit 50])
|
||||||
(make-evaluator 'racket/base #:requires '("utils.rkt"))))
|
(make-evaluator 'typed/racket/base #:requires '("utils.rkt"))))
|
||||||
|
|
||||||
|
@section{Base Types}
|
||||||
|
@defidform[Variable]{
|
||||||
|
|
||||||
|
Any Racket symbol. Designates a variable in a discrete dynamical network.
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@defform[(VariableMapping A)]{
|
||||||
|
|
||||||
|
An immutable mapping (a hash table) assigning elements of type @racket[A] to
|
||||||
|
the variables.
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@section{Hashtable injection}
|
@section{Hashtable injection}
|
||||||
|
|
||||||
|
@ -23,7 +39,7 @@ This section defines some utilities to streamline the usage of hash tables
|
||||||
mapping symbols to values. The goal is essentially to avoid having to write
|
mapping symbols to values. The goal is essentially to avoid having to write
|
||||||
explicit @racket[hash-ref] calls.
|
explicit @racket[hash-ref] calls.
|
||||||
|
|
||||||
@defproc[(eval-with [ht variable-mapping?] [expr any/c]) any]{
|
@defproc[(eval-with [ht (VariableMapping Any)] [expr Any]) AnyValues]{
|
||||||
|
|
||||||
Temporarily injects the mappings from the given hash table as bindings in
|
Temporarily injects the mappings from the given hash table as bindings in
|
||||||
a namespace including @racket[racket/base] and then evaluates the expression.
|
a namespace including @racket[racket/base] and then evaluates the expression.
|
||||||
|
@ -44,6 +60,15 @@ missing identifier:
|
||||||
(eval-with ht '(+ b z a 1)))
|
(eval-with ht '(+ b z a 1)))
|
||||||
)]}
|
)]}
|
||||||
|
|
||||||
|
@defproc[(eval1-with [ht (VariableMapping Any)] [expr Any]) Any]{
|
||||||
|
|
||||||
|
Like @racket[eval-with], but returns only the first value computed by
|
||||||
|
@racket[expr].
|
||||||
|
|
||||||
|
@examples[#:eval utils-evaluator
|
||||||
|
(let ([ht (hash 'a 1 'b 1)])
|
||||||
|
(eval1-with ht '(+ b a 1)))
|
||||||
|
]}
|
||||||
@section{Analysis of quoted expressions}
|
@section{Analysis of quoted expressions}
|
||||||
|
|
||||||
@section{Org-mode interoperability}
|
@section{Org-mode interoperability}
|
||||||
|
|
Loading…
Add table
Reference in a new issue