This teachpack provides facilities for the quick and easy generation of web interfaces for programs written in the HtDP (How to Design Programs) estudent languages of Racket.
Consider the following program, which builds an acronym from the capitalized words in a list of strings:
; acronym : listof string -> string (define (acronym a-los) (cond [(empty? a-los) ""] [(cons? a-los) (if (string-upper-case? (string-ith (first a-los) 0)) (string-append (string-ith (first a-los) 0) (acronym (rest a-los))) (acronym (rest a-los)))]))
A web application for this can be automatically generated by including the following at the top of the program:
|(require (planet nah22/racketui:1:2))|
and then putting the following code beneath the definition of acronym:
( "Acronym Builder" (function "Produces an acronym of the capitalized words in the given list of words." (acronym ["Words" (listof+ ["Word" string+])] ->["The acronym" string])))
Running this program should launch a web browser with a user interface that allows input of a list of words (strings) and controls to apply the function to that input and view the result.
RacketUI generates a user interface based on an annotated specification of the types of data that the underlying function consumes and produces. The types of data that RacketUI supports are given by the web specs below. These are intended to correspond to the types of data used in How to Design Programs.
For the purposes of generating a user-friendly interface, specifications are annotated with text informally describing their purpose or interpretation in the context of the program.
[label spec] (constant x)where x is any value boolean number symbol string string+for non-empty strings filenamefor functions that expect the name of an input file, or that produce the name of a generated output file (structure constr lab-spec ...+)where constr is a structure constructor and lab-spec are one or more labeled specs corresponding to the types expected for the fields of the structure (oneof lab-spec ...+)where lab-spec are one or more labeled specs corresponding to an itemization (union) of specifications (listof lab-spec)or, for non-empty lists, (listof+ lab-spec)where lab-spec is a labeled spec describing the type of elements in the list (function purpose (proc lab-spec ...+ -> lab-spec))
It is possible to define a name for specifications that occur repeatedly:
|( id spec)|
After this, id can be used in any context where a web spec is expected.
To start a web application, use the following form:
|( title web-spec)|