diff options
Diffstat (limited to 'connectivity')
-rw-r--r-- | connectivity/source/drivers/firebird/PreparedStatement.cxx | 65 | ||||
-rw-r--r-- | connectivity/source/drivers/firebird/PreparedStatement.hxx | 6 |
2 files changed, 27 insertions, 44 deletions
diff --git a/connectivity/source/drivers/firebird/PreparedStatement.cxx b/connectivity/source/drivers/firebird/PreparedStatement.cxx index 2c59931c1ca8..ffa3124d3add 100644 --- a/connectivity/source/drivers/firebird/PreparedStatement.cxx +++ b/connectivity/source/drivers/firebird/PreparedStatement.cxx @@ -345,18 +345,9 @@ void SAL_CALL OPreparedStatement::setBoolean(sal_Int32 nIndex, sal_Bool x) // it might be best to just determine the db type and set as appropriate? } -void SAL_CALL OPreparedStatement::setByte(sal_Int32 nIndex, sal_Int8 nValue) - throw(SQLException, RuntimeException) -{ - (void) nIndex; - (void) nValue; - ::dbtools::throwFunctionNotSupportedException("setByte not supported in firebird", - *this, - Any()); -} - -void SAL_CALL OPreparedStatement::setShort(sal_Int32 nIndex, sal_Int16 nValue) - throw(SQLException, RuntimeException) +template <typename T> +void OPreparedStatement::setValue(sal_Int32 nIndex, T nValue, ISC_SHORT nType) + throw(SQLException) { MutexGuard aGuard( m_pConnection->getMutex() ); checkDisposed(OStatementCommonBase_Base::rBHelper.bDisposed); @@ -367,52 +358,38 @@ void SAL_CALL OPreparedStatement::setShort(sal_Int32 nIndex, sal_Int16 nValue) XSQLVAR* pVar = m_pInSqlda->sqlvar + (nIndex - 1); - int dtype = (pVar->sqltype & ~1); // drop flag bit for now - - if (dtype != SQL_SHORT) + if ((pVar->sqltype & ~1) != nType) throw SQLException(); // TODO: cast instead? memcpy(pVar->sqldata, &nValue, sizeof(nValue)); } -void SAL_CALL OPreparedStatement::setInt(sal_Int32 nIndex, sal_Int32 nValue) +void SAL_CALL OPreparedStatement::setByte(sal_Int32 nIndex, sal_Int8 nValue) throw(SQLException, RuntimeException) { - MutexGuard aGuard( m_pConnection->getMutex() ); - checkDisposed(OStatementCommonBase_Base::rBHelper.bDisposed); - ensurePrepared(); - - checkParameterIndex(nIndex); - setParameterNull(nIndex, false); - - XSQLVAR* pVar = m_pInSqlda->sqlvar + (nIndex - 1); - - int dtype = (pVar->sqltype & ~1); // drop flag bit for now + (void) nIndex; + (void) nValue; + ::dbtools::throwFunctionNotSupportedException("setByte not supported in firebird", + *this, + Any()); +} - if (dtype != SQL_LONG) - throw SQLException(); // TODO: cast instead? +void SAL_CALL OPreparedStatement::setShort(sal_Int32 nIndex, sal_Int16 nValue) + throw(SQLException, RuntimeException) +{ + setValue< sal_Int16 >(nIndex, nValue, SQL_SHORT); +} - memcpy(pVar->sqldata, &nValue, sizeof(nValue)); +void SAL_CALL OPreparedStatement::setInt(sal_Int32 nIndex, sal_Int32 nValue) + throw(SQLException, RuntimeException) +{ + setValue< sal_Int32 >(nIndex, nValue, SQL_LONG); } void SAL_CALL OPreparedStatement::setLong(sal_Int32 nIndex, sal_Int64 nValue) throw(SQLException, RuntimeException) { - MutexGuard aGuard( m_pConnection->getMutex() ); - checkDisposed(OStatementCommonBase_Base::rBHelper.bDisposed); - ensurePrepared(); - - checkParameterIndex(nIndex); - setParameterNull(nIndex, false); - - XSQLVAR* pVar = m_pInSqlda->sqlvar + (nIndex - 1); - - int dtype = (pVar->sqltype & ~1); // drop flag bit for now - - if (dtype != SQL_INT64) - throw SQLException(); // TODO: cast instead? - - memcpy(pVar->sqldata, &nValue, sizeof(nValue)); + setValue< sal_Int64 >(nIndex, nValue, SQL_INT64); } // ------------------------------------------------------------------------- diff --git a/connectivity/source/drivers/firebird/PreparedStatement.hxx b/connectivity/source/drivers/firebird/PreparedStatement.hxx index 4434a644620c..5392a93d6a52 100644 --- a/connectivity/source/drivers/firebird/PreparedStatement.hxx +++ b/connectivity/source/drivers/firebird/PreparedStatement.hxx @@ -74,6 +74,12 @@ namespace connectivity void checkParameterIndex(sal_Int32 nParameterIndex) throw(::com::sun::star::sdbc::SQLException); + /** + * Set a numeric value in the input SQLDA. If the destination + * parameter is not of nType then an Exception will be thrown. + */ + template <typename T> void setValue(sal_Int32 nIndex, T nValue, ISC_SHORT nType) + throw(::com::sun::star::sdbc::SQLException); void setParameterNull(sal_Int32 nParameterIndex, bool bSetNull = true); void ensurePrepared() |