http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopConnection.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopConnection.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopConnection.java new file mode 100644 index 0000000..6870717 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopConnection.java @@ -0,0 +1,256 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.sql.Array; +import java.sql.Blob; +import java.sql.CallableStatement; +import java.sql.Clob; +import java.sql.Connection; +import java.sql.DatabaseMetaData; +import java.sql.NClob; +import java.sql.PreparedStatement; +import java.sql.SQLClientInfoException; +import java.sql.SQLException; +import java.sql.SQLWarning; +import java.sql.SQLXML; +import java.sql.Savepoint; +import java.sql.Statement; +import java.sql.Struct; +import java.util.Collections; +import java.util.Map; +import java.util.Properties; +import java.util.concurrent.Executor; + +/** + * A {@link Connection} implementation which does nothing. + */ +public class AvaticaNoopConnection implements Connection { + + private static final AvaticaNoopConnection INSTANCE = new AvaticaNoopConnection(); + + public static AvaticaNoopConnection getInstance() { + return INSTANCE; + } + + private AvaticaNoopConnection() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("Unsupported"); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + throw unsupported(); + } + + @Override public Statement createStatement() throws SQLException { + return AvaticaNoopStatement.getInstance(); + } + + @Override public PreparedStatement prepareStatement(String sql) throws SQLException { + return AvaticaNoopPreparedStatement.getInstance(); + } + + @Override public CallableStatement prepareCall(String sql) throws SQLException { + throw unsupported(); + } + + @Override public String nativeSQL(String sql) throws SQLException { + throw unsupported(); + } + + @Override public void setAutoCommit(boolean autoCommit) throws SQLException {} + + @Override public boolean getAutoCommit() throws SQLException { + return false; + } + + @Override public void commit() throws SQLException {} + + @Override public void rollback() throws SQLException {} + + @Override public void close() throws SQLException {} + + @Override public boolean isClosed() throws SQLException { + return true; + } + + @Override public DatabaseMetaData getMetaData() throws SQLException { + return AvaticaNoopDatabaseMetaData.getInstance(); + } + + @Override public void setReadOnly(boolean readOnly) throws SQLException {} + + @Override public boolean isReadOnly() throws SQLException { + return false; + } + + @Override public void setCatalog(String catalog) throws SQLException {} + + @Override public String getCatalog() throws SQLException { + return null; + } + + @Override public void setTransactionIsolation(int level) throws SQLException {} + + @Override public int getTransactionIsolation() throws SQLException { + return 0; + } + + @Override public SQLWarning getWarnings() throws SQLException { + return null; + } + + @Override public void clearWarnings() throws SQLException {} + + @Override public Statement createStatement(int resultSetType, int resultSetConcurrency) + throws SQLException { + return AvaticaNoopStatement.getInstance(); + } + + @Override public PreparedStatement prepareStatement(String sql, int resultSetType, + int resultSetConcurrency) throws SQLException { + return AvaticaNoopPreparedStatement.getInstance(); + } + + @Override public CallableStatement prepareCall(String sql, int resultSetType, + int resultSetConcurrency) throws SQLException { + throw unsupported(); + } + + @Override public Map<String, Class<?>> getTypeMap() throws SQLException { + return Collections.emptyMap(); + } + + @Override public void setTypeMap(Map<String, Class<?>> map) throws SQLException {} + + @Override public void setHoldability(int holdability) throws SQLException {} + + @Override public int getHoldability() throws SQLException { + throw unsupported(); + } + + @Override public Savepoint setSavepoint() throws SQLException { + throw unsupported(); + } + + @Override public Savepoint setSavepoint(String name) throws SQLException { + throw unsupported(); + } + + @Override public void rollback(Savepoint savepoint) throws SQLException { + throw unsupported(); + } + + @Override public void releaseSavepoint(Savepoint savepoint) throws SQLException { + throw unsupported(); + } + + @Override public Statement createStatement(int resultSetType, int resultSetConcurrency, + int resultSetHoldability) throws SQLException { + return AvaticaNoopStatement.getInstance(); + } + + @Override public PreparedStatement prepareStatement(String sql, int resultSetType, + int resultSetConcurrency, int resultSetHoldability) throws SQLException { + return AvaticaNoopPreparedStatement.getInstance(); + } + + @Override public CallableStatement prepareCall(String sql, int resultSetType, + int resultSetConcurrency, int resultSetHoldability) throws SQLException { + throw unsupported(); + } + + @Override public PreparedStatement prepareStatement(String sql, int autoGeneratedKeys) + throws SQLException { + return AvaticaNoopPreparedStatement.getInstance(); + } + + @Override public PreparedStatement prepareStatement(String sql, int[] columnIndexes) + throws SQLException { + return AvaticaNoopPreparedStatement.getInstance(); + } + + @Override public PreparedStatement prepareStatement(String sql, String[] columnNames) + throws SQLException { + return AvaticaNoopPreparedStatement.getInstance(); + } + + @Override public Clob createClob() throws SQLException { + throw unsupported(); + } + + @Override public Blob createBlob() throws SQLException { + throw unsupported(); + } + + @Override public NClob createNClob() throws SQLException { + throw unsupported(); + } + + @Override public SQLXML createSQLXML() throws SQLException { + throw unsupported(); + } + + @Override public boolean isValid(int timeout) throws SQLException { + return true; + } + + @Override public void setClientInfo(String name, String value) throws SQLClientInfoException {} + + @Override public void setClientInfo(Properties properties) throws SQLClientInfoException {} + + @Override public String getClientInfo(String name) throws SQLException { + throw unsupported(); + } + + @Override public Properties getClientInfo() throws SQLException { + throw unsupported(); + } + + @Override public Array createArrayOf(String typeName, Object[] elements) throws SQLException { + throw unsupported(); + } + + @Override public Struct createStruct(String typeName, Object[] attributes) throws SQLException { + throw unsupported(); + } + + @Override public void setSchema(String schema) throws SQLException {} + + @Override public String getSchema() throws SQLException { + return null; + } + + @Override public void abort(Executor executor) throws SQLException { + throw unsupported(); + } + + @Override public void setNetworkTimeout(Executor executor, int milliseconds) + throws SQLException {} + + @Override public int getNetworkTimeout() throws SQLException { + throw unsupported(); + } + +} + +// End AvaticaNoopConnection.java
http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDatabaseMetaData.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDatabaseMetaData.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDatabaseMetaData.java new file mode 100644 index 0000000..2b58590 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDatabaseMetaData.java @@ -0,0 +1,770 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.sql.Connection; +import java.sql.DatabaseMetaData; +import java.sql.ResultSet; +import java.sql.RowIdLifetime; +import java.sql.SQLException; + +/** + * A {@link DatabaseMetaData} implementation which does nothing. + */ +public class AvaticaNoopDatabaseMetaData implements DatabaseMetaData { + + private static final AvaticaNoopDatabaseMetaData INSTANCE = new AvaticaNoopDatabaseMetaData(); + + public static AvaticaNoopDatabaseMetaData getInstance() { + return INSTANCE; + } + + private AvaticaNoopDatabaseMetaData() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("Unsupported"); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + return false; + } + + @Override public boolean allProceduresAreCallable() throws SQLException { + return false; + } + + @Override public boolean allTablesAreSelectable() throws SQLException { + return false; + } + + @Override public String getURL() throws SQLException { + throw unsupported(); + } + + @Override public String getUserName() throws SQLException { + throw unsupported(); + } + + @Override public boolean isReadOnly() throws SQLException { + return false; + } + + @Override public boolean nullsAreSortedHigh() throws SQLException { + return false; + } + + @Override public boolean nullsAreSortedLow() throws SQLException { + return false; + } + + @Override public boolean nullsAreSortedAtStart() throws SQLException { + return false; + } + + @Override public boolean nullsAreSortedAtEnd() throws SQLException { + return false; + } + + @Override public String getDatabaseProductName() throws SQLException { + throw unsupported(); + } + + @Override public String getDatabaseProductVersion() throws SQLException { + throw unsupported(); + } + + @Override public String getDriverName() throws SQLException { + throw unsupported(); + } + + @Override public String getDriverVersion() throws SQLException { + throw unsupported(); + } + + @Override public int getDriverMajorVersion() { + return 0; + } + + @Override public int getDriverMinorVersion() { + return 0; + } + + @Override public boolean usesLocalFiles() throws SQLException { + return false; + } + + @Override public boolean usesLocalFilePerTable() throws SQLException { + return false; + } + + @Override public boolean supportsMixedCaseIdentifiers() throws SQLException { + return false; + } + + @Override public boolean storesUpperCaseIdentifiers() throws SQLException { + return false; + } + + @Override public boolean storesLowerCaseIdentifiers() throws SQLException { + return false; + } + + @Override public boolean storesMixedCaseIdentifiers() throws SQLException { + return false; + } + + @Override public boolean supportsMixedCaseQuotedIdentifiers() throws SQLException { + return false; + } + + @Override public boolean storesUpperCaseQuotedIdentifiers() throws SQLException { + return false; + } + + @Override public boolean storesLowerCaseQuotedIdentifiers() throws SQLException { + return false; + } + + @Override public boolean storesMixedCaseQuotedIdentifiers() throws SQLException { + return false; + } + + @Override public String getIdentifierQuoteString() throws SQLException { + throw unsupported(); + } + + @Override public String getSQLKeywords() throws SQLException { + throw unsupported(); + } + + @Override public String getNumericFunctions() throws SQLException { + throw unsupported(); + } + + @Override public String getStringFunctions() throws SQLException { + throw unsupported(); + } + + @Override public String getSystemFunctions() throws SQLException { + throw unsupported(); + } + + @Override public String getTimeDateFunctions() throws SQLException { + throw unsupported(); + } + + @Override public String getSearchStringEscape() throws SQLException { + throw unsupported(); + } + + @Override public String getExtraNameCharacters() throws SQLException { + throw unsupported(); + } + + @Override public boolean supportsAlterTableWithAddColumn() throws SQLException { + return false; + } + + @Override public boolean supportsAlterTableWithDropColumn() throws SQLException { + return false; + } + + @Override public boolean supportsColumnAliasing() throws SQLException { + return false; + } + + @Override public boolean nullPlusNonNullIsNull() throws SQLException { + return false; + } + + @Override public boolean supportsConvert() throws SQLException { + return false; + } + + @Override public boolean supportsConvert(int fromType, int toType) throws SQLException { + return false; + } + + @Override public boolean supportsTableCorrelationNames() throws SQLException { + return false; + } + + @Override public boolean supportsDifferentTableCorrelationNames() throws SQLException { + return false; + } + + @Override public boolean supportsExpressionsInOrderBy() throws SQLException { + return false; + } + + @Override public boolean supportsOrderByUnrelated() throws SQLException { + return false; + } + + @Override public boolean supportsGroupBy() throws SQLException { + return false; + } + + @Override public boolean supportsGroupByUnrelated() throws SQLException { + return false; + } + + @Override public boolean supportsGroupByBeyondSelect() throws SQLException { + return false; + } + + @Override public boolean supportsLikeEscapeClause() throws SQLException { + return false; + } + + @Override public boolean supportsMultipleResultSets() throws SQLException { + return false; + } + + @Override public boolean supportsMultipleTransactions() throws SQLException { + return false; + } + + @Override public boolean supportsNonNullableColumns() throws SQLException { + return false; + } + + @Override public boolean supportsMinimumSQLGrammar() throws SQLException { + return false; + } + + @Override public boolean supportsCoreSQLGrammar() throws SQLException { + return false; + } + + @Override public boolean supportsExtendedSQLGrammar() throws SQLException { + return false; + } + + @Override public boolean supportsANSI92EntryLevelSQL() throws SQLException { + return false; + } + + @Override public boolean supportsANSI92IntermediateSQL() throws SQLException { + return false; + } + + @Override public boolean supportsANSI92FullSQL() throws SQLException { + return false; + } + + @Override public boolean supportsIntegrityEnhancementFacility() throws SQLException { + return false; + } + + @Override public boolean supportsOuterJoins() throws SQLException { + return false; + } + + @Override public boolean supportsFullOuterJoins() throws SQLException { + return false; + } + + @Override public boolean supportsLimitedOuterJoins() throws SQLException { + return false; + } + + @Override public String getSchemaTerm() throws SQLException { + throw unsupported(); + } + + @Override public String getProcedureTerm() throws SQLException { + throw unsupported(); + } + + @Override public String getCatalogTerm() throws SQLException { + throw unsupported(); + } + + @Override public boolean isCatalogAtStart() throws SQLException { + return false; + } + + @Override public String getCatalogSeparator() throws SQLException { + throw unsupported(); + } + + @Override public boolean supportsSchemasInDataManipulation() throws SQLException { + return false; + } + + @Override public boolean supportsSchemasInProcedureCalls() throws SQLException { + return false; + } + + @Override public boolean supportsSchemasInTableDefinitions() throws SQLException { + return false; + } + + @Override public boolean supportsSchemasInIndexDefinitions() throws SQLException { + return false; + } + + @Override public boolean supportsSchemasInPrivilegeDefinitions() throws SQLException { + return false; + } + + @Override public boolean supportsCatalogsInDataManipulation() throws SQLException { + return false; + } + + @Override public boolean supportsCatalogsInProcedureCalls() throws SQLException { + return false; + } + + @Override public boolean supportsCatalogsInTableDefinitions() throws SQLException { + return false; + } + + @Override public boolean supportsCatalogsInIndexDefinitions() throws SQLException { + return false; + } + + @Override public boolean supportsCatalogsInPrivilegeDefinitions() throws SQLException { + return false; + } + + @Override public boolean supportsPositionedDelete() throws SQLException { + return false; + } + + @Override public boolean supportsPositionedUpdate() throws SQLException { + return false; + } + + @Override public boolean supportsSelectForUpdate() throws SQLException { + return false; + } + + @Override public boolean supportsStoredProcedures() throws SQLException { + return false; + } + + @Override public boolean supportsSubqueriesInComparisons() throws SQLException { + return false; + } + + @Override public boolean supportsSubqueriesInExists() throws SQLException { + return false; + } + + @Override public boolean supportsSubqueriesInIns() throws SQLException { + return false; + } + + @Override public boolean supportsSubqueriesInQuantifieds() throws SQLException { + return false; + } + + @Override public boolean supportsCorrelatedSubqueries() throws SQLException { + return false; + } + + @Override public boolean supportsUnion() throws SQLException { + return false; + } + + @Override public boolean supportsUnionAll() throws SQLException { + return false; + } + + @Override public boolean supportsOpenCursorsAcrossCommit() throws SQLException { + return false; + } + + @Override public boolean supportsOpenCursorsAcrossRollback() throws SQLException { + return false; + } + + @Override public boolean supportsOpenStatementsAcrossCommit() throws SQLException { + return false; + } + + @Override public boolean supportsOpenStatementsAcrossRollback() throws SQLException { + return false; + } + + @Override public int getMaxBinaryLiteralLength() throws SQLException { + return 0; + } + + @Override public int getMaxCharLiteralLength() throws SQLException { + return 0; + } + + @Override public int getMaxColumnNameLength() throws SQLException { + return 0; + } + + @Override public int getMaxColumnsInGroupBy() throws SQLException { + return 0; + } + + @Override public int getMaxColumnsInIndex() throws SQLException { + return 0; + } + + @Override public int getMaxColumnsInOrderBy() throws SQLException { + return 0; + } + + @Override public int getMaxColumnsInSelect() throws SQLException { + return 0; + } + + @Override public int getMaxColumnsInTable() throws SQLException { + return 0; + } + + @Override public int getMaxConnections() throws SQLException { + return 0; + } + + @Override public int getMaxCursorNameLength() throws SQLException { + return 0; + } + + @Override public int getMaxIndexLength() throws SQLException { + return 0; + } + + @Override public int getMaxSchemaNameLength() throws SQLException { + return 0; + } + + @Override public int getMaxProcedureNameLength() throws SQLException { + return 0; + } + + @Override public int getMaxCatalogNameLength() throws SQLException { + return 0; + } + + @Override public int getMaxRowSize() throws SQLException { + return 0; + } + + @Override public boolean doesMaxRowSizeIncludeBlobs() throws SQLException { + return false; + } + + @Override public int getMaxStatementLength() throws SQLException { + return 0; + } + + @Override public int getMaxStatements() throws SQLException { + return 0; + } + + @Override public int getMaxTableNameLength() throws SQLException { + return 0; + } + + @Override public int getMaxTablesInSelect() throws SQLException { + return 0; + } + + @Override public int getMaxUserNameLength() throws SQLException { + return 0; + } + + @Override public int getDefaultTransactionIsolation() throws SQLException { + return 0; + } + + @Override public boolean supportsTransactions() throws SQLException { + return false; + } + + @Override public boolean supportsTransactionIsolationLevel(int level) throws SQLException { + return false; + } + + @Override public boolean supportsDataDefinitionAndDataManipulationTransactions() + throws SQLException { + return false; + } + + @Override public boolean supportsDataManipulationTransactionsOnly() throws SQLException { + return false; + } + + @Override public boolean dataDefinitionCausesTransactionCommit() throws SQLException { + return false; + } + + @Override public boolean dataDefinitionIgnoredInTransactions() throws SQLException { + return false; + } + + @Override public ResultSet getProcedures(String catalog, String schemaPattern, + String procedureNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getProcedureColumns(String catalog, String schemaPattern, + String procedureNamePattern, String columnNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getTables(String catalog, String schemaPattern, + String tableNamePattern, String[] types) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getSchemas() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getCatalogs() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getTableTypes() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getColumns(String catalog, String schemaPattern, + String tableNamePattern, String columnNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getColumnPrivileges(String catalog, String schema, String table, + String columnNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getTablePrivileges(String catalog, String schemaPattern, + String tableNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getBestRowIdentifier(String catalog, String schema, String table, + int scope, boolean nullable) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getVersionColumns(String catalog, String schema, String table) + throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getPrimaryKeys(String catalog, String schema, String table) + throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getImportedKeys(String catalog, String schema, String table) + throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getExportedKeys(String catalog, String schema, String table) + throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getCrossReference(String parentCatalog, String parentSchema, + String parentTable, String foreignCatalog, String foreignSchema, + String foreignTable) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getTypeInfo() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getIndexInfo(String catalog, String schema, String table, + boolean unique, boolean approximate) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public boolean supportsResultSetType(int type) throws SQLException { + return false; + } + + @Override public boolean supportsResultSetConcurrency(int type, int concurrency) + throws SQLException { + return false; + } + + @Override public boolean ownUpdatesAreVisible(int type) throws SQLException { + return false; + } + + @Override public boolean ownDeletesAreVisible(int type) throws SQLException { + return false; + } + + @Override public boolean ownInsertsAreVisible(int type) throws SQLException { + return false; + } + + @Override public boolean othersUpdatesAreVisible(int type) throws SQLException { + return false; + } + + @Override public boolean othersDeletesAreVisible(int type) throws SQLException { + return false; + } + + @Override public boolean othersInsertsAreVisible(int type) throws SQLException { + return false; + } + + @Override public boolean updatesAreDetected(int type) throws SQLException { + return false; + } + + @Override public boolean deletesAreDetected(int type) throws SQLException { + return false; + } + + @Override public boolean insertsAreDetected(int type) throws SQLException { + return false; + } + + @Override public boolean supportsBatchUpdates() throws SQLException { + return false; + } + + @Override public ResultSet getUDTs(String catalog, String schemaPattern, String typeNamePattern, + int[] types) throws SQLException { + throw unsupported(); + } + + @Override public Connection getConnection() throws SQLException { + throw unsupported(); + } + + @Override public boolean supportsSavepoints() throws SQLException { + return false; + } + + @Override public boolean supportsNamedParameters() throws SQLException { + return false; + } + + @Override public boolean supportsMultipleOpenResults() throws SQLException { + return false; + } + + @Override public boolean supportsGetGeneratedKeys() throws SQLException { + return false; + } + + @Override public ResultSet getSuperTypes(String catalog, String schemaPattern, + String typeNamePattern) throws SQLException { + throw unsupported(); + } + + @Override public ResultSet getSuperTables(String catalog, String schemaPattern, + String tableNamePattern) throws SQLException { + throw unsupported(); + } + + @Override public ResultSet getAttributes(String catalog, String schemaPattern, + String typeNamePattern, String attributeNamePattern) throws SQLException { + throw unsupported(); + } + + @Override public boolean supportsResultSetHoldability(int holdability) throws SQLException { + return false; + } + + @Override public int getResultSetHoldability() throws SQLException { + return 0; + } + + @Override public int getDatabaseMajorVersion() throws SQLException { + return 0; + } + + @Override public int getDatabaseMinorVersion() throws SQLException { + return 0; + } + + @Override public int getJDBCMajorVersion() throws SQLException { + return 0; + } + + @Override public int getJDBCMinorVersion() throws SQLException { + return 0; + } + + @Override public int getSQLStateType() throws SQLException { + return 0; + } + + @Override public boolean locatorsUpdateCopy() throws SQLException { + return false; + } + + @Override public boolean supportsStatementPooling() throws SQLException { + return false; + } + + @Override public RowIdLifetime getRowIdLifetime() throws SQLException { + throw unsupported(); + } + + @Override public ResultSet getSchemas(String catalog, String schemaPattern) throws SQLException { + throw unsupported(); + } + + @Override public boolean supportsStoredFunctionsUsingCallSyntax() throws SQLException { + return false; + } + + @Override public boolean autoCommitFailureClosesAllResultSets() throws SQLException { + return false; + } + + @Override public ResultSet getClientInfoProperties() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getFunctions(String catalog, String schemaPattern, + String functionNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getFunctionColumns(String catalog, String schemaPattern, + String functionNamePattern, String columnNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public ResultSet getPseudoColumns(String catalog, String schemaPattern, + String tableNamePattern, String columnNamePattern) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public boolean generatedKeyAlwaysReturned() throws SQLException { + return false; + } +} + +// End AvaticaNoopDatabaseMetaData.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDriver.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDriver.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDriver.java new file mode 100644 index 0000000..76f5356 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopDriver.java @@ -0,0 +1,74 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.sql.Connection; +import java.sql.Driver; +import java.sql.DriverManager; +import java.sql.DriverPropertyInfo; +import java.sql.SQLException; +import java.sql.SQLFeatureNotSupportedException; +import java.util.Properties; +import java.util.logging.Logger; + +/** + * A Noop JDBC Driver. + */ +public class AvaticaNoopDriver implements Driver { + + private static final AvaticaNoopDriver INSTANCE = new AvaticaNoopDriver(); + + static { + try { + DriverManager.registerDriver(INSTANCE); + } catch (Exception e) { + System.err.println("Failed to register driver"); + e.printStackTrace(System.err); + } + } + + @Override public Connection connect(String url, Properties info) throws SQLException { + return AvaticaNoopConnection.getInstance(); + } + + @Override public boolean acceptsURL(String url) throws SQLException { + return url.startsWith("jdbc:avatica:noop"); + } + + @Override public DriverPropertyInfo[] getPropertyInfo(String url, Properties info) + throws SQLException { + return new DriverPropertyInfo[0]; + } + + @Override public int getMajorVersion() { + return 1; + } + + @Override public int getMinorVersion() { + return 7; + } + + @Override public boolean jdbcCompliant() { + return true; + } + + @Override public Logger getParentLogger() throws SQLFeatureNotSupportedException { + return Logger.getLogger(""); + } +} + +// End AvaticaNoopDriver.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopParameterMetaData.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopParameterMetaData.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopParameterMetaData.java new file mode 100644 index 0000000..f7117e9 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopParameterMetaData.java @@ -0,0 +1,85 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.sql.ParameterMetaData; +import java.sql.SQLException; + +/** + * An implementation of {@link ParameterMetaData} which does nothing. + */ +public class AvaticaNoopParameterMetaData implements ParameterMetaData { + + private static final AvaticaNoopParameterMetaData INSTANCE = new AvaticaNoopParameterMetaData(); + + public static AvaticaNoopParameterMetaData getInstance() { + return INSTANCE; + } + + private AvaticaNoopParameterMetaData() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("Unsupported"); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + return false; + } + + @Override public int getParameterCount() throws SQLException { + return 0; + } + + @Override public int isNullable(int param) throws SQLException { + return 0; + } + + @Override public boolean isSigned(int param) throws SQLException { + return false; + } + + @Override public int getPrecision(int param) throws SQLException { + return 0; + } + + @Override public int getScale(int param) throws SQLException { + return 0; + } + + @Override public int getParameterType(int param) throws SQLException { + return 0; + } + + @Override public String getParameterTypeName(int param) throws SQLException { + throw unsupported(); + } + + @Override public String getParameterClassName(int param) throws SQLException { + return "java.lang.Object"; + } + + @Override public int getParameterMode(int param) throws SQLException { + return 0; + } + +} + +// End AvaticaNoopParameterMetaData.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopPreparedStatement.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopPreparedStatement.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopPreparedStatement.java new file mode 100644 index 0000000..b8ad8cc --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopPreparedStatement.java @@ -0,0 +1,344 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.io.InputStream; +import java.io.Reader; +import java.math.BigDecimal; +import java.net.URL; +import java.sql.Array; +import java.sql.Blob; +import java.sql.Clob; +import java.sql.Connection; +import java.sql.Date; +import java.sql.NClob; +import java.sql.ParameterMetaData; +import java.sql.PreparedStatement; +import java.sql.Ref; +import java.sql.ResultSet; +import java.sql.ResultSetMetaData; +import java.sql.RowId; +import java.sql.SQLException; +import java.sql.SQLWarning; +import java.sql.SQLXML; +import java.sql.Time; +import java.sql.Timestamp; +import java.util.Calendar; + +/** + * A {@link PreparedStatement} instance which does nothing. + */ +public class AvaticaNoopPreparedStatement implements PreparedStatement { + + private static final AvaticaNoopPreparedStatement INSTANCE = new AvaticaNoopPreparedStatement(); + + public static AvaticaNoopPreparedStatement getInstance() { + return INSTANCE; + } + + private AvaticaNoopPreparedStatement() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("Unsupported"); + } + + @Override public ResultSet executeQuery(String sql) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public int executeUpdate(String sql) throws SQLException { + return 1; + } + + @Override public void close() throws SQLException {} + + @Override public int getMaxFieldSize() throws SQLException { + throw unsupported(); + } + + @Override public void setMaxFieldSize(int max) throws SQLException {} + + @Override public int getMaxRows() throws SQLException { + throw unsupported(); + } + + @Override public void setMaxRows(int max) throws SQLException {} + + @Override public void setEscapeProcessing(boolean enable) throws SQLException {} + + @Override public int getQueryTimeout() throws SQLException { + throw unsupported(); + } + + @Override public void setQueryTimeout(int seconds) throws SQLException {} + + @Override public void cancel() throws SQLException {} + + @Override public SQLWarning getWarnings() throws SQLException { + throw unsupported(); + } + + @Override public void clearWarnings() throws SQLException {} + + @Override public void setCursorName(String name) throws SQLException {} + + @Override public boolean execute(String sql) throws SQLException { + return false; + } + + @Override public ResultSet getResultSet() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public int getUpdateCount() throws SQLException { + return 1; + } + + @Override public boolean getMoreResults() throws SQLException { + return false; + } + + @Override public void setFetchDirection(int direction) throws SQLException {} + + @Override public int getFetchDirection() throws SQLException { + throw unsupported(); + } + + @Override public void setFetchSize(int rows) throws SQLException {} + + @Override public int getFetchSize() throws SQLException { + throw unsupported(); + } + + @Override public int getResultSetConcurrency() throws SQLException { + throw unsupported(); + } + + @Override public int getResultSetType() throws SQLException { + throw unsupported(); + } + + @Override public void addBatch(String sql) throws SQLException {} + + @Override public void clearBatch() throws SQLException {} + + @Override public int[] executeBatch() throws SQLException { + return new int[0]; + } + + @Override public Connection getConnection() throws SQLException { + return AvaticaNoopConnection.getInstance(); + } + + @Override public boolean getMoreResults(int current) throws SQLException { + throw unsupported(); + } + + @Override public ResultSet getGeneratedKeys() throws SQLException { + throw unsupported(); + } + + @Override public int executeUpdate(String sql, int autoGeneratedKeys) throws SQLException { + return 1; + } + + @Override public int executeUpdate(String sql, int[] columnIndexes) throws SQLException { + return 1; + } + + @Override public int executeUpdate(String sql, String[] columnNames) throws SQLException { + return 1; + } + + @Override public boolean execute(String sql, int autoGeneratedKeys) throws SQLException { + return true; + } + + @Override public boolean execute(String sql, int[] columnIndexes) throws SQLException { + return true; + } + + @Override public boolean execute(String sql, String[] columnNames) throws SQLException { + return true; + } + + @Override public int getResultSetHoldability() throws SQLException { + throw unsupported(); + } + + @Override public boolean isClosed() throws SQLException { + return false; + } + + @Override public void setPoolable(boolean poolable) throws SQLException {} + + @Override public boolean isPoolable() throws SQLException { + return true; + } + + @Override public void closeOnCompletion() throws SQLException {} + + @Override public boolean isCloseOnCompletion() throws SQLException { + throw unsupported(); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + return false; + } + + @Override public ResultSet executeQuery() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public int executeUpdate() throws SQLException { + return 1; + } + + @Override public void setNull(int parameterIndex, int sqlType) throws SQLException {} + + @Override public void setBoolean(int parameterIndex, boolean x) throws SQLException {} + + @Override public void setByte(int parameterIndex, byte x) throws SQLException {} + + @Override public void setShort(int parameterIndex, short x) throws SQLException {} + + @Override public void setInt(int parameterIndex, int x) throws SQLException {} + + @Override public void setLong(int parameterIndex, long x) throws SQLException {} + + @Override public void setFloat(int parameterIndex, float x) throws SQLException {} + + @Override public void setDouble(int parameterIndex, double x) throws SQLException {} + + @Override public void setBigDecimal(int parameterIndex, BigDecimal x) throws SQLException {} + + @Override public void setString(int parameterIndex, String x) throws SQLException {} + + @Override public void setBytes(int parameterIndex, byte[] x) throws SQLException {} + + @Override public void setDate(int parameterIndex, Date x) throws SQLException {} + + @Override public void setTime(int parameterIndex, Time x) throws SQLException {} + + @Override public void setTimestamp(int parameterIndex, Timestamp x) throws SQLException {} + + @Override public void setAsciiStream(int parameterIndex, InputStream x, int length) + throws SQLException {} + + @Override public void setUnicodeStream(int parameterIndex, InputStream x, int length) + throws SQLException {} + + @Override public void setBinaryStream(int parameterIndex, InputStream x, int length) + throws SQLException {} + + @Override public void clearParameters() throws SQLException {} + + @Override public void setObject(int parameterIndex, Object x, int targetSqlType) + throws SQLException {} + + @Override public void setObject(int parameterIndex, Object x) throws SQLException {} + + @Override public boolean execute() throws SQLException { + return false; + } + + @Override public void addBatch() throws SQLException {} + + @Override public void setCharacterStream(int parameterIndex, Reader reader, int length) + throws SQLException {} + + @Override public void setRef(int parameterIndex, Ref x) throws SQLException {} + + @Override public void setBlob(int parameterIndex, Blob x) throws SQLException {} + + @Override public void setClob(int parameterIndex, Clob x) throws SQLException {} + + @Override public void setArray(int parameterIndex, Array x) throws SQLException {} + + @Override public ResultSetMetaData getMetaData() throws SQLException { + return AvaticaNoopResultSetMetaData.getInstance(); + } + + @Override public void setDate(int parameterIndex, Date x, Calendar cal) throws SQLException {} + + @Override public void setTime(int parameterIndex, Time x, Calendar cal) throws SQLException {} + + @Override public void setTimestamp(int parameterIndex, Timestamp x, Calendar cal) + throws SQLException {} + + @Override public void setNull(int parameterIndex, int sqlType, String typeName) + throws SQLException {} + + @Override public void setURL(int parameterIndex, URL x) throws SQLException {} + + @Override public ParameterMetaData getParameterMetaData() throws SQLException { + return AvaticaNoopParameterMetaData.getInstance(); + } + + @Override public void setRowId(int parameterIndex, RowId x) throws SQLException {} + + @Override public void setNString(int parameterIndex, String value) throws SQLException {} + + @Override public void setNCharacterStream(int parameterIndex, Reader value, long length) + throws SQLException {} + + @Override public void setNClob(int parameterIndex, NClob value) throws SQLException {} + + @Override public void setClob(int parameterIndex, Reader reader, long length) + throws SQLException {} + + @Override public void setBlob(int parameterIndex, InputStream inputStream, long length) + throws SQLException {} + + @Override public void setNClob(int parameterIndex, Reader reader, long length) + throws SQLException {} + + @Override public void setSQLXML(int parameterIndex, SQLXML xmlObject) throws SQLException {} + + @Override public void setObject(int parameterIndex, Object x, int targetSqlType, + int scaleOrLength) + throws SQLException {} + + @Override public void setAsciiStream(int parameterIndex, InputStream x, long length) + throws SQLException {} + + @Override public void setBinaryStream(int parameterIndex, InputStream x, long length) + throws SQLException {} + + @Override public void setCharacterStream(int parameterIndex, Reader reader, long length) + throws SQLException {} + + @Override public void setAsciiStream(int parameterIndex, InputStream x) throws SQLException {} + + @Override public void setBinaryStream(int parameterIndex, InputStream x) throws SQLException {} + + @Override public void setCharacterStream(int parameterIndex, Reader reader) throws SQLException {} + + @Override public void setNCharacterStream(int parameterIndex, Reader value) throws SQLException {} + + @Override public void setClob(int parameterIndex, Reader reader) throws SQLException {} + + @Override public void setBlob(int parameterIndex, InputStream inputStream) throws SQLException {} + + @Override public void setNClob(int parameterIndex, Reader reader) throws SQLException {} +} + +// End AvaticaNoopPreparedStatement.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSet.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSet.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSet.java new file mode 100644 index 0000000..2d71184 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSet.java @@ -0,0 +1,661 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.io.InputStream; +import java.io.Reader; +import java.math.BigDecimal; +import java.net.URL; +import java.sql.Array; +import java.sql.Blob; +import java.sql.Clob; +import java.sql.Date; +import java.sql.NClob; +import java.sql.Ref; +import java.sql.ResultSet; +import java.sql.ResultSetMetaData; +import java.sql.RowId; +import java.sql.SQLException; +import java.sql.SQLWarning; +import java.sql.SQLXML; +import java.sql.Statement; +import java.sql.Time; +import java.sql.Timestamp; +import java.util.Calendar; +import java.util.Map; + +/** + * A {@link ResultSet} implementation which does nothing. + */ +public class AvaticaNoopResultSet implements ResultSet { + + private static final AvaticaNoopResultSet INSTANCE = new AvaticaNoopResultSet(); + + public static AvaticaNoopResultSet getInstance() { + return INSTANCE; + } + + private AvaticaNoopResultSet() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("unsupported"); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean next() throws SQLException { + return false; + } + + @Override public void close() throws SQLException {} + + @Override public boolean wasNull() throws SQLException { + return false; + } + + @Override public String getString(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public boolean getBoolean(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public byte getByte(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public short getShort(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public int getInt(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public long getLong(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public float getFloat(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public double getDouble(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public BigDecimal getBigDecimal(int columnIndex, int scale) throws SQLException { + throw unsupported(); + } + + @Override public byte[] getBytes(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Date getDate(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Time getTime(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Timestamp getTimestamp(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public InputStream getAsciiStream(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public InputStream getUnicodeStream(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public InputStream getBinaryStream(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public String getString(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public boolean getBoolean(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public byte getByte(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public short getShort(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public int getInt(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public long getLong(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public float getFloat(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public double getDouble(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public BigDecimal getBigDecimal(String columnLabel, int scale) throws SQLException { + throw unsupported(); + } + + @Override public byte[] getBytes(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Date getDate(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Time getTime(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Timestamp getTimestamp(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public InputStream getAsciiStream(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public InputStream getUnicodeStream(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public InputStream getBinaryStream(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public SQLWarning getWarnings() throws SQLException { + throw unsupported(); + } + + @Override public void clearWarnings() throws SQLException {} + + @Override public String getCursorName() throws SQLException { + throw unsupported(); + } + + @Override public ResultSetMetaData getMetaData() throws SQLException { + return AvaticaNoopResultSetMetaData.getInstance(); + } + + @Override public Object getObject(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Object getObject(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public int findColumn(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Reader getCharacterStream(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Reader getCharacterStream(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public BigDecimal getBigDecimal(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public BigDecimal getBigDecimal(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public boolean isBeforeFirst() throws SQLException { + throw unsupported(); + } + + @Override public boolean isAfterLast() throws SQLException { + throw unsupported(); + } + + @Override public boolean isFirst() throws SQLException { + throw unsupported(); + } + + @Override public boolean isLast() throws SQLException { + throw unsupported(); + } + + @Override public void beforeFirst() throws SQLException {} + + @Override public void afterLast() throws SQLException {} + + @Override public boolean first() throws SQLException { + throw unsupported(); + } + + @Override public boolean last() throws SQLException { + throw unsupported(); + } + + @Override public int getRow() throws SQLException { + throw unsupported(); + } + + @Override public boolean absolute(int row) throws SQLException { + throw unsupported(); + } + + @Override public boolean relative(int rows) throws SQLException { + throw unsupported(); + } + + @Override public boolean previous() throws SQLException { + throw unsupported(); + } + + @Override public void setFetchDirection(int direction) throws SQLException {} + + @Override public int getFetchDirection() throws SQLException { + throw unsupported(); + } + + @Override public void setFetchSize(int rows) throws SQLException {} + + @Override public int getFetchSize() throws SQLException { + throw unsupported(); + } + + @Override public int getType() throws SQLException { + throw unsupported(); + } + + @Override public int getConcurrency() throws SQLException { + throw unsupported(); + } + + @Override public boolean rowUpdated() throws SQLException { + throw unsupported(); + } + + @Override public boolean rowInserted() throws SQLException { + throw unsupported(); + } + + @Override public boolean rowDeleted() throws SQLException { + throw unsupported(); + } + + @Override public void updateNull(int columnIndex) throws SQLException {} + + @Override public void updateBoolean(int columnIndex, boolean x) throws SQLException {} + + @Override public void updateByte(int columnIndex, byte x) throws SQLException {} + + @Override public void updateShort(int columnIndex, short x) throws SQLException {} + + @Override public void updateInt(int columnIndex, int x) throws SQLException {} + + @Override public void updateLong(int columnIndex, long x) throws SQLException {} + + @Override public void updateFloat(int columnIndex, float x) throws SQLException {} + + @Override public void updateDouble(int columnIndex, double x) throws SQLException {} + + @Override public void updateBigDecimal(int columnIndex, BigDecimal x) throws SQLException {} + + @Override public void updateString(int columnIndex, String x) throws SQLException {} + + @Override public void updateBytes(int columnIndex, byte[] x) throws SQLException {} + + @Override public void updateDate(int columnIndex, Date x) throws SQLException {} + + @Override public void updateTime(int columnIndex, Time x) throws SQLException {} + + @Override public void updateTimestamp(int columnIndex, Timestamp x) throws SQLException {} + + @Override public void updateAsciiStream(int columnIndex, InputStream x, int length) + throws SQLException {} + + @Override public void updateBinaryStream(int columnIndex, InputStream x, int length) + throws SQLException {} + + @Override public void updateCharacterStream(int columnIndex, Reader x, int length) + throws SQLException {} + + @Override public void updateObject(int columnIndex, Object x, int scaleOrLength) + throws SQLException {} + + @Override public void updateObject(int columnIndex, Object x) throws SQLException {} + + @Override public void updateNull(String columnLabel) throws SQLException {} + + @Override public void updateBoolean(String columnLabel, boolean x) throws SQLException {} + + @Override public void updateByte(String columnLabel, byte x) throws SQLException {} + + @Override public void updateShort(String columnLabel, short x) throws SQLException {} + + @Override public void updateInt(String columnLabel, int x) throws SQLException {} + + @Override public void updateLong(String columnLabel, long x) throws SQLException {} + + @Override public void updateFloat(String columnLabel, float x) throws SQLException {} + + @Override public void updateDouble(String columnLabel, double x) throws SQLException {} + + @Override public void updateBigDecimal(String columnLabel, BigDecimal x) throws SQLException {} + + @Override public void updateString(String columnLabel, String x) throws SQLException {} + + @Override public void updateBytes(String columnLabel, byte[] x) throws SQLException {} + + @Override public void updateDate(String columnLabel, Date x) throws SQLException {} + + @Override public void updateTime(String columnLabel, Time x) throws SQLException {} + + @Override public void updateTimestamp(String columnLabel, Timestamp x) throws SQLException {} + + @Override public void updateAsciiStream(String columnLabel, InputStream x, int length) + throws SQLException {} + + @Override public void updateBinaryStream(String columnLabel, InputStream x, int length) + throws SQLException {} + + @Override public void updateCharacterStream(String columnLabel, Reader reader, int length) + throws SQLException {} + + @Override public void updateObject(String columnLabel, Object x, int scaleOrLength) + throws SQLException {} + + @Override public void updateObject(String columnLabel, Object x) throws SQLException {} + + @Override public void insertRow() throws SQLException {} + + @Override public void updateRow() throws SQLException {} + + @Override public void deleteRow() throws SQLException {} + + @Override public void refreshRow() throws SQLException {} + + @Override public void cancelRowUpdates() throws SQLException {} + + @Override public void moveToInsertRow() throws SQLException {} + + @Override public void moveToCurrentRow() throws SQLException {} + + @Override public Statement getStatement() throws SQLException { + return AvaticaNoopStatement.getInstance(); + } + + @Override public Object getObject(int columnIndex, Map<String, Class<?>> map) + throws SQLException { + throw unsupported(); + } + + @Override public Ref getRef(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Blob getBlob(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Clob getClob(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Array getArray(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Object getObject(String columnLabel, Map<String, Class<?>> map) + throws SQLException { + throw unsupported(); + } + + @Override public Ref getRef(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Blob getBlob(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Clob getClob(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Array getArray(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Date getDate(int columnIndex, Calendar cal) throws SQLException { + throw unsupported(); + } + + @Override public Date getDate(String columnLabel, Calendar cal) throws SQLException { + throw unsupported(); + } + + @Override public Time getTime(int columnIndex, Calendar cal) throws SQLException { + throw unsupported(); + } + + @Override public Time getTime(String columnLabel, Calendar cal) throws SQLException { + throw unsupported(); + } + + @Override public Timestamp getTimestamp(int columnIndex, Calendar cal) throws SQLException { + throw unsupported(); + } + + @Override public Timestamp getTimestamp(String columnLabel, Calendar cal) throws SQLException { + throw unsupported(); + } + + @Override public URL getURL(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public URL getURL(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public void updateRef(int columnIndex, Ref x) throws SQLException {} + + @Override public void updateRef(String columnLabel, Ref x) throws SQLException {} + + @Override public void updateBlob(int columnIndex, Blob x) throws SQLException {} + + @Override public void updateBlob(String columnLabel, Blob x) throws SQLException {} + + @Override public void updateClob(int columnIndex, Clob x) throws SQLException {} + + @Override public void updateClob(String columnLabel, Clob x) throws SQLException {} + + @Override public void updateArray(int columnIndex, Array x) throws SQLException {} + + @Override public void updateArray(String columnLabel, Array x) throws SQLException {} + + @Override public RowId getRowId(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public RowId getRowId(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public void updateRowId(int columnIndex, RowId x) throws SQLException {} + + @Override public void updateRowId(String columnLabel, RowId x) throws SQLException {} + + @Override public int getHoldability() throws SQLException { + throw unsupported(); + } + + @Override public boolean isClosed() throws SQLException { + return false; + } + + @Override public void updateNString(int columnIndex, String nString) throws SQLException {} + + @Override public void updateNString(String columnLabel, String nString) throws SQLException {} + + @Override public void updateNClob(int columnIndex, NClob nClob) throws SQLException {} + + @Override public void updateNClob(String columnLabel, NClob nClob) throws SQLException {} + + @Override public NClob getNClob(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public NClob getNClob(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public SQLXML getSQLXML(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public SQLXML getSQLXML(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public void updateSQLXML(int columnIndex, SQLXML xmlObject) throws SQLException {} + + @Override public void updateSQLXML(String columnLabel, SQLXML xmlObject) throws SQLException {} + + @Override public String getNString(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public String getNString(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public Reader getNCharacterStream(int columnIndex) throws SQLException { + throw unsupported(); + } + + @Override public Reader getNCharacterStream(String columnLabel) throws SQLException { + throw unsupported(); + } + + @Override public void updateNCharacterStream(int columnIndex, Reader x, long length) + throws SQLException {} + + @Override public void updateNCharacterStream(String columnLabel, Reader reader, long length) + throws SQLException {} + + @Override public void updateAsciiStream(int columnIndex, InputStream x, long length) + throws SQLException {} + + @Override public void updateBinaryStream(int columnIndex, InputStream x, long length) + throws SQLException {} + + @Override public void updateCharacterStream(int columnIndex, Reader x, long length) + throws SQLException {} + + @Override public void updateAsciiStream(String columnLabel, InputStream x, long length) + throws SQLException {} + + @Override public void updateBinaryStream(String columnLabel, InputStream x, long length) + throws SQLException {} + + @Override public void updateCharacterStream(String columnLabel, Reader reader, long length) + throws SQLException {} + + @Override public void updateBlob(int columnIndex, InputStream inputStream, long length) + throws SQLException {} + + @Override public void updateBlob(String columnLabel, InputStream inputStream, long length) + throws SQLException {} + + @Override public void updateClob(int columnIndex, Reader reader, long length) + throws SQLException {} + + @Override public void updateClob(String columnLabel, Reader reader, long length) + throws SQLException {} + + @Override public void updateNClob(int columnIndex, Reader reader, long length) + throws SQLException {} + + @Override public void updateNClob(String columnLabel, Reader reader, long length) + throws SQLException {} + + @Override public void updateNCharacterStream(int columnIndex, Reader x) throws SQLException {} + + @Override public void updateNCharacterStream(String columnLabel, Reader reader) + throws SQLException {} + + @Override public void updateAsciiStream(int columnIndex, InputStream x) throws SQLException {} + + @Override public void updateBinaryStream(int columnIndex, InputStream x) throws SQLException {} + + @Override public void updateCharacterStream(int columnIndex, Reader x) throws SQLException {} + + @Override public void updateAsciiStream(String columnLabel, InputStream x) throws SQLException {} + + @Override public void updateBinaryStream(String columnLabel, InputStream x) throws SQLException {} + + @Override public void updateCharacterStream(String columnLabel, Reader reader) + throws SQLException {} + + @Override public void updateBlob(int columnIndex, InputStream inputStream) throws SQLException {} + + @Override public void updateBlob(String columnLabel, InputStream inputStream) + throws SQLException {} + + @Override public void updateClob(int columnIndex, Reader reader) throws SQLException {} + + @Override public void updateClob(String columnLabel, Reader reader) throws SQLException {} + + @Override public void updateNClob(int columnIndex, Reader reader) throws SQLException {} + + @Override public void updateNClob(String columnLabel, Reader reader) throws SQLException {} + + @Override public <T> T getObject(int columnIndex, Class<T> type) throws SQLException { + throw unsupported(); + } + + @Override public <T> T getObject(String columnLabel, Class<T> type) throws SQLException { + throw unsupported(); + } + +} + +// End AvaticaNoopResultSet.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSetMetaData.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSetMetaData.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSetMetaData.java new file mode 100644 index 0000000..ddc8c3b --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopResultSetMetaData.java @@ -0,0 +1,133 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.sql.ResultSetMetaData; +import java.sql.SQLException; + +/** + * A {@link ResultSetMetaData} implementation which does nothing. + */ +public class AvaticaNoopResultSetMetaData implements ResultSetMetaData { + + private static final AvaticaNoopResultSetMetaData INSTANCE = new AvaticaNoopResultSetMetaData(); + + public static AvaticaNoopResultSetMetaData getInstance() { + return INSTANCE; + } + + private AvaticaNoopResultSetMetaData() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("Unsupported"); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + throw unsupported(); + } + + @Override public int getColumnCount() throws SQLException { + return 0; + } + + @Override public boolean isAutoIncrement(int column) throws SQLException { + return false; + } + + @Override public boolean isCaseSensitive(int column) throws SQLException { + return false; + } + + @Override public boolean isSearchable(int column) throws SQLException { + return false; + } + + @Override public boolean isCurrency(int column) throws SQLException { + return false; + } + + @Override public int isNullable(int column) throws SQLException { + return 0; + } + + @Override public boolean isSigned(int column) throws SQLException { + return false; + } + + @Override public int getColumnDisplaySize(int column) throws SQLException { + return 0; + } + + @Override public String getColumnLabel(int column) throws SQLException { + return ""; + } + + @Override public String getColumnName(int column) throws SQLException { + throw unsupported(); + } + + @Override public String getSchemaName(int column) throws SQLException { + throw unsupported(); + } + + @Override public int getPrecision(int column) throws SQLException { + return 0; + } + + @Override public int getScale(int column) throws SQLException { + return 0; + } + + @Override public String getTableName(int column) throws SQLException { + throw unsupported(); + } + + @Override public String getCatalogName(int column) throws SQLException { + throw unsupported(); + } + + @Override public int getColumnType(int column) throws SQLException { + return 0; + } + + @Override public String getColumnTypeName(int column) throws SQLException { + throw unsupported(); + } + + @Override public boolean isReadOnly(int column) throws SQLException { + return false; + } + + @Override public boolean isWritable(int column) throws SQLException { + return false; + } + + @Override public boolean isDefinitelyWritable(int column) throws SQLException { + return false; + } + + @Override public String getColumnClassName(int column) throws SQLException { + throw unsupported(); + } + +} + +// End AvaticaNoopResultSetMetaData.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopStatement.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopStatement.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopStatement.java new file mode 100644 index 0000000..079cea4 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/AvaticaNoopStatement.java @@ -0,0 +1,191 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.sql.Connection; +import java.sql.ResultSet; +import java.sql.SQLException; +import java.sql.SQLWarning; +import java.sql.Statement; + +/** + * A {@link Statement} implementation which does nothing. + */ +public class AvaticaNoopStatement implements Statement { + + private static final AvaticaNoopStatement INSTANCE = new AvaticaNoopStatement(); + + public static AvaticaNoopStatement getInstance() { + return INSTANCE; + } + + private AvaticaNoopStatement() {} + + private UnsupportedOperationException unsupported() { + return new UnsupportedOperationException("Unsupported"); + } + + @Override public ResultSet executeQuery(String sql) throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public int executeUpdate(String sql) throws SQLException { + return 1; + } + + @Override public void close() throws SQLException {} + + @Override public int getMaxFieldSize() throws SQLException { + throw unsupported(); + } + + @Override public void setMaxFieldSize(int max) throws SQLException {} + + @Override public int getMaxRows() throws SQLException { + throw unsupported(); + } + + @Override public void setMaxRows(int max) throws SQLException {} + + @Override public void setEscapeProcessing(boolean enable) throws SQLException {} + + @Override public int getQueryTimeout() throws SQLException { + throw unsupported(); + } + + @Override public void setQueryTimeout(int seconds) throws SQLException {} + + @Override public void cancel() throws SQLException {} + + @Override public SQLWarning getWarnings() throws SQLException { + throw unsupported(); + } + + @Override public void clearWarnings() throws SQLException {} + + @Override public void setCursorName(String name) throws SQLException {} + + @Override public boolean execute(String sql) throws SQLException { + return false; + } + + @Override public ResultSet getResultSet() throws SQLException { + return AvaticaNoopResultSet.getInstance(); + } + + @Override public int getUpdateCount() throws SQLException { + return 1; + } + + @Override public boolean getMoreResults() throws SQLException { + return false; + } + + @Override public void setFetchDirection(int direction) throws SQLException {} + + @Override public int getFetchDirection() throws SQLException { + throw unsupported(); + } + + @Override public void setFetchSize(int rows) throws SQLException {} + + @Override public int getFetchSize() throws SQLException { + throw unsupported(); + } + + @Override public int getResultSetConcurrency() throws SQLException { + throw unsupported(); + } + + @Override public int getResultSetType() throws SQLException { + throw unsupported(); + } + + @Override public void addBatch(String sql) throws SQLException {} + + @Override public void clearBatch() throws SQLException {} + + @Override public int[] executeBatch() throws SQLException { + return new int[0]; + } + + @Override public Connection getConnection() throws SQLException { + return AvaticaNoopConnection.getInstance(); + } + + @Override public boolean getMoreResults(int current) throws SQLException { + throw unsupported(); + } + + @Override public ResultSet getGeneratedKeys() throws SQLException { + throw unsupported(); + } + + @Override public int executeUpdate(String sql, int autoGeneratedKeys) throws SQLException { + return 1; + } + + @Override public int executeUpdate(String sql, int[] columnIndexes) throws SQLException { + return 1; + } + + @Override public int executeUpdate(String sql, String[] columnNames) throws SQLException { + return 1; + } + + @Override public boolean execute(String sql, int autoGeneratedKeys) throws SQLException { + return true; + } + + @Override public boolean execute(String sql, int[] columnIndexes) throws SQLException { + return true; + } + + @Override public boolean execute(String sql, String[] columnNames) throws SQLException { + return true; + } + + @Override public int getResultSetHoldability() throws SQLException { + throw unsupported(); + } + + @Override public boolean isClosed() throws SQLException { + return false; + } + + @Override public void setPoolable(boolean poolable) throws SQLException {} + + @Override public boolean isPoolable() throws SQLException { + return true; + } + + @Override public void closeOnCompletion() throws SQLException {} + + @Override public boolean isCloseOnCompletion() throws SQLException { + throw unsupported(); + } + + @Override public <T> T unwrap(Class<T> iface) throws SQLException { + throw unsupported(); + } + + @Override public boolean isWrapperFor(Class<?> iface) throws SQLException { + throw unsupported(); + } +} + +// End AvaticaNoopStatement.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/PackageMarker.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/PackageMarker.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/PackageMarker.java new file mode 100644 index 0000000..6ae1905 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/PackageMarker.java @@ -0,0 +1,37 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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.apache.calcite.avatica.noop; + +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; + +/** + * This is a dummy annotation that forces javac to produce output for + * otherwise empty package-info.java. + * + * <p>The result is maven-compiler-plugin can properly identify the scope of + * changed files + * + * <p>See more details in + * <a href="https://jira.codehaus.org/browse/MCOMPILER-205"> + * maven-compiler-plugin: incremental compilation broken</a> + */ +@Retention(RetentionPolicy.SOURCE) +public @interface PackageMarker { +} + +// End PackageMarker.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/package-info.java ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/package-info.java b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/package-info.java new file mode 100644 index 0000000..da1c5c4 --- /dev/null +++ b/avatica/noop-driver/src/main/java/org/apache/calcite/avatica/noop/package-info.java @@ -0,0 +1,24 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to you 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. + */ + +/** + * A no-operation implementation of a JDBC driver built for testing Avatica. + */ +@PackageMarker +package org.apache.calcite.avatica.noop; + +// End package-info.java http://git-wip-us.apache.org/repos/asf/calcite/blob/5cee486f/avatica/noop-driver/src/main/resources/META-INF/services/java.sql.Driver ---------------------------------------------------------------------- diff --git a/avatica/noop-driver/src/main/resources/META-INF/services/java.sql.Driver b/avatica/noop-driver/src/main/resources/META-INF/services/java.sql.Driver new file mode 100644 index 0000000..24845b0 --- /dev/null +++ b/avatica/noop-driver/src/main/resources/META-INF/services/java.sql.Driver @@ -0,0 +1 @@ +org.apache.calcite.avatica.noop.AvaticaNoopDriver
