summaryrefslogtreecommitdiff
path: root/src/ast/nodes/ArglistNode.java
blob: a0ea25b55035ba74f04246329a6fff64590b42e5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package ast.nodes;

import ast.types.*;
import java.util.ArrayList;
import java.util.Arrays;
import semanticanalysis.SemanticError;
import semanticanalysis.SymbolTable;

/**
 * Node for the `arglist` statement of the grammar.
 */
public class ArglistNode implements Node {

    protected ArrayList<Node> arguments;

    public ArglistNode(ArrayList<Node> arguments) {
        this.arguments = arguments;
    }

    @Override
    public ArrayList<SemanticError> checkSemantics(SymbolTable ST, int _nesting) {
        ArrayList<SemanticError> errors = new ArrayList<>();

        for (var arg : arguments) {
            if (arg instanceof ExprNode) {
                ExprNode argExpr = (ExprNode) arg;
                String argName = argExpr.getId();

                // TODO: check fucking IntType for params
                // TODO: remove fucking comments
                if (argName != null) {
                    if (Arrays.asList(bif).contains(argName)) {
                        continue;
                    }

                    if (ST.lookup(argName) != null && ST.lookup(argName).getType() instanceof ImportType) {
                        continue;
                    }

                    if (ST.nslookup(argName) < 0 && argExpr.typeCheck() instanceof AtomType) {
                        errors.add(new SemanticError("name '" + argName + "' is not defined."));
                    }
                } else {
                    errors.addAll(arg.checkSemantics(ST, _nesting));
                }
            }
        }

        return errors;
    }

    public int getArgumentNumber() {
        return arguments.size();
    }

    @Override
    public Type typeCheck() {
        return new VoidType();
    }

    // TODO: add code generation for arglist node
    @Override
    public String codeGeneration() {
        return "";
    }

    @Override
    public String toPrint(String prefix) {
        String str = prefix + "ArglistNode\n";

        prefix += "  ";
        for (Node arg : arguments) {
            str += arg.toPrint(prefix);
        }

        return str;
    }

}