Mercurial > cpdt > repo
diff src/MoreDep.v @ 416:ded318830bb0
Manual font choice for notation scope delimiters
author | Adam Chlipala <adam@chlipala.net> |
---|---|
date | Wed, 13 Jun 2012 11:14:00 -0400 |
parents | f0f76356de9c |
children | 539ed97750bb |
line wrap: on
line diff
--- a/src/MoreDep.v Fri Jun 08 15:58:54 2012 -0400 +++ b/src/MoreDep.v Wed Jun 13 11:14:00 2012 -0400 @@ -215,7 +215,7 @@ | Prod t1 t2 => typeDenote t1 * typeDenote t2 end%type. -(** The [typeDenote] function compiles types of our object language into %``%#"#native#"#%''% Coq types. It is deceptively easy to implement. The only new thing we see is the [%][type] annotation, which tells Coq to parse the [match] expression using the notations associated with types. Without this annotation, the [*] would be interpreted as multiplication on naturals, rather than as the product type constructor. The token [type] is one example of an identifer bound to a _notation scope_. In this book, we will not go into more detail on notation scopes, but the Coq manual can be consulted for more information. +(** The [typeDenote] function compiles types of our object language into %``%#"#native#"#%''% Coq types. It is deceptively easy to implement. The only new thing we see is the [%]%\coqdocvar{%#<tt>#type#</tt>#%}% annotation, which tells Coq to parse the [match] expression using the notations associated with types. Without this annotation, the [*] would be interpreted as multiplication on naturals, rather than as the product type constructor. The token %\coqdocvar{%#<tt>#type#</tt>#%}% is one example of an identifer bound to a%\index{notation scope delimiter}% _notation scope delimiter_. In this book, we will not go into more detail on notation scopes, but the Coq manual can be consulted for more information. We can define a function [expDenote] that is typed in terms of [typeDenote]. *)