Attribuuttikielioppi

Attribuuttikielioppi määrittelee attribuutit formaalin kielen pääte- ja välikesymboleille sekä produktioille ominaiset laskusäännöt, joissa attribuuttien arvoja käytetään. Laskusääntöjä kutsutaan myös semanttisiksi toiminnoiksi. Laskusäännöillä ei saa olla sivuvaikutuksia. Kieliopista voidaan muodostaa abstrakti syntaksipuu ja attribuuttien laskusäännöt ovat puun solmukohdissa. Attribuutit voivat olla joko synteettisiä tai periytyneitä. Synteettiset attribuutit ovat aina attribuuttien laskusääntöjen tuloksista saatuja ja periytyneet ovat vanhemmilta solmukohdilta saatuja. [1]

Esimerkki muokkaa

Esimerkin Yhteydetön kielioppi kuvaa kielen, jolla voi kirjoittaa yksinkertaisia matemaattisia lauseita:

Kielioppi
ExprExpr + Term
ExprTerm
TermTerm * Factor
TermFactor
Factor → "(" Expr ")"
Factorinteger

Alla esitettyllä attribuuttikieliopilla pystyy laskemaan lukuarvoja kirjoitetuista lausekkeista. Kielioppi käyttää vain synteettisiä attribuutteja, joten se on S-attribuuttikielioppi.

Kielioppi Semanttiset toiminnot
Expr1Expr2 + Term [ Expr1.value = Expr2.value + Term.value ]
ExprTerm [ Expr.value = Term.value ]
Term1Term2 * Factor [ Term1.value = Term2.value * Factor.value ]
TermFactor [ Term.value = Factor.value ]
Factor → "(" Expr ")" [ Factor.value = Expr.value ]
Factorinteger [ Factor.value = stringToInteger(integer.string) ]

Lähteet muokkaa

  1. Aho, Sethi, Ullman: Compilers: Principles, Techniques and Tools. Addison-Wesley, 1987. englanti