Оди до главна содржина
Učilnica FRI 25/26
  • Дома
  • Календар
  • More
Македонски ‎(mk)‎
English ‎(en)‎ Slovenščina ‎(sl)‎ Македонски ‎(mk)‎ Русский ‎(ru)‎ 한국어 ‎(ko)‎
Моментално користите гостински пристап
Најави се
Učilnica FRI 25/26
Дома Календар
Прошири ги сите Затвори ги сите
  1. Контролна табла
  2. pns
  3. Основно
  4. 3. domača naloga

3. domača naloga

Услови за завршување
Opened: понеделник, 31 март 2025, 09:00
Due: понеделник, 7 април 2025, 09:00

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.

Моментално користите гостински пристап (Најави се)
Преземи мобилна апликација
Powered by Moodle
Obvestilo o avtorskih pravicah