package com.tesora.dve.sql.expression; /* * #%L * Tesora Inc. * Database Virtualization Engine * %% * Copyright (C) 2011 - 2014 Tesora Inc. * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * #L% */ import java.util.List; import java.util.Set; import com.tesora.dve.sql.node.expression.Alias; import com.tesora.dve.sql.node.expression.ExpressionAlias; import com.tesora.dve.sql.node.expression.ExpressionNode; import com.tesora.dve.sql.node.expression.FunctionCall; import com.tesora.dve.sql.node.expression.NameInstance; import com.tesora.dve.sql.node.expression.TableInstance; import com.tesora.dve.sql.node.expression.VariableInstance; import com.tesora.dve.sql.parser.SourceLocation; import com.tesora.dve.sql.schema.LockInfo; import com.tesora.dve.sql.schema.Name; import com.tesora.dve.sql.schema.PEColumn; import com.tesora.dve.sql.schema.PETable; import com.tesora.dve.sql.schema.Schema; import com.tesora.dve.sql.schema.SchemaContext; import com.tesora.dve.sql.schema.SubqueryTable; import com.tesora.dve.sql.schema.Table; import com.tesora.dve.sql.schema.UnqualifiedName; import com.tesora.dve.sql.statement.dml.ProjectingStatement; import com.tesora.dve.sql.util.ListSet; public interface Scope { public ScopeParsePhase getPhase(); public void setPhase(ScopeParsePhase spp); public List<Scope> getNested(); public ListSet<ProjectingStatement> getNestedQueries(); public ListSet<VariableInstance> getVariables(); // this is used solely for show schema public TableInstance buildTableInstance(Name inTableName, UnqualifiedName alias, Schema<?> inSchema, SchemaContext sc, LockInfo info); public TableInstance buildTableInstance(Name inTableName, UnqualifiedName alias, SchemaContext sc, LockInfo info); public void pushVirtualTable(SubqueryTable sqt, UnqualifiedName alias, SchemaContext sc); public void insertTable(TableInstance ti); public ExpressionNode buildColumnInstance(SchemaContext sc, Name given); public TableInstance lookupTableInstance(SchemaContext sc, Name given, boolean required); public void resolveProjection(SchemaContext sc); // this also moves the phase to RESOLVING_CURRENT public void storeProjection(List<ExpressionNode> projection); public void insertColumn(UnqualifiedName alias, ExpressionAlias e); public ExpressionNode buildExpressionAlias(ExpressionNode e, Alias alias, SourceLocation sloc); public Set<String> getAllAliases(); public ListSet<TableKey> getLocalTables(); public ListSet<TableKey> getAllVisibleTables(); public ListSet<FunctionCall> getFunctions(); public void registerFunction(FunctionCall fc); public PEColumn registerColumn(PEColumn c); public void registerAlterColumns(SchemaContext sc, PETable tab); public PEColumn lookupInProcessColumn(Name n); public Table<?> getAlteredTable(); public ListSet<NameInstance> getUnresolvedChildren(); }