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

prerna.rdf.util.AbstractQueryParser Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright 2015 Defense Health Agency (DHA)
 *
 * If your use of this software does not include any GPLv2 components:
 * 	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.
 * ----------------------------------------------------------------------------
 * If your use of this software includes any GPLv2 components:
 * 	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 2
 * 	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.
 *******************************************************************************/
package prerna.rdf.util;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.List;
import java.util.Set;

public abstract class AbstractQueryParser {

	protected boolean hasColumnAggregatorFunction = false;
	protected Set returnVariables = new HashSet();
	protected Hashtable> typePropVariables = new Hashtable>();
	protected Hashtable> typeReturnVariables = new Hashtable>();

	protected Hashtable  types = new Hashtable();
	protected Hashtable  props = new Hashtable();
	protected String query;
	protected List triplesData = new ArrayList();
	protected HashMap aliasTableMap = new HashMap();

	public AbstractQueryParser(){
		this.query = "";
	}
	
	public AbstractQueryParser(String query){
		this.query = query;
	}
	
	public abstract void parseQuery();
	public abstract List getTriplesData();
	
	public void setQuery(String query){
		this.query = query;
	}
	
	public Hashtable getNodesFromQuery(){
		return types;
	}
	
	public Hashtable> getPropertiesFromQuery(){
		return typePropVariables;
	}
	
	public Hashtable> getReturnVariables(){
		return typeReturnVariables;
	}
	
	protected void addToVariablesMap(Hashtable> mappingObj, String tableName, String columnAlias, String columnName){
		if(mappingObj.get(tableName)!=null){
			Hashtable returnVariablesForCurrentTable = mappingObj.get(tableName);
			returnVariablesForCurrentTable.put(columnAlias, columnName);
			mappingObj.put(tableName, returnVariablesForCurrentTable);
		} else {
			Hashtable returnVariablesForCurrentTable = new Hashtable();
			returnVariablesForCurrentTable.put(columnAlias, columnName);
			mappingObj.put(tableName, returnVariablesForCurrentTable);
		}
	}
	
	public boolean hasAggregateFunction(){
		return hasColumnAggregatorFunction;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy