
org.coode.owlapi.functionalparser.JJTOWLFunctionalSyntaxParserState Maven / Gradle / Ivy
/*
* This file is part of the OWL API.
*
* The contents of this file are subject to the LGPL License, Version 3.0.
*
* Copyright (C) 2011, The University of Manchester
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see http://www.gnu.org/licenses/.
*
*
* Alternatively, the contents of this file may be used under the terms of the Apache License, Version 2.0
* in which case, the provisions of the Apache License Version 2.0 are applicable instead of those above.
*
* Copyright 2011, The University of Manchester
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* Generated By:JavaCC: Do not edit this line. JJTOWLFunctionalSyntaxParserState.java Version 5.0 */
package org.coode.owlapi.functionalparser;
@SuppressWarnings({ "unused", "javadoc" })
public class JJTOWLFunctionalSyntaxParserState {
private java.util.List nodes;
private java.util.List marks;
private int sp; // number of nodes on stack
private int mk; // current mark
private boolean node_created;
public JJTOWLFunctionalSyntaxParserState() {
nodes = new java.util.ArrayList();
marks = new java.util.ArrayList();
sp = 0;
mk = 0;
}
/*
* Determines whether the current node was actually closed and pushed. This
* should only be called in the final user action of a node scope.
*/
public boolean nodeCreated() {
return node_created;
}
/*
* Call this to reinitialize the node stack. It is called automatically by
* the parser's ReInit() method.
*/
public void reset() {
nodes.clear();
marks.clear();
sp = 0;
mk = 0;
}
/*
* Returns the root node of the AST. It only makes sense to call this after
* a successful parse.
*/
public Node rootNode() {
return nodes.get(0);
}
/* Pushes a node on to the stack. */
public void pushNode(Node n) {
nodes.add(n);
++sp;
}
/*
* Returns the node on the top of the stack, and remove it from the stack.
*/
public Node popNode() {
if (--sp < mk) {
mk = marks.remove(marks.size() - 1);
}
return nodes.remove(nodes.size() - 1);
}
/* Returns the node currently on the top of the stack. */
public Node peekNode() {
return nodes.get(nodes.size() - 1);
}
/*
* Returns the number of children on the stack in the current node scope.
*/
public int nodeArity() {
return sp - mk;
}
public void clearNodeScope(Node n) {
while (sp > mk) {
popNode();
}
mk = marks.remove(marks.size() - 1);
}
public void openNodeScope(Node n) {
marks.add(mk);
mk = sp;
n.jjtOpen();
}
/*
* A definite node is constructed from a specified number of children. That
* number of nodes are popped from the stack and made the children of the
* definite node. Then the definite node is pushed on to the stack.
*/
public void closeNodeScope(Node n, int _num) {
int num = _num;
mk = marks.remove(marks.size() - 1);
while (num-- > 0) {
Node c = popNode();
c.jjtSetParent(n);
n.jjtAddChild(c, num);
}
n.jjtClose();
pushNode(n);
node_created = true;
}
/*
* A conditional node is constructed if its condition is true. All the nodes
* that have been pushed since the node was opened are made children of the
* conditional node, which is then pushed on to the stack. If the condition
* is false the node is not constructed and they are left on the stack.
*/
public void closeNodeScope(Node n, boolean condition) {
if (condition) {
int a = nodeArity();
mk = marks.remove(marks.size() - 1);
while (a-- > 0) {
Node c = popNode();
c.jjtSetParent(n);
n.jjtAddChild(c, a);
}
n.jjtClose();
pushNode(n);
node_created = true;
} else {
mk = marks.remove(marks.size() - 1);
node_created = false;
}
}
}
/*
* JavaCC - OriginalChecksum=f9fdb4aab44f4de0f4e5ba334d66ad6b (do not edit this
* line)
*/
© 2015 - 2025 Weber Informatics LLC | Privacy Policy