| General InformationTutorialsReference ManualsLibrariesTranslation TasksTools
 
 
 
 Administration
     |   | LIDO - Reference Manual
           
 
The names described in this chapter have a predefined meaning
in LIDO specifications.
 
The following types are predefined in LIDO:
 
 
VOIDAttributes of this type describe a computational state without
propagating values between computations. Those attributes do not
occur as data objects in the generated evaluator.
intThe terminal type.
NODEPTRAttributes of this type represent computed subtrees.
 
The predefined value NULLNODEPTRof typeNODEPTRdenotes no tree. 
The CLASSsymbolROOTCLASSis predefined.
It is implicitly inherited by the root of the tree grammar
(see  Symbol Specifications). 
The following attribute is predefined in LIDO:
 
 
GENTREEEvery insertion point symbol has an attribute GENTREEof
typeNODEPTR. 
The following functional notations have a specific meaning in LIDO.
They are translated into suitable C constructs rather than into
function calls:
 
 
IF (a, b, c)denotes a conditional expression.
At runtime either borcis evaluated, ifayields a non-zero or a zero value. 
For determination of the static evaluation order
each ofa, b, ccontribute to the precondition of the
computation that contains theIFconstruct.
If it occurs in value contextbandcare in value context, too.
Thenbandchave to yield values of the same type
(not checked by LIGA). Otherwisebandcare
inVOIDcontext and may or may not yield a value of some type.
IF (a, b)is a conditional computation of
b, which is executed only ifayields a non-zero value.
For determination of the static evaluation order
bothaandbcontribute to the precondition of the
computation that contains theIFconstruct.
ThisIFconstruct must occur inVOIDcontext.bis in VOID context, too.
ORDER (a, b, ..., x)The arguments are evaluated in the specified order. 
If it occurs in VOIDcontext all arguments are inVOIDcontext. 
If it occurs in value context it yields the result of the 
last argumentx.
The others are inVOIDcontext and may or may not yield a value.
For determination of the static evaluation order
all arguments of theORDERconstruct contribute to the
precondition of the computation containing it.
Any nesting ofORDER,IF, function calls, 
and other expressions is
allowed, as long as the stated conditions forVOIDand value
contexts hold.
RuleFct (C_String, arguments ...)A call of this function is substituted by a call 
of a function whose name is composed of the C_Stringand
the name of the rule that has (or inherits) this call.
The remaining arguments are taken as arguments of the substituted
call. E.g. in a rule namedrBlocka callRuleFct ("PTG", a, b)is substituted byPTGrBlock (a, b).
RhsFct (C_String, arguments ...)A call of this function is substituted by a call
of a function whose name is composed of the C_Stringand
and two numbers that indicate how many nonterminals and terminals
are on the right-hand side of the rule that has (or inherits) this call.
The remaining arguments are taken as arguments of the substituted
call. E.g. in a ruleRULE: X ::= Id Y Id Z Id END;,
whereY, Zare nonterminals, andIdis a terminal,
a callRhsFct ("PTGChoice", a, b)is substituted byPTGChoice_2_3 (a, b).
Usually,RhsFctwill be used in symbol computations,
having arguments that are obtained by theRHSconstruct and
by aTermFctcall.
TermFct (C_String, arguments ...)A call of this function is substituted by a comma separated
sequence of calls 
of functions whose names are composed of the C_Stringand
the name of the non-literal terminals in the rule
that has (or inherits) this call.
The remaining arguments are taken as arguments of the substituted
calls. E.g. the following symbol computation
  SYMBOL X COMPUTE
    SYNT.Ptg = f (TermFct ("ToPtg", TERM));
  END;
  RULE: X ::= Y Number Z Ident ';' END;
yields the following rule computation
  RULE: X ::= Y Number Z Ident ';' COMPUTE
    X.Ptg = f (ToPtgNumber (Number), ToPtgIdent (Ident));
  END;
The order of the calls corresponds to the order of the terminals
in the rule. TheTermFctcall must occur on argument
position if there is more than one terminal in the rule. 
The following names can be used in computations to obtain
values that are specific for the context in the abstract tree
in which the computation occurs:
 
 
LINEthe source line number of the tree context.
COLthe source column number of the tree context.
COORDREFthe address of the source coordinates of the tree context,
to be used for example in calls of the message routine of 
the error module or in calls of tree construction functions.
RULENAMEa string literal for the rule name of the tree context,
to be used for example in symbol computations.
 
Note: These names are translated by LIGA into specific constructs of the
evaluator. Hence, they can not be used with this meaning in macros
that are expanded when the evaluator is translated.
(That was allowed in previous versions of LIGA.)
 
The following C macros are defined as described for the generated 
evaluator, and can be used in the LIDO text:
 
 
   APPLY (f, a, ... )  (*f) (a, ... )   a call of the function The last four macros are especially useful infwith the remaining arguments
   CAST(tp,ex)         ( (tp) (ex) )
   SELECT(str,fld)     ( (str).fld )
   PTRSELECT(str,fld)  ( (str)->fld )
   INDEX(arr,indx)     ( (arr)[indx] )
   ADD(lop,rop)        ( lop + rop )
   SUB(lop,rop)        ( lop - rop )
   MUL(lop,rop)        ( lop * rop )
   DIV(lop,rop)        ( lop / rop )
   MOD(lop,rop)        ( lop % rop )
   NEG(op)             ( -op )
   NOT(op)             ( !op )
   AND(lop,rop)        ( lop && rop )
   OR(lop,rop)         ( lop || rop )
   BITAND(lop,rop)     ( lop & rop )
   BITOR(lop,rop)      ( lop | rop )
   BITXOR(lop,rop)     ( lop ^ rop )
   GT(lop,rop)         ( lop > rop )
   LT(lop,rop)         ( lop < rop )
   EQ(lop,rop)         ( lop == rop )
   NE(lop,rop)         ( lop != rop )
   GE(lop,rop)         ( lop >= rop )
   LE(lop,rop)         ( lop <= rop )
   VOIDEN(a)           ((void)a)
   IDENTICAL(a)        (a)
   ZERO()              0  
   ONE()               1
   ARGTOONE(x)         1 WITHclauses ofCONSTITUENTSconstructs.
 
 
           
 |