Metody realizacji języków programowania/MRJP Laboratorium/Scrap: Różnice pomiędzy wersjami
Linia 196: | Linia 196: | ||
<td>''<DeklaracjaTypu>'' </td> | <td>''<DeklaracjaTypu>'' </td> | ||
<td>::= </td> | <td>::= </td> | ||
<td><tt>'''type'''</tt> ''<Ident>'' <tt> | <td><tt>'''type'''</tt> ''<Ident>'' <tt><math>=</math></tt> ''<OpisTypu>'' </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 272: | Linia 272: | ||
<tr> | <tr> | ||
<td> | <td> | ||
ε | |||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
Linia 284: | Linia 284: | ||
<tr> | <tr> | ||
<td> | <td> | ||
ε | |||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
Linia 306: | Linia 306: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td>''<WyrazeniePostfiksowe>'' <tt>: | <td>''<WyrazeniePostfiksowe>'' <tt>:<math>=</math></tt> ''<Wyrazenie>'' <tt>;</tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 395: | Linia 395: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td><tt'''super'''</tt> </td> | <td><tt>'''super'''</tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 437: | Linia 437: | ||
<tr> | <tr> | ||
<td> | <td> | ||
ε | |||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
Linia 524: | Linia 524: | ||
<td>''<OperatorAddytywny>'' </td> | <td>''<OperatorAddytywny>'' </td> | ||
<td>::= </td> | <td>::= </td> | ||
<td><tt> | <td><tt><math>+</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 531: | Linia 531: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td><tt> | <td><tt><math>-</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 548: | Linia 548: | ||
<td>''<OperatorPorownania>'' </td> | <td>''<OperatorPorownania>'' </td> | ||
<td>::= </td> | <td>::= </td> | ||
<td><tt> | <td><tt><math><</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 555: | Linia 555: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td><tt> | <td><tt><math>></math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 562: | Linia 562: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td><tt> | <td><tt><math><=</math>}</tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 569: | Linia 569: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td> | <td><tt><math>>=</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 576: | Linia 576: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td> | <td><tt><math>==</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 583: | Linia 583: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td><tt>! | <td><tt>!<math>=</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 600: | Linia 600: | ||
<td>''<OperatorLogiczny>'' </td> | <td>''<OperatorLogiczny>'' </td> | ||
<td>::= </td> | <td>::= </td> | ||
<td> | <td><tt><math>||</math></tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 607: | Linia 607: | ||
</td> | </td> | ||
<td>| </td> | <td>| </td> | ||
<td> | <td><tt>&&</tt></td> | ||
</tr> | </tr> | ||
<tr> | <tr> | ||
Linia 652: | Linia 650: | ||
<td>''<DeklaracjaKlasy>'' </td> | <td>''<DeklaracjaKlasy>'' </td> | ||
<td>::= </td> | <td>::= </td> | ||
<td><tt>'''class'''</tt> ''<Ident>'' <tt>extends</tt> ''<Ident>'' <tt> | <td><tt>'''class'''</tt> ''<Ident>'' <tt>extends</tt> ''<Ident>'' <tt>{</tt> ''<ListDeklaracja>'' <tt>}</tt> </td> | ||
</tr> | </tr> | ||
<tr> | <tr> |
Wersja z 14:54, 25 sie 2006
The lexical structure of kotek
Identifiers
Identifiers Ident are unquoted strings beginning with a letter, followed by any combination of letters, digits, and the characters _ ', reserved words excluded.
Literals
String literals <String> have the form "", where is any sequence of any characters except " unless preceded by \.
Integer literals <Int> are nonempty sequences of digits.
Reserved words and symbols
The set of reserved words is the set of terminals appearing in the grammar. Those reserved words that consist of non-letter characters are called symbols, and they are treated in a different way from those that are similar to identifiers. The lexer follows rules familiar from languages like Haskell, C, and Java, including longest match and spacing conventions.
The reserved words used in kotek are the following:
array | class | delete |
do | done | else |
endif | extends | function |
if | int | new |
null | of | program |
read | return | string |
super | then | this |
type | var | void |
while | write |
The symbols used in kotek are the following:
; | { | } |
= | , | : |
( | ) | := |
[ | ] | . |
- | + | ! |
* | / | < |
> | <= | >= |
== | != | || |
&& |
Comments
Single-line comments begin with {\symb{//}}. \\Multiple-line comments are enclosed with {\symb{(*}} and {\symb{*)}}.
The syntactic structure of kotek
Non-terminals are enclosed between and . The symbols := (production), | (union) and ε (empty rule) belong to the BNF notation. All other symbols are terminals.
<Program> | ::= | program ; <Cialo> |
<Cialo> | ::= | <ListDeklaracja> <Blok> |
<Blok> | ::= | { <ListInstrukcja> } |
<ListDeklaracja> | ::= | |
| | <Deklaracja> <ListDeklaracja> | |
<Deklaracja> | ::= | <DeklaracjaTypu> |
| | <DeklaracjaZmiennej> | |
| | <DeklaracjaFunkcji> | |
| | <DeklaracjaKlasy> | |
<DeklaracjaTypu> | ::= | type <Ident> <OpisTypu> |
<OpisTypu> | ::= | <Ident> |
| | { <ListDeklaracjaZmiennej> } | |
| | array of <Typ> | |
<ListDeklaracjaZmiennej> | ::= | <DeklaracjaZmiennej> |
| | <DeklaracjaZmiennej> , <ListDeklaracjaZmiennej> | |
<Typ> | ::= | <Ident> |
| | string | |
| | int | |
| | void | |
<DeklaracjaZmiennej> | ::= | var <Ident> : <Typ> |
<DeklaracjaFunkcji> | ::= | function <Ident> ( <DeklaracjaArgumentow> ) : <Typ> <Cialo> |
<DeklaracjaArgumentow> | ::= | <ListDeklaracjaZmiennej> |
ε |
| | |
<ListInstrukcja> | ::= | |
ε |
| | <Instrukcja> <ListInstrukcja> |
<Instrukcja> | ::= | <Wyrazenie> ; |
| | <ZlozonaInstrukcja> ; | |
| | <WyrazeniePostfiksowe> : <Wyrazenie> ; | |
| | <Blok> | |
| | delete <Wyrazenie> ; | |
| | ; | |
| | read <Ident> ; | |
| | write <Wyrazenie> ; | |
| | return <Wyrazenie> ; | |
| | return ; | |
<WyrazeniePodstawowe> | ::= | <Ident> |
| | <String> | |
| | <Integer> | |
| | ( <Wyrazenie> ) | |
| | this | |
| | super | |
| | null | |
<WyrazeniePostfiksowe> | ::= | <WyrazeniePostfiksowe> [ <Wyrazenie> ] |
| | <WyrazeniePostfiksowe> ( <Parametry> ) | |
| | <WyrazeniePostfiksowe> . <Ident> | |
| | <WyrazeniePodstawowe> | |
<Parametry> | ::= | |
ε |
| | <ListWyrazenie> |
<ListWyrazenie> | ::= | <Wyrazenie> |
| | <Wyrazenie> , <ListWyrazenie> | |
<WyrazenieUnarne> | ::= | <OperatorUnarny> <WyrazenieUnarne> |
| | <WyrazeniePostfiksowe> | |
<OperatorUnarny> | ::= | {} |
| | {} | |
| | ! | |
<WyrazenieMultiplikatywne> | ::= | <WyrazenieMultiplikatywne> <OperatorMultiplikatywny> <WyrazenieUnarne> |
| | <WyrazenieUnarne> | |
<WyrazenieAddytywne> | ::= | <WyrazenieAddytywne> <OperatorAddytywny> <WyrazenieMultiplikatywne> |
| | <WyrazenieMultiplikatywne> | |
<OperatorMultiplikatywny> | ::= | * |
| | / | |
<OperatorAddytywny> | ::= | |
| | ||
<WyrazeniePorownania> | ::= | <WyrazenieAddytywne> <OperatorPorownania> <WyrazenieAddytywne> |
| | <WyrazenieAddytywne> | |
<OperatorPorownania> | ::= | |
| | ||
| | } | |
| | ||
| | ||
| | ! | |
<WyrazenieLogiczne> | ::= | <WyrazeniePorownania> <OperatorLogiczny> <WyrazeniePorownania> |
| | <WyrazeniePorownania> | |
<OperatorLogiczny> | ::= | |
| | && | |
<Wyrazenie> | ::= | <WyrazenieLogiczne> |
| | new <Typ> | |
| | new <Typ> [ <Wyrazenie> ] | |
<ZlozonaInstrukcja> | ::= | if <Wyrazenie> then <ListInstrukcja> else <ListInstrukcja> endif |
| | if <Wyrazenie> then <ListInstrukcja> endif | |
| | while <Wyrazenie> do <ListInstrukcja> done | |
<DeklaracjaKlasy> | ::= | class <Ident> extends <Ident> { <ListDeklaracja> } |