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

org.antlr.stringtemplate.language.FormalArgument Maven / Gradle / Ivy

There is a newer version: 3.5.3
Show newest version
package org.antlr.stringtemplate.language;

import org.antlr.stringtemplate.StringTemplate;

import java.util.HashMap;
import java.util.Map;
import java.util.List;
import java.util.LinkedHashMap;

/** Represents the name of a formal argument
 *  defined in a template:
 *
 *  group test;
 *  test(a,b) : "$a$ $b$"
 *  t() : "blort"
 *
 *  Each template has a set of these formal arguments or uses
 *  a placeholder object: UNKNOWN (indicating that no arguments
 *  were specified such as when a template is loaded from a file.st).
 *
 *  Note: originally, I tracked cardinality as well as the name of an
 *  attribute.  I'm leaving the code here as I suspect something may come
 *  of it later.  Currently, though, cardinality is not used.
 */
public class FormalArgument {
    // the following represent bit positions emulating a cardinality bitset.
    public static final int OPTIONAL = 1;     // a?
    public static final int REQUIRED = 2;     // a
    public static final int ZERO_OR_MORE = 4; // a*
    public static final int ONE_OR_MORE = 8;  // a+

    public static final String[] suffixes = {
        null,
        "?",
        "",
        null,
        "*",
        null,
        null,
        null,
        "+"
    };

    /** When template arguments are not available such as when the user
     *  uses "new StringTemplate(...)", then the list of formal arguments
     *  must be distinguished from the case where a template can specify
     *  args and there just aren't any such as the t() template above.
     */
    public static final LinkedHashMap UNKNOWN = new LinkedHashMap();

    public String name;
    //protected int cardinality = REQUIRED;

	/** If they specified name="value", store the template here */
	public StringTemplate defaultValueST;

	public FormalArgument(String name) {
		this.name = name;
	}

	public FormalArgument(String name, StringTemplate defaultValueST) {
		this.name = name;
		this.defaultValueST = defaultValueST;
	}

    public static String getCardinalityName(int cardinality) {
        switch (cardinality) {
            case OPTIONAL : return "optional";
            case REQUIRED : return "exactly one";
            case ZERO_OR_MORE : return "zero-or-more";
            case ONE_OR_MORE : return "one-or-more";
            default : return "unknown";
        }
    }

	public boolean equals(Object o) {
		if ( o==null || !(o instanceof FormalArgument) ) {
			return false;
		}
		FormalArgument other = (FormalArgument)o;
		if ( !this.name.equals(other.name) ) {
			return false;
		}
		// only check if there is a default value; that's all
		if ( (this.defaultValueST!=null && other.defaultValueST==null) ||
			 (this.defaultValueST==null && other.defaultValueST!=null) ) {
			return false;
		}
		return true;
	}

    public String toString() {
		if ( defaultValueST!=null ) {
			return name+"="+defaultValueST;
		}
        return name;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy