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

org.modelcc.parser.fence.Handle Maven / Gradle / Ivy

Go to download

ModelCC is a model-based parser generator (a.k.a. compiler compiler) that decouples language specification from language processing, avoiding some of the problems caused by grammar-driven parser generators. ModelCC receives a conceptual model as input, along with constraints that annotate it. It is then able to create a parser for the desired textual language and the generated parser fully automates the instantiation of the language conceptual model. ModelCC also includes a built-in reference resolution mechanism that results in abstract syntax graphs, rather than mere abstract syntax trees.

The newest version!
/*
 * ModelCC, distributed under ModelCC Shared Software License, www.modelcc.org
 */

package org.modelcc.parser.fence;

import java.io.Serializable;

import org.modelcc.language.syntax.Rule;
import org.modelcc.language.syntax.InputSymbol;

/**
 * Handle
 * 
 * @author Luis Quesada ([email protected])
 */
class Handle implements Serializable {

    /**
     * Rule.
     */
    protected Rule rule;

    /**
     * Number of matched elements/next element to match.
     */
    protected int matched;

    /**
     * Start index.
     */
    protected int start;

    /**
     * First matched symbol.
     */
    protected InputSymbol first;

    /**
     * Default constructor.
     * @param rule the rule
     * @param matched the number of matched elements
     * @param first the first matched symbol
     */
    Handle(Rule rule,int matched,int start,InputSymbol first) {
        this.rule = rule;
        this.matched = matched;
        this.start = start;
        this.first = first;
    }

    /**
     * @return the rule
     */
    Rule getRule() {
        return rule;
    }

    /**
     * @return the matched
     */
    int getMatched() {
        return matched;
    }

    /**
     * @return the first
     */
    int getStart() {
        return start;
    }

    /**
     * Equals method
     * @param obj Object to compare with
     * @return true if equals, false if not.
     */
    @Override
    public boolean equals(Object obj) {
        if (obj == null) {
            return false;
        }
        if (getClass() != obj.getClass()) {
            return false;
        }
        final Handle other = (Handle) obj;
        if (this.rule != other.rule && (this.rule == null || !this.rule.equals(other.rule))) {
            return false;
        }
        if (this.matched != other.matched) {
            return false;
        }
        if (this.start != other.start) {
            return false;
        }
        return true;
    }

    /**
     * Unique hashCode
     * @return a hashCode
     */
    @Override
    public int hashCode() {
        int hash = 5;
        hash = 83 * hash + (this.rule != null ? this.rule.hashCode() : 0);
        hash = 83 * hash + this.matched;
        hash = 83 * hash + this.start;
        return hash;
    }

    /**
     * @return the first symbol
     */
    public InputSymbol getFirst() {
        return first;
    }

    @Override
    public String toString() {
        return "Handle Rule "+rule+" matched "+matched+ " first at "+first.getStartIndex();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy