From b121d55d789c78eb1e77a0aa6580d1194ef71533 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Robert=20Claris=C3=B3?= Date: Wed, 26 Jul 2023 09:42:56 +0200 Subject: [PATCH] Update README.md - Added grammar --- README.md | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/README.md b/README.md index afd8e07..f471888 100644 --- a/README.md +++ b/README.md @@ -29,6 +29,28 @@ The **parser** reads OCL# specifications and produces a parse tree for syntactic ?- parse_ocls_expr( "1 = 2 + 3", X ). X = equals(int_const(1), plus(int_const(2), int_const(3))). +The following is a compact description of the grammar for OCL#: + + Spec ::= | Invariant Spec; + Invariant ::= 'context' IDENT 'inv' ':' Expression; + Type ::= 'bool' | 'int' | 'OclAny' | IDENT | CollectionType '(' Type ')'; + CollectionType ::= 'Set' | 'Bag' | 'Sequence' | 'OrderedSet'; + UnaryOperator ::= '-' | 'not'; + BinaryOperator ::= '=' | '+' | '-' | '*' | '/' | 'and' | 'or'; + Type ::= + TypeCast ::= 'asBag' | 'asSet' | 'asSequence' | 'asOrderedSet'; + Expression ::= self | true | false | INT_VALUE | IDENT | + 'no' '(' Type ')' | + IDENT '.' 'allInstances' '(' ')' | + Expression '.' IDENT | + Expression '->' 'including' '(' Expression ')' | + Expression '->' 'iterate' '(' IDENT ';' IDENT '=' Expression '|' Expression ')' | + Expression '->' TypeCast '(' ')' | + '(' Expression ')' | + UnaryOperator Expression | + Expression BinaryOperator Expresion | + 'if' Expression 'then' Expression 'else' Expression 'endif'; + The **type-checker** can be used to compute the type of an OCL# expression and check the type of subexpressions. For convenience, it can be used either on a parse tree or a string containing an OCL# expression (the expression is parsed and then type-checked). ?- type_check_ocls( equals(int_const(1), plus(int_const(2), int_const(3))), X ).