All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nodes.functions.TypeDeclaration Maven / Gradle / Ivy

The newest version!
package nodes.functions;

import interfaces.IFunctionRenameable;
import interfaces.IVariableRenameable;
import nodes.AbstractFunction;
import tree.TreeContext;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

/**
 * Represents a Native Function. Looks like a function, but begins with "native" rather than "function"
 */
public final class TypeDeclaration extends AbstractFunction implements IFunctionRenameable, IVariableRenameable {

    private String name;
    private String flags;

    /**
     * Sets up this node with a scanner to receive words.
     *
     * @param inputScanner Scanner containing JASS code
     */
    public TypeDeclaration(Scanner inputScanner, TreeContext context) {
        super(inputScanner, context);
    }

    /**
     * No-args constructor used for creating from an existing
     *
     * @param context
     */
    public TypeDeclaration(TreeContext context, String name, String flags) {
        super(context);
        this.name = name;
        this.flags = flags;
    }

    /**
     * Parse the JASS code contained in the Scanner into a model object
     */
    @Override
    protected final void readNode() {
        String line = readLine();
        line = line.replace("\t", " ");
        while(line.contains("  ")) {
            line = line.replace("  ", " ");
        }
        if(line.startsWith("type ")) {
            line = line.substring("type ".length());
        }
        if(line.contains(" ")) {
            name = line.substring(0, line.indexOf(" "));
            line = line.substring(1+name.length());
            flags = line;
        } else {
            name = line;
        }
    }

    /**
     * Renames the variable and all uses of this variable.
     *
     * @param oldVariableName   Existing variable name
     * @param newVariableName   Desired variable name
     */
    @Override
    public final void renameVariable(String oldVariableName, String newVariableName) {
        // do nothing
    }

    /**
     * Renames a function and uses to a new name
     *
     * @param oldFunctionName   Existing function name
     * @param newFunctionName   Desired function name
     */
    @Override
    public final void renameFunction(String oldFunctionName, String newFunctionName) {
        this.name = rename(name, oldFunctionName, newFunctionName);
    }

    /**
     * Converts this node back to its original form.
     * Indentation is not added.
     *
     * @return Original form of this node (code or string)
     */
    @Override
    public final String toString() {
        StringBuilder builder = new StringBuilder();
        builder.append("type ").append(name);
        if(flags != null && !flags.isEmpty()) {
            builder.append(" ").append(flags);
        }
        return builder.toString();
    }

    /**
     * Converts this node back to its original form.
     *
     * @param indentationLevel Current indentation level
     * @return Original form of this node (code or string) with indentation
     */
    @Override
    public String toFormattedString(int indentationLevel) {
        return this.toString();
    }

    @Override
    public final String getName() {
        return name;
    }

    public final List getArguments() {
        List arguments = new ArrayList<>();
        return arguments;
    }

    @Override
    public int hashCode() {
        return this.toString().hashCode();
    }

    @Override
    public boolean equals(Object obj) {
        if (obj == null) { return false; }
        if (obj == this) { return true; }
        if (obj.getClass() != getClass()) {
            return false;
        }
        TypeDeclaration other = (TypeDeclaration) obj;
        return this.toString().equals(other.toString());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy