# HG changeset patch # User Adam Chlipala # Date 1224623542 14400 # Node ID 948315ea84c30e7d7e24bd9fe6ecaa3a83a80faf # Parent e76a27d6854ff8a394dd539932ed16e296fd6790 Hello prose diff -r e76a27d6854f -r 948315ea84c3 demo/prose --- a/demo/prose Tue Oct 21 17:02:03 2008 -0400 +++ b/demo/prose Tue Oct 21 17:12:22 2008 -0400 @@ -26,7 +26,13 @@ hello.urp -

This one is my favorite.

+

We must, of course, begin with "Hello World."

+ +

The project file justs list one filename prefix, hello. This causes both hello.urs and hello.ur to be pulled into the project. .urs files are like OCaml .mli files, and .ur files are like OCaml .ml files. That is, .urs files provide interfaces, and .ur files provide implementations. .urs files may be omitted for .ur files, in which case most permissive interfaces are inferred.

+ +

Ur/Web features a module system very similar to those found in SML and OCaml. Like in OCaml, interface files are treated as module system signatures, and they are ascribed to structures built from interface files. hello.urs tells us that we only export a function named main, taking no arguments and running a transaction that results in an HTML page. transaction is a monad in the spirit of the Haskell IO monad, with the intent that every operation performable in transaction can be undone. By design, Ur/Web does not provide a less constrained way of running side-effecting actions. This particular example application will employ no side effects, but the compiler requires that all pages be generated by transactions.

+ +

Looking at hello.ur, we see an SML-looking function definition that returns a fragment of XML, written with special syntax. This fragment is returned to browsers that request the URI /Demo/Hello/main. That is, we take the demo-wide prefix /Demo and add a suffix that indicates we want to call the main function in the Hello module. This path convention generalizes to arbitrary levels of nested module definitions and functor applications (which we will see later).

link.urp