org.firebirdsql.gds.ng.ServerVersionInformation Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird-jdk18 Show documentation
Show all versions of jaybird-jdk18 Show documentation
JDBC Driver for the Firebird RDBMS
/* * $Id$ * * Firebird Open Source JavaEE Connector - JDBC Driver * * Distributable under LGPL license. * You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html * * 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 * LGPL License for more details. * * This file was created by members of the firebird development team. * All individual contributions remain the Copyright (C) of those * individuals. Contributors to this file are either listed here or * can be obtained from a source control history command. * * All rights reserved. */ package org.firebirdsql.gds.ng; import org.firebirdsql.gds.impl.GDSServerVersion; import static org.firebirdsql.gds.ISCConstants.*; /** * Strategy for handling server version specific information needs that do not depend on the wire protocol (or client * library) version, but on the Firebird server version. *
*/ private boolean isEqualOrBelow(int majorVersion, int minorVersion) { return this.majorVersion < majorVersion || (this.majorVersion == majorVersion && this.minorVersion <= minorVersion); } /** * Gets the instance with the highest version that is equal to or lower in version than the specified version. ** Currently only contains information items for statement info requests. *
* * @author Mark Rotteveel * @since 3.0 */ enum ServerVersionInformation { // IMPORTANT: Enums should be defined from low versions to high versions /** * Information for Version 1.0 and higher */ VERSION_1_0(1, 0) { @Override public byte[] getStatementInfoRequestItems() { return Constants.V1_0_STATEMENT_INFO.clone(); } @Override public byte[] getParameterDescriptionInfoRequestItems() { return Constants.V_1_0_PARAMETER_INFO.clone(); } }, /** * Information for Version 2.0 and higher */ VERSION_2_0(2, 0) { @Override public byte[] getStatementInfoRequestItems() { return Constants.V_2_0_STATEMENT_INFO.clone(); } @Override public byte[] getParameterDescriptionInfoRequestItems() { return Constants.V_2_0_PARAMETER_INFO.clone(); } }; private final int majorVersion; private final int minorVersion; private ServerVersionInformation(int majorVersion, int minorVersion) { this.majorVersion = majorVersion; this.minorVersion = minorVersion; } /** * @return The (full) statement info request items. * @see #getParameterDescriptionInfoRequestItems() */ public abstract byte[] getStatementInfoRequestItems(); /** * TODO Do we actually need this separate from {@link #getStatementInfoRequestItems()}? * * @return The {@code isc_info_sql_describe_vars} info request items. * @see #getStatementInfoRequestItems() */ public abstract byte[] getParameterDescriptionInfoRequestItems(); /** * Convenience method to check if the majorVersion.minorVersion of this instance is equal to or smaller than the * specified version. * * @param majorVersion Required major version * @param minorVersion Required minor version * @returntrue
when current majorVersion is smaller than required, or majorVersion is same and * minorVersion is equal to or smaller than required* If the specified version is too low, it will return {@link #VERSION_1_0}. *
* * @param majorVersion Required major version * @param minorVersion Required minor version * @return Instance * @see #getForVersion(org.firebirdsql.gds.impl.GDSServerVersion) */ public static ServerVersionInformation getForVersion(int majorVersion, int minorVersion) { // NOTE: This depends on the contract of Enum.values() and the ordering of the definition of enums ServerVersionInformation highest = VERSION_1_0; for (ServerVersionInformation strategy : values()) { if (strategy.isEqualOrBelow(majorVersion, minorVersion)) { highest = strategy; } else { break; } } return highest; } /** * Gets the instance with the highest version that is equal to or lower in version than the specified version. ** If the specified version is too low, it will return {@link #VERSION_1_0}. *
* * @param serverVersion Server version * @return Instance * @see #getForVersion(int, int) */ public static ServerVersionInformation getForVersion(GDSServerVersion serverVersion) { return getForVersion(serverVersion.getMajorVersion(), serverVersion.getMinorVersion()); } private static class Constants { public static final byte[] V1_0_STATEMENT_INFO = new byte[] { isc_info_sql_stmt_type, isc_info_sql_select, isc_info_sql_describe_vars, isc_info_sql_sqlda_seq, isc_info_sql_type, isc_info_sql_sub_type, isc_info_sql_scale, isc_info_sql_length, isc_info_sql_field, isc_info_sql_alias, isc_info_sql_relation, isc_info_sql_owner, isc_info_sql_describe_end, isc_info_sql_bind, isc_info_sql_describe_vars, isc_info_sql_sqlda_seq, isc_info_sql_type, isc_info_sql_sub_type, isc_info_sql_scale, isc_info_sql_length, // TODO: Information not available in normal queries, check for procedures, otherwise remove //isc_info_sql_field, //isc_info_sql_alias, //isc_info_sql_relation, //isc_info_sql_relation_alias, //isc_info_sql_owner, isc_info_sql_describe_end }; public static final byte[] V_1_0_PARAMETER_INFO = new byte[] { isc_info_sql_describe_vars, isc_info_sql_sqlda_seq, isc_info_sql_type, isc_info_sql_sub_type, isc_info_sql_scale, isc_info_sql_length, isc_info_sql_field, isc_info_sql_alias, isc_info_sql_relation, isc_info_sql_owner, isc_info_sql_describe_end }; public static final byte[] V_2_0_STATEMENT_INFO = new byte[] { isc_info_sql_stmt_type, isc_info_sql_select, isc_info_sql_describe_vars, isc_info_sql_sqlda_seq, isc_info_sql_type, isc_info_sql_sub_type, isc_info_sql_scale, isc_info_sql_length, isc_info_sql_field, isc_info_sql_alias, isc_info_sql_relation, isc_info_sql_relation_alias, isc_info_sql_owner, isc_info_sql_describe_end, isc_info_sql_bind, isc_info_sql_describe_vars, isc_info_sql_sqlda_seq, isc_info_sql_type, isc_info_sql_sub_type, isc_info_sql_scale, isc_info_sql_length, // TODO: Information not available in normal queries, check for procedures, otherwise remove //isc_info_sql_field, //isc_info_sql_alias, //isc_info_sql_relation, //isc_info_sql_relation_alias, //isc_info_sql_owner, isc_info_sql_describe_end }; public static final byte[] V_2_0_PARAMETER_INFO = new byte[] { isc_info_sql_describe_vars, isc_info_sql_sqlda_seq, isc_info_sql_type, isc_info_sql_sub_type, isc_info_sql_scale, isc_info_sql_length, isc_info_sql_field, isc_info_sql_alias, isc_info_sql_relation, isc_info_sql_relation_alias, isc_info_sql_owner, isc_info_sql_describe_end }; } }
© 2015 - 2025 Weber Informatics LLC | Privacy Policy