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

org.cloudgraph.recognizer.GraphRecognizerSyntaxTreeAssembler Maven / Gradle / Ivy

/**
 * Copyright 2017 TerraMeta Software, Inc.
 * 
 * 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.
 */
package org.cloudgraph.recognizer;

import org.cloudgraph.query.expr.DefaultBinaryExprTreeAssembler;
import org.cloudgraph.query.expr.ExprAssembler;
import org.cloudgraph.query.expr.RelationalBinaryExpr;
import org.cloudgraph.query.expr.PredicateBinaryExpr;
import org.cloudgraph.store.mapping.DataGraphMapping;
import org.plasma.query.model.Having;
import org.plasma.query.model.Literal;
import org.plasma.query.model.PredicateOperator;
import org.plasma.query.model.Property;
import org.plasma.query.model.RelationalOperator;
import org.plasma.query.model.Where;
import org.plasma.sdo.PlasmaType;

/**
 * A binary expression tree assembler which constructs an operator precedence
 * map, then {@link org.cloudgraph.query.expr.ExpresionVisitorSupport visits}
 * (traverses) the given predicate expression syntax tree depth-first using an
 * adapted shunting-yard algorithm and assembles a resulting binary tree
 * structure with expression nodes specific for detecting i.e. recognizing a
 * data graph. In typical usage scenarios, a single expression tree is assembled
 * once, and then used to evaluate any number of data graphs.
 * 

* The adapted shunting-yard algorithm in general uses a stack of operators and * operands, and as new binary tree nodes are detected and created they are * pushed onto the operand stack based on operator precedence. The resulting * binary expression tree reflects the syntax of the underlying query expression * including the precedence of its operators. *

* * @author Scott Cinnamond * @since 0.5.3 * * @see ExprAssembler * @see DefaultBinaryExprTreeAssembler */ public class GraphRecognizerSyntaxTreeAssembler extends DefaultBinaryExprTreeAssembler { protected DataGraphMapping graphConfig; /** * Constructs an assembler based on the given predicate data graph * configuration and graph root type. * * @param predicates * the predicates * @param rootType * the graph root type */ public GraphRecognizerSyntaxTreeAssembler(Where predicates, PlasmaType rootType) { super(predicates, rootType); } /** * Constructs an assembler based on the given predicate data graph * configuration and graph root type. * * @param predicates * the predicates * @param rootType * the graph root type */ public GraphRecognizerSyntaxTreeAssembler(Having predicates, PlasmaType rootType) { super(predicates, rootType); } @Override public RelationalBinaryExpr createRelationalBinaryExpr(Property property, Literal literal, RelationalOperator operator) { return new GraphRecognizerRelationalBinaryExpr(property, literal, operator); } @Override public PredicateBinaryExpr createPredicateBinaryExpr(Property property, Literal literal, PredicateOperator operator) { return new GraphRecognizerPredicateBinaryExpr(property, literal, operator); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy