utils.scrbl: Add the documentation for types, eval-with, and eval1-with.

This commit is contained in:
Sergiu Ivanov 2020-12-04 02:25:19 +01:00
parent 7f032c045a
commit 6cee8a49d9

View file

@ -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}