src/module-parse.lisp: Frob `_' to `-' in item names.
[sod] / doc / syntax.tex
... / ...
CommitLineData
1%%% -*-latex-*-
2%%%
3%%% Module syntax
4%%%
5%%% (c) 2015 Straylight/Edgeware
6%%%
7
8%%%----- Licensing notice ---------------------------------------------------
9%%%
10%%% This file is part of the Sensible Object Design, an object system for C.
11%%%
12%%% SOD is free software; you can redistribute it and/or modify
13%%% it under the terms of the GNU General Public License as published by
14%%% the Free Software Foundation; either version 2 of the License, or
15%%% (at your option) any later version.
16%%%
17%%% SOD is distributed in the hope that it will be useful,
18%%% but WITHOUT ANY WARRANTY; without even the implied warranty of
19%%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20%%% GNU General Public License for more details.
21%%%
22%%% You should have received a copy of the GNU General Public License
23%%% along with SOD; if not, write to the Free Software Foundation,
24%%% Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
25
26\chapter{Module syntax} \label{ch:syntax}
27
28%%%--------------------------------------------------------------------------
29\section{Notation} \label{sec:syntax.notation}
30
31Fortunately, Sod is syntactically quite simple. The notation is slightly
32unusual in order to make the presentation shorter and easier to read.
33
34Anywhere a simple nonterminal name $x$ may appear in the grammar, an
35\emph{indexed} nonterminal $x[a_1, \ldots, a_n]$ may also appear. On the
36left-hand side of a production rule, the indices $a_1$, \ldots, $a_n$ are
37variables which vary over all nonterminal and terminal symbols, and the
38variables may also appear on the right-hand side in place of a nonterminal.
39Such a rule stands for a family of rules, in each variable is replaced by
40each possible simple nonterminal or terminal symbol.
41
42The letter $\epsilon$ denotes the empty nonterminal
43\begin{quote}
44 \syntax{$\epsilon$ ::=}
45\end{quote}
46
47The following indexed productions are used throughout the grammar, some often
48enough that they deserve special notation.
49\begin{itemize}
50\item @[$x$@] abbreviates @<optional>$[x]$, denoting an optional occurrence
51 of $x$:
52 \begin{quote}
53 \syntax{@[$x$@] ::= <optional>$[x]$ ::= $\epsilon$ @! $x$}
54 \end{quote}
55\item $x^*$ abbreviates @<zero-or-more>$[x]$, denoting a sequence of zero or
56 more occurrences of $x$:
57 \begin{quote}
58 \syntax{$x^*$ ::= <zero-or-more>$[x]$ ::=
59 $\epsilon$ @! <zero-or-more>$[x]$ $x$}
60 \end{quote}
61\item $x^+$ abbreviates @<one-or-more>$[x]$, denoting a sequence of zero or
62 more occurrences of $x$:
63 \begin{quote}
64 \syntax{$x^+$ ::= <one-or-more>$[x]$ ::= <zero-or-more>$[x]$ $x$}
65 \end{quote}
66\item @<list>$[x]$ denotes a sequence of one or more occurrences of $x$
67 separated by commas:
68 \begin{quote}
69 \syntax{<list>$[x]$ ::= $x$ @! <list>$[x]$ "," $x$}
70 \end{quote}
71\end{itemize}
72
73%%%--------------------------------------------------------------------------
74\section{Lexical syntax} \label{sec:syntax.lex}
75
76Whitespace and comments are discarded. The remaining characters are
77collected into tokens according to the following syntax.
78
79\begin{grammar}
80<token> ::= <identifier>
81\alt <string-literal>
82\alt <char-literal>
83\alt <integer-literal>
84\alt <punctuation>
85\end{grammar}
86
87This syntax is slightly ambiguous, and is disambiguated by the \emph{maximal
88munch} rule: at each stage we take the longest sequence of characters which
89could be a token.
90
91
92\subsection{Identifiers} \label{sec:syntax.lex.id}
93
94\begin{grammar}
95<identifier> ::= <id-start-char> @<id-body-char>^*
96
97<id-start-char> ::= <alpha-char> | "_"
98
99<id-body-char> ::= <id-start-char> @! <digit-char>
100
101<alpha-char> ::= "A" | "B" | \dots\ | "Z"
102\alt "a" | "b" | \dots\ | "z"
103\alt <extended-alpha-char>
104
105<digit-char> ::= "0" | <nonzero-digit-char>
106
107<nonzero-digit-char> ::= "1" | "2" $| \cdots |$ "9"
108\end{grammar}
109
110The precise definition of @<alpha-char> is left to the function
111\textsf{alpha-char-p} in the hosting Lisp system. For portability,
112programmers are encouraged to limit themselves to the standard ASCII letters.
113
114There are no reserved words at the lexical level, but the higher-level syntax
115recognizes certain identifiers as \emph{keywords} in some contexts. There is
116also an ambiguity (inherited from C) in the declaration syntax which is
117settled by distinguishing type names from other identifiers at a lexical
118level.
119
120
121\subsection{String and character literals} \label{sec:syntax.lex.string}
122
123\begin{grammar}
124<string-literal> ::= "\"" @<string-literal-char>^* "\""
125
126<char-literal> ::= "'" <char-literal-char> "'"
127
128<string-literal-char> ::= any character other than "\\" or "\""
129\alt "\\" <char>
130
131<char-literal-char> ::= any character other than "\\" or "'"
132\alt "\\" <char>
133
134<char> ::= any single character
135\end{grammar}
136
137The syntax for string and character literals differs from~C. In particular,
138escape sequences such as @`\textbackslash n' are not recognized. The use
139of string and character literals in Sod, outside of C~fragments, is limited,
140and the simple syntax seems adequate. For the sake of future compatibility,
141the use of character sequences which resemble C escape sequences is
142discouraged.
143
144\subsubsection{Integer literals} \label{sec:syntax.lex.int}
145
146\begin{grammar}
147<integer-literal> ::= <decimal-integer>
148\alt <binary-integer>
149\alt <octal-integer>
150\alt <hex-integer>
151
152<decimal-integer> ::= "0" | <nonzero-digit-char> @<digit-char>^*
153
154<binary-integer> ::= "0" @("b"|"B"@) @<binary-digit-char>^+
155
156<binary-digit-char> ::= "0" | "1"
157
158<octal-integer> ::= "0" @["o"|"O"@] @<octal-digit-char>^+
159
160<octal-digit-char> ::= "0" | "1" $| \cdots |$ "7"
161
162<hex-integer> ::= "0" @("x"|"X"@) @<hex-digit-char>^+
163
164<hex-digit-char> ::= <digit-char>
165\alt "A" | "B" | "C" | "D" | "E" | "F"
166\alt "a" | "b" | "c" | "d" | "e" | "f"
167\end{grammar}
168
169Sod understands only integers, not floating-point numbers; its integer syntax
170goes slightly beyond C in allowing a @`0o' prefix for octal and @`0b' for
171binary. However, length and signedness indicators are not permitted.
172
173
174\subsection{Punctuation} \label{sec:syntax.lex.punct}
175
176\begin{grammar}
177<punctuation> ::= any nonalphanumeric character other than "_", "\"" or "'"
178\end{grammar}
179
180
181\subsection{Comments} \label{sec:syntax.lex.comment}
182
183\begin{grammar}
184<comment> ::= <block-comment>
185\alt <line-comment>
186
187<block-comment> ::=
188 "/*"
189 @<not-star>^* @(@<star>^+ <not-star-or-slash> @<not-star>^*@)^*
190 @<star>^*
191 "*/"
192
193<star> ::= "*"
194
195<not-star> ::= any character other than "*"
196
197<not-star-or-slash> ::= any character other than "*" or "/"
198
199<line-comment> ::= "//" @<not-newline>^* <newline>
200
201<newline> ::= a newline character
202
203<not-newline> ::= any character other than newline
204\end{grammar}
205
206Comments are exactly as in C99: both traditional block comments `\texttt{/*}
207\dots\ \texttt{*/}' and \Cplusplus-style `\texttt{//} \dots' comments are
208permitted and ignored.
209
210
211\subsection{Special nonterminals} \label{sec:syntax.lex.special}
212
213Aside from the lexical syntax presented above (\xref{sec:lexical-syntax}),
214two special nonterminals occur in the module syntax.
215
216\subsubsection{S-expressions}
217\begin{grammar}
218<s-expression> ::= an S-expression, as parsed by the Lisp reader
219\end{grammar}
220
221When an S-expression is expected, the Sod parser simply calls the host Lisp
222system's @|read| function. Sod modules are permitted to modify the read
223table to extend the S-expression syntax.
224
225S-expressions are self-delimiting, so no end-marker is needed.
226
227\subsubsection{C fragments}
228\begin{grammar}
229<c-fragment> ::= a sequence of C tokens, with matching brackets
230\end{grammar}
231
232Sequences of C code are simply stored and written to the output unchanged
233during translation. They are read using a simple scanner which nonetheless
234understands C comments and string and character literals.
235
236A C fragment is terminated by one of a small number of delimiter characters
237determined by the immediately surrounding context -- usually a closing brace
238or bracket. The first such delimiter character which is not enclosed in
239brackets, braces or parenthesis ends the fragment.
240
241%%%--------------------------------------------------------------------------
242\section{Module syntax} \label{sec:syntax.module}
243
244\begin{grammar}
245<module> ::= @<definition>^*
246
247<definition> ::= <import-definition>
248\alt <load-definition>
249\alt <lisp-definition>
250\alt <code-definition>
251\alt <typename-definition>
252\alt <class-definition>
253\end{grammar}
254
255A @<module> is the top-level syntactic item. A module consists of a sequence
256of definitions.
257
258\subsection{Simple definitions} \label{sec:syntax.module.simple}
259
260\subsubsection{Importing modules}
261\begin{grammar}
262<import-definition> ::= "import" <string> ";"
263\end{grammar}
264
265The module named @<string> is processed and its definitions made available.
266
267A search is made for a module source file as follows.
268\begin{itemize}
269\item The module name @<string> is converted into a filename by appending
270 @`.sod', if it has no extension already.\footnote{%
271 Technically, what happens is \textsf{(merge-pathnames name (make-pathname
272 :type "SOD" :case :common))}, so exactly what this means varies
273 according to the host system.} %
274\item The file is looked for relative to the directory containing the
275 importing module.
276\item If that fails, then the file is looked for in each directory on the
277 module search path in turn.
278\item If the file still isn't found, an error is reported and the import
279 fails.
280\end{itemize}
281At this point, if the file has previously been imported, nothing further
282happens.\footnote{%
283 This check is done using \textsf{truename}, so it should see through simple
284 tricks like symbolic links. However, it may be confused by fancy things
285 like bind mounts and so on.} %
286
287Recursive imports, either direct or indirect, are an error.
288
289\subsubsection{Loading extensions}
290\begin{grammar}
291<load-definition> ::= "load" <string> ";"
292\end{grammar}
293
294The Lisp file named @<string> is loaded and evaluated.
295
296A search is made for a Lisp source file as follows.
297\begin{itemize}
298\item The name @<string> is converted into a filename by appending @`.lisp',
299 if it has no extension already.\footnote{%
300 Technically, what happens is \textsf{(merge-pathnames name (make-pathname
301 :type "LISP" :case :common))}, so exactly what this means varies
302 according to the host system.} %
303\item A search is then made in the same manner as for module imports
304 (\xref{sec:syntax-module}).
305\end{itemize}
306If the file is found, it is loaded using the host Lisp's \textsf{load}
307function.
308
309Note that Sod doesn't attempt to compile Lisp files, or even to look for
310existing compiled files. The right way to package a substantial extension to
311the Sod translator is to provide the extension as a standard ASDF system (or
312similar) and leave a dropping @"foo-extension.lisp" in the module path saying
313something like
314\begin{quote}
315 \textsf{(asdf:load-system :foo-extension)}
316\end{quote}
317which will arrange for the extension to be compiled if necessary.
318
319(This approach means that the language doesn't need to depend on any
320particular system definition facility. It's bad enough already that it
321depends on Common Lisp.)
322
323\subsubsection{Lisp escapes}
324\begin{grammar}
325<lisp-definition> ::= "lisp" <s-expression> ";"
326\end{grammar}
327
328The @<s-expression> is evaluated immediately. It can do anything it likes.
329
330\begin{boxy}[Warning!]
331 This means that hostile Sod modules are a security hazard. Lisp code can
332 read and write files, start other programs, and make network connections.
333 Don't install Sod modules from sources that you don't trust.\footnote{%
334 Presumably you were going to run the corresponding code at some point, so
335 this isn't as unusually scary as it sounds. But please be careful.} %
336\end{boxy}
337
338\subsubsection{Declaring type names}
339\begin{grammar}
340<typename-definition> ::=
341 "typename" <list>$[\mbox{@<identifier>}]$ ";"
342\end{grammar}
343
344Each @<identifier> is declared as naming a C type. This is important because
345the C type syntax -- which Sod uses -- is ambiguous, and disambiguation is
346done by distinguishing type names from other identifiers.
347
348Don't declare class names using @"typename"; use @"class" forward
349declarations instead.
350
351
352\subsection{Literal code} \label{sec:syntax.module.literal}
353
354\begin{grammar}
355<code-definition> ::=
356 "code" <identifier> ":" <identifier> @[<constraints>@]
357 "{" <c-fragment> "}"
358
359<constraints> ::= "[" <list>$[\mbox{@<constraint>}]$ "]"
360
361<constraint> ::= @<identifier>^+
362\end{grammar}
363
364The @<c-fragment> will be output unchanged to one of the output files.
365
366The first @<identifier> is the symbolic name of an output file. Predefined
367output file names are @"c" and @"h", which are the implementation code and
368header file respectively; other output files can be defined by extensions.
369
370The second @<identifier> provides a name for the output item. Several C
371fragments can have the same name: they will be concatenated together in the
372order in which they were encountered.
373
374The @<constraints> provide a means for specifying where in the output file
375the output item should appear. (Note the two kinds of square brackets shown
376in the syntax: square brackets must appear around the constraints if they are
377present, but that they may be omitted.) Each comma-separated @<constraint>
378is a sequence of identifiers naming output items, and indicates that the
379output items must appear in the order given -- though the translator is free
380to insert additional items in between them. (The particular output items
381needn't be defined already -- indeed, they needn't be defined ever.)
382
383There is a predefined output item @"includes" in both the @"c" and @"h"
384output files which is a suitable place for inserting @"\#include"
385preprocessor directives in order to declare types and functions for use
386elsewhere in the generated output files.
387
388
389\subsection{Property sets} \label{sec:syntax.module.properties}
390\begin{grammar}
391<properties> ::= "[" <list>$[\mbox{@<property>}]$ "]"
392
393<property> ::= <identifier> "=" <expression>
394\end{grammar}
395
396Property sets are a means for associating miscellaneous information with
397classes and related items. By using property sets, additional information
398can be passed to extensions without the need to introduce idiosyncratic
399syntax.
400
401A property has a name, given as an @<identifier>, and a value computed by
402evaluating an @<expression>. The value can be one of a number of types,
403though the only operators currently defined act on integer values only.
404
405\subsubsection{The expression evaluator}
406\begin{grammar}
407<expression> ::= <term> | <expression> "+" <term> | <expression> "-" <term>
408
409<term> ::= <factor> | <term> "*" <factor> | <term> "/" <factor>
410
411<factor> ::= <primary> | "+" <factor> | "-" <factor>
412
413<primary> ::=
414 <integer-literal> | <string-literal> | <char-literal> | <identifier>
415\alt "?" <s-expression>
416\alt "(" <expression> ")"
417\end{grammar}
418
419The arithmetic expression syntax is simple and standard; there are currently
420no bitwise, logical, or comparison operators.
421
422A @<primary> expression may be a literal or an identifier. Note that
423identifiers stand for themselves: they \emph{do not} denote values. For more
424fancy expressions, the syntax
425\begin{quote}
426 @"?" @<s-expression>
427\end{quote}
428causes the @<s-expression> to be evaluated using the Lisp \textsf{eval}
429function.
430%%% FIXME crossref to extension docs
431
432
433\subsection{C types} \label{sec:syntax.module.types}
434
435Sod's syntax for C types closely mirrors the standard C syntax. A C type has
436two parts: a sequence of @<declaration-specifier>s and a @<declarator>. In
437Sod, a type must contain at least one @<declaration-specifier> (i.e.,
438`implicit @"int"' is forbidden), and storage-class specifiers are not
439recognized.
440
441\subsubsection{Declaration specifiers}
442\begin{grammar}
443<declaration-specifier> ::= <type-name>
444\alt "struct" <identifier> | "union" <identifier> | "enum" <identifier>
445\alt "void" | "char" | "int" | "float" | "double"
446\alt "short" | "long"
447\alt "signed" | "unsigned"
448\alt "bool" | "_Bool"
449\alt "imaginary" | "_Imaginary" | "complex" | "_Complex"
450\alt <qualifier>
451
452<qualifier> ::= "const" | "volatile" | "restrict"
453
454<type-name> ::= <identifier>
455\end{grammar}
456
457A @<type-name> is an identifier which has been declared as being a type name,
458using the @"typename" or @"class" definitions. The following type names are
459defined in the built-in module.
460\begin{itemize}
461\item @"va_list"
462\item @"size_t"
463\item @"ptrdiff_t"
464\item @"wchar_t"
465\end{itemize}
466
467Declaration specifiers may appear in any order. However, not all
468combinations are permitted. A declaration specifier must consist of zero or
469more @<qualifiers>, and one of the following, up to reordering.
470\begin{itemize}
471\item @<type-name>
472\item @"struct" @<identifier>, @"union" @<identifier>, @"enum" @<identifier>
473\item @"void"
474\item @"_Bool", @"bool"
475\item @"char", @"unsigned char", @"signed char"
476\item @"short", @"unsigned short", @"signed short"
477\item @"short int", @"unsigned short int", @"signed short int"
478\item @"int", @"unsigned int", @"signed int", @"unsigned", @"signed"
479\item @"long", @"unsigned long", @"signed long"
480\item @"long int", @"unsigned long int", @"signed long int"
481\item @"long long", @"unsigned long long", @"signed long long"
482\item @"long long int", @"unsigned long long int", @"signed long long int"
483\item @"float", @"double", @"long double"
484\item @"float _Imaginary", @"double _Imaginary", @"long double _Imaginary"
485\item @"float imaginary", @"double imaginary", @"long double imaginary"
486\item @"float _Complex", @"double _Complex", @"long double _Complex"
487\item @"float complex", @"double complex", @"long double complex"
488\end{itemize}
489All of these have their usual C meanings.
490
491\subsubsection{Declarators}
492\begin{grammar}
493<declarator>$[k]$ ::= @<pointer>^* <primary-declarator>$[k]$
494
495<primary-declarator>$[k]$ ::= $k$
496\alt "(" <primary-declarator>$[k]$ ")"
497\alt <primary-declarator>$[k]$ @<declarator-suffix>
498
499<pointer> ::= "*" @<qualifier>^*
500
501<declarator-suffix> ::= "[" <c-fragment> "]"
502\alt "(" <arguments> ")"
503
504<argument-list> ::= $\epsilon$ | "..."
505\alt <list>$[\mbox{@<argument>}]$ @["," "..."@]
506
507<argument> ::= @<declaration-specifier>^+ <argument-declarator>
508
509<argument-declarator> ::= <declarator>$[\mbox{@<identifier> @! $\epsilon$}]$
510
511<simple-declarator> ::= <declarator>$[\mbox{@<identifier>}]$
512
513<dotted-name> ::= <identifier> "." <identifier>
514\end{grammar}
515
516The declarator syntax is taken from C, but with some differences.
517\begin{itemize}
518\item Array dimensions are uninterpreted @<c-fragments>, terminated by a
519 closing square bracket. This allows array dimensions to contain arbitrary
520 constant expressions.
521\item A declarator may have either a single @<identifier> at its centre or a
522 pair of @<identifier>s separated by a @`.'; this is used to refer to
523 slots or messages defined in superclasses.
524\end{itemize}
525The remaining differences are (I hope) a matter of presentation rather than
526substance.
527
528
529\subsection{Class definitions} \label{sec:syntax.module.class}
530
531\begin{grammar}
532<class-definition> ::= <class-forward-declaration>
533\alt <full-class-definition>
534\end{grammar}
535
536\subsubsection{Forward declarations}
537\begin{grammar}
538<class-forward-declaration> ::= "class" <identifier> ";"
539\end{grammar}
540
541A @<class-forward-declaration> informs Sod that an @<identifier> will be used
542to name a class which is currently undefined. Forward declarations are
543necessary in order to resolve certain kinds of circularity. For example,
544\begin{listing}
545class Sub;
546
547class Super : SodObject {
548 Sub *sub;
549};
550
551class Sub : Super {
552 /* ... */
553};
554\end{listing}
555
556\subsubsection{Full class definitions}
557\begin{grammar}
558<full-class-definition> ::=
559 @[<properties>@]
560 "class" <identifier> ":" <list>$[\mbox{@<identifier>}]$
561 "{" @<properties-class-item>^* "}"
562
563<properties-class-item> ::= @[<properties>@] <class-item>
564
565<class-item> ::= <slot-item>
566\alt <initializer-item>
567\alt <message-item>
568\alt <method-item>
569\end{grammar}
570
571A full class definition provides a complete description of a class.
572
573The first @<identifier> gives the name of the class. It is an error to
574give the name of an existing class (other than a forward-referenced class),
575or an existing type name. It is conventional to give classes `MixedCase'
576names, to distinguish them from other kinds of identifiers.
577
578The @<list>$[\mbox{@<identifier>}]$ names the direct superclasses for the new
579class. It is an error if any of these @<identifier>s does not name a defined
580class.
581
582The @<properties> provide additional information. The standard class
583properties are as follows.
584\begin{description}
585\item[@"lisp_class"] The name of the Lisp class to use within the translator
586 to represent this class. The property value must be an identifier; the
587 default is @"sod_class". Extensions may define classes with additional
588 behaviour, and may recognize additional class properties.
589\item[@"metaclass"] The name of the Sod metaclass for this class. In the
590 generated code, a class is itself an instance of another class -- its
591 \emph{metaclass}. The metaclass defines which slots the class will have,
592 which messages it will respond to, and what its behaviour will be when it
593 receives them. The property value must be an identifier naming a defined
594 subclass of @"SodClass". The default metaclass is @"SodClass".
595 %%% FIXME xref to theory
596\item[@"nick"] A nickname for the class, to be used to distinguish it from
597 other classes in various limited contexts. The property value must be an
598 identifier; the default is constructed by forcing the class name to
599 lower-case.
600\end{description}
601
602The class body consists of a sequence of @<class-item>s enclosed in braces.
603These items are discussed on the following sections.
604
605\subsubsection{Slot items}
606\begin{grammar}
607<slot-item> ::=
608 @<declaration-specifier>^+ <list>$[\mbox{@<init-declarator>}]$ ";"
609
610<init-declarator> ::= <simple-declarator> @["=" <initializer>@]
611\end{grammar}
612
613A @<slot-item> defines one or more slots. All instances of the class and any
614subclass will contain these slot, with the names and types given by the
615@<declaration-specifiers> and the @<declarators>. Slot declarators may not
616contain dotted names.
617
618It is not possible to declare a slot with function type: such an item is
619interpreted as being a @<message-item> or @<method-item>. Pointers to
620functions are fine.
621
622An @<initializer>, if present, is treated as if a separate
623@<initializer-item> containing the slot name and initializer were present.
624For example,
625\begin{listing}
626[nick = eg]
627class Example : Super {
628 int foo = 17;
629};
630\end{listing}
631means the same as
632\begin{listing}
633[nick = eg]
634class Example : Super {
635 int foo;
636 eg.foo = 17;
637};
638\end{listing}
639
640\subsubsection{Initializer items}
641\begin{grammar}
642<initializer-item> ::= @["class"@] <list>$[\mbox{@<slot-initializer>}]$ ";"
643
644<slot-initializer> ::= <dotted-name> "=" <initializer>
645
646<initializer> :: "{" <c-fragment> "}" | <c-fragment>
647\end{grammar}
648
649An @<initializer-item> provides an initial value for one or more slots. If
650prefixed by @"class", then the initial values are for class slots (i.e.,
651slots of the class object itself); otherwise they are for instance slots.
652
653The first component of the @<dotted-name> must be the nickname of one of the
654class's superclasses (including itself); the second must be the name of a
655slot defined in that superclass.
656
657The initializer has one of two forms.
658\begin{itemize}
659\item A @<c-fragment> enclosed in braces denotes an aggregate initializer.
660 This is suitable for initializing structure, union or array slots.
661\item A @<c-fragment> \emph{not} beginning with an open brace is a `bare'
662 initializer, and continues until the next @`,' or @`;' which is not within
663 nested brackets. Bare initializers are suitable for initializing scalar
664 slots, such as pointers or integers, and strings.
665\end{itemize}
666
667\subsubsection{Message items}
668\begin{grammar}
669<message-item> ::=
670 @<declaration-specifier>^+
671 <keyword-declarator>$[\mbox{@<identifier>}]$
672 @[<method-body>@]
673\end{grammar}
674
675\subsubsection{Method items}
676\begin{grammar}
677<method-item> ::=
678 @<declaration-specifier>^+
679 <keyword-declarator>$[\mbox{@<dotted-name>}]$
680 <method-body>
681
682<method-body> ::= "{" <c-fragment> "}" | "extern" ";"
683\end{grammar}
684
685%%%----- That's all, folks --------------------------------------------------
686
687%%% Local variables:
688%%% mode: LaTeX
689%%% TeX-master: "sod.tex"
690%%% TeX-PDF-mode: t
691%%% End: