1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<!--Converted with LaTeX2HTML 98.1p1 release (March 2nd, 1998)
originally by Nikos Drakos (nikos@cbl.leeds.ac.uk), CBLU, University of Leeds
* revised and updated by: Marcus Hennecke, Ross Moore, Herb Swan
* with significant contributions from:
Jens Lippmann, Marek Rouchal, Martin Wilck and others -->
<HTML>
<HEAD>
<TITLE>Defining Terms</TITLE>
<META NAME="description" CONTENT="Defining Terms">
<META NAME="keywords" CONTENT="tpman">
<META NAME="resource-type" CONTENT="document">
<META NAME="distribution" CONTENT="global">
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<LINK REL="STYLESHEET" HREF="tpman.css">
<LINK REL="next" HREF="node8.html">
<LINK REL="previous" HREF="node6.html">
<LINK REL="up" HREF="node6.html">
<LINK REL="next" HREF="node8.html">
</HEAD>
<BODY >
<!--Navigation Panel-->
<A NAME="tex2html211"
HREF="node8.html">
<IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next"
SRC="/usr/share/latex2html/icons/next.png"></A>
<A NAME="tex2html207"
HREF="node6.html">
<IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up"
SRC="/usr/share/latex2html/icons/up.png"></A>
<A NAME="tex2html201"
HREF="node6.html">
<IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous"
SRC="/usr/share/latex2html/icons/prev.png"></A>
<A NAME="tex2html209"
HREF="node4.html">
<IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents"
SRC="/usr/share/latex2html/icons/contents.png"></A>
<A NAME="tex2html210"
HREF="node58.html">
<IMG WIDTH="43" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="index"
SRC="/usr/share/latex2html/icons/index.png"></A>
<BR>
<B> Next:</B> <A NAME="tex2html212"
HREF="node8.html">Attributes of Terms</A>
<B> Up:</B> <A NAME="tex2html208"
HREF="node6.html">Input</A>
<B> Previous:</B> <A NAME="tex2html202"
HREF="node6.html">Input</A>
<BR>
<BR>
<!--End of Navigation Panel-->
<H2><A NAME="SECTION00061000000000000000"> </A>
<A NAME="input-terms"> </A>
<BR>
Defining Terms
</H2>
<P>
The input structure of terms is borrowed from the Synthesizer's
Specification Language SSL.
<A NAME="112"> </A>
An example is the following.
<A NAME="113"> </A><A NAME="114"> </A>
<PRE><HR><!--lgrindfile: phylum_example.k 12:12 Jan 17 1997-->
expr: Plus(expr expr)
| Minus(expr expr)
| Neg(expr)
| Zero()
;
<BR>
exprlist: <B>list</B> expr;
<HR></PRE>
This declares two
<EM>phyla</EM><A NAME="117"> </A>,
or term types, or nonterminals, depending on your viewpoint.
Each of these denotes a set of terms.
As shown, there are two ways of constructing a phylum.
One is by enumerating its variants, each of which is an
<EM>operator</EM>
<A NAME="119"> </A>
applied to a list of phyla.
It is possible to declare nullary operators, but it is not possible to define
phyla that do not have operators.
The other way is declaring it as a
<I>list</I>
phylum.
<A NAME="121"> </A>
This is effectively equivalent to declaring the following right recursive
phylum:
<A NAME="122"> </A>
<PRE><HR><!--lgrindfile: list_phylum_example.k 19:44 Oct 21 1992-->
exprlist:Nilexprlist()
| Consexprlist(expr exprlist)
;
<HR></PRE>
<P>
A list phylum therefore always has an empty list constructor, and a prefix operator.
The advantage of a list declaration, apart from its brevity, is that it
instructs the system to generate additional, list-specific, functions.
<P>
There are a number of predefined phyla, among them are
<I>casestring</I>
<A NAME="1342"> </A>
and
<I>nocasestring</I>
<A NAME="1343"> </A>
for case-sensitive and case-insensitive character strings respectively.
The full list of predefined phyla is in Section <A HREF="node18.html#gen-predef">2.3</A>.
<P>
<P>
Phyla can be defined more than once, and at each occurrence operators, attributes,
and storage options (see below) can be added.
<P>
For each phylum, the term processor generates a C data type (a record)
with the same name.
This is discussed in more detail in Section <A HREF="node16.html#gen-types">2.1</A>.
<P>
<HR>
<!--Navigation Panel-->
<A NAME="tex2html211"
HREF="node8.html">
<IMG WIDTH="37" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="next"
SRC="/usr/share/latex2html/icons/next.png"></A>
<A NAME="tex2html207"
HREF="node6.html">
<IMG WIDTH="26" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="up"
SRC="/usr/share/latex2html/icons/up.png"></A>
<A NAME="tex2html201"
HREF="node6.html">
<IMG WIDTH="63" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="previous"
SRC="/usr/share/latex2html/icons/prev.png"></A>
<A NAME="tex2html209"
HREF="node4.html">
<IMG WIDTH="65" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="contents"
SRC="/usr/share/latex2html/icons/contents.png"></A>
<A NAME="tex2html210"
HREF="node58.html">
<IMG WIDTH="43" HEIGHT="24" ALIGN="BOTTOM" BORDER="0" ALT="index"
SRC="/usr/share/latex2html/icons/index.png"></A>
<BR>
<B> Next:</B> <A NAME="tex2html212"
HREF="node8.html">Attributes of Terms</A>
<B> Up:</B> <A NAME="tex2html208"
HREF="node6.html">Input</A>
<B> Previous:</B> <A NAME="tex2html202"
HREF="node6.html">Input</A>
<!--End of Navigation Panel-->
<ADDRESS>
<I></I>
<BR><I>2000-04-17</I>
</ADDRESS>
</BODY>
</HTML>
|