File: node7.html

package info (click to toggle)
kimwitu-doc 10a-3
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k, sarge
  • size: 1,192 kB
  • ctags: 341
  • sloc: makefile: 166; yacc: 125; ansic: 40; lex: 18; sh: 2
file content (163 lines) | stat: -rw-r--r-- 5,251 bytes parent folder | download | duplicates (2)
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">&#160;</A>
<A NAME="input-terms">&#160;</A>
<BR>
Defining Terms
</H2>

<P>
The input structure of terms is borrowed from the  Synthesizer's
Specification Language SSL.
<A NAME="112">&#160;</A>
An example is the following.
<A NAME="113">&#160;</A><A NAME="114">&#160;</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">&#160;</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">&#160;</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">&#160;</A>
This is effectively equivalent to declaring the following right recursive
phylum:
<A NAME="122">&#160;</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">&#160;</A>
and
<I>nocasestring</I>
<A NAME="1343">&#160;</A>
for case-sensitive and case-insensitive character strings respectively.
The full list of predefined phyla is in Section&nbsp;<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&nbsp;<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>