Skip to main content
Testna Učilnica FRI 24/25
  • Home
  • More
Close
Toggle search input
English ‎(en)‎
English ‎(en)‎ Slovenščina ‎(sl)‎ Македонски ‎(mk)‎ Русский ‎(ru)‎ 한국어 ‎(ko)‎
You are currently using guest access
Log in
Testna Učilnica FRI 24/25
Home
Expand all Collapse all
  1. pns
  2. General
  3. 3. domača naloga

3. domača naloga

Completion requirements
Opened: Friday, 26 April 2024, 3:00 PM
Due: Monday, 6 May 2024, 7:00 AM

Sestavite generiranje abstraktnega sintaksnega drevesa.

Nalogo rešite z dopolnitvijo sintaksnega analizatorja. V posamezne metode sintaksnega analizatorja vstavite kodo za gradnjo abstraktnega sintaksnega drevesa, ob tem pa se seveda spremeni tip rezultata posamezne metode. Obenem izračunajte vrednost atributa, ki opisuje lokacijo kode, ki pripada posameznemu vozlišču abstraktnega sintaksnega drevesa.

Obenem morate spremeniti metodo parse v paketu SynAn.  Po novem je ta metoda sledeča:

public AST.Node parse(HashMap<AST.Node, Report.Locatable> attrLoc) {
    this.attrLoc = attrLoc;
    final AST.Nodes<AST.MainDef> defs = parseProgram();
    if (lexAn.peekToken().symbol() != Token.Symbol.EOF)
        Report.warning(lexAn.peekToken(),
            "Unexpected text '" + lexAn.peekToken().lexeme() + "...' at the end of the program.");
    return defs;
}

Dodate pa še lokalno spremenljivko attrLoc:

private HashMap<AST.Node, Report.Locatable> attrLoc;

Rešitev domače naloge oddajte na Učilnico kot datoteko xxxxxxxx-abstr.zip, pri čemer je xxxxxxxx vaše vpisna številka.  Ta datoteka mora imeti natančno enako strukturo direktorijev kot datoteka s predlogo domače naloge, datoteke in direktoriji morajo biti enako poimenovani.  Oddajte samo izvorno kodo.

You are currently using guest access (Log in)
Powered by Moodle
Obvestilo o avtorskih pravicah