2000-09-18 23:16:46 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
|
|
|
* $RCSfile: RowSet.cxx,v $
|
|
|
|
*
|
2000-10-17 11:21:45 +00:00
|
|
|
* $Revision: 1.8 $
|
2000-09-18 23:16:46 +00:00
|
|
|
*
|
2000-10-17 11:21:45 +00:00
|
|
|
* last change: $Author: oj $ $Date: 2000-10-17 12:21:45 $
|
2000-09-18 23:16:46 +00:00
|
|
|
*
|
|
|
|
* The Contents of this file are made available subject to the terms of
|
|
|
|
* either of the following licenses
|
|
|
|
*
|
|
|
|
* - GNU Lesser General Public License Version 2.1
|
|
|
|
* - Sun Industry Standards Source License Version 1.1
|
|
|
|
*
|
|
|
|
* Sun Microsystems Inc., October, 2000
|
|
|
|
*
|
|
|
|
* GNU Lesser General Public License Version 2.1
|
|
|
|
* =============================================
|
|
|
|
* Copyright 2000 by Sun Microsystems, Inc.
|
|
|
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License version 2.1, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
* MA 02111-1307 USA
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Sun Industry Standards Source License Version 1.1
|
|
|
|
* =================================================
|
|
|
|
* The contents of this file are subject to the Sun Industry Standards
|
|
|
|
* Source License Version 1.1 (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.openoffice.org/license.html.
|
|
|
|
*
|
|
|
|
* Software provided under this License is provided on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
|
|
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
|
|
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
|
|
|
* See the License for the specific provisions governing your rights and
|
|
|
|
* obligations concerning the Software.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
|
|
|
*
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s): _______________________________________
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
2000-10-17 11:21:45 +00:00
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
#ifndef DBACCESS_CORE_API_ROWSET_HXX
|
|
|
|
#include "RowSet.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBASHARED_STRINGCONSTANTS_HRC_
|
|
|
|
#include "stringconstants.hrc"
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_BEANS_PROPERTYATTRIBUTE_HPP_
|
|
|
|
#include <com/sun/star/beans/PropertyAttribute.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_LANG_DISPOSEDEXCEPTION_HPP_
|
|
|
|
#include <com/sun/star/lang/DisposedException.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _CPPUHELPER_INTERFACECONTAINER_H_
|
|
|
|
#include <cppuhelper/interfacecontainer.h>
|
|
|
|
#endif
|
|
|
|
#ifndef _CPPUHELPER_TYPEPROVIDER_HXX_
|
|
|
|
#include <cppuhelper/typeprovider.hxx>
|
|
|
|
#endif
|
2000-10-11 10:21:40 +00:00
|
|
|
#ifndef _COMPHELPER_SEQUENCE_HXX_
|
|
|
|
#include <comphelper/sequence.hxx>
|
2000-09-18 23:16:46 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDB_ROWSETVETOEXCEPTION_HPP_
|
|
|
|
#include <com/sun/star/sdb/RowSetVetoException.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_FETCHDIRECTION_HPP_
|
|
|
|
#include <com/sun/star/sdbc/FetchDirection.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_RESULTSETCONCURRENCY_HPP_
|
|
|
|
#include <com/sun/star/sdbc/ResultSetConcurrency.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDB_COMMANDTYPE_HPP_
|
|
|
|
#include <com/sun/star/sdb/CommandType.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XDATASOURCE_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XDataSource.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDB_XSQLQUERYCOMPOSERFACTORY_HPP_
|
|
|
|
#include <com/sun/star/sdb/XSQLQueryComposerFactory.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDB_XQUERIESSUPPLIER_HPP_
|
|
|
|
#include <com/sun/star/sdb/XQueriesSupplier.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDB_ROWCHANGEACTION_HPP_
|
|
|
|
#include <com/sun/star/sdb/RowChangeAction.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XDRIVERACCESS_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XDriverAccess.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_SDBCX_XDATADEFINITIONSUPPLIER_HPP_
|
|
|
|
#include <com/sun/star/sdbcx/XDataDefinitionSupplier.hpp>
|
|
|
|
#endif
|
|
|
|
#ifndef _COM_SUN_STAR_UNO_XNAMINGSERVICE_HPP_
|
|
|
|
#include <com/sun/star/uno/XNamingService.hpp>
|
|
|
|
#endif
|
2000-10-11 10:21:40 +00:00
|
|
|
#ifndef _CONNECTIVITY_DBTOOLS_HXX_
|
|
|
|
#include <connectivity/dbtools.hxx>
|
2000-09-18 23:16:46 +00:00
|
|
|
#endif
|
|
|
|
#ifndef _CPPUHELPER_EXTRACT_HXX_
|
|
|
|
#include <cppuhelper/extract.hxx>
|
|
|
|
#endif
|
|
|
|
#ifndef DBACCESS_CORE_API_ROWSETCACHE_HXX
|
|
|
|
#include "RowSetCache.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBA_CORE_REGISTRYHELPER_HXX_
|
|
|
|
#include "registryhelper.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBA_REGISTRATION_HELPER_HXX_
|
|
|
|
#include "registrationhelper.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef _DBA_CORE_TABLECONTAINER_HXX_
|
|
|
|
#include "tablecontainer.hxx"
|
|
|
|
#endif
|
|
|
|
#ifdef DEBUG
|
|
|
|
#ifndef _COM_SUN_STAR_SDBC_XDRIVERMANAGER_HPP_
|
|
|
|
#include <com/sun/star/sdbc/XDriverManager.hpp>
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#ifndef _DBACORE_DATACOLUMN_HXX_
|
|
|
|
#include "CRowSetDataColumn.hxx"
|
|
|
|
#endif
|
|
|
|
#ifndef DBACCESS_CORE_API_CROWSETCOLUMN_HXX
|
|
|
|
#include "CRowSetColumn.hxx"
|
|
|
|
#endif
|
2000-10-17 09:19:03 +00:00
|
|
|
#ifndef _COMPHELPER_TYPES_HXX_
|
|
|
|
#include <comphelper/types.hxx>
|
2000-10-17 11:21:45 +00:00
|
|
|
#endif
|
2000-10-11 10:21:40 +00:00
|
|
|
#ifndef _COMPHELPER_SEQSTREAM_HXX
|
|
|
|
#include <comphelper/seqstream.hxx>
|
2000-09-29 14:23:36 +00:00
|
|
|
#endif
|
2000-10-17 11:21:45 +00:00
|
|
|
#ifndef _TOOLS_DEBUG_HXX
|
|
|
|
#include <tools/debug.hxx>
|
|
|
|
#endif
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
using namespace dbaccess;
|
|
|
|
using namespace connectivity;
|
2000-10-05 08:37:27 +00:00
|
|
|
using namespace comphelper;
|
2000-09-18 23:16:46 +00:00
|
|
|
using namespace ::com::sun::star::uno;
|
|
|
|
using namespace ::com::sun::star::beans;
|
|
|
|
using namespace ::com::sun::star::sdbc;
|
|
|
|
using namespace ::com::sun::star::sdb;
|
|
|
|
using namespace ::com::sun::star::sdbcx;
|
|
|
|
using namespace ::com::sun::star::container;
|
|
|
|
using namespace ::com::sun::star::lang;
|
|
|
|
using namespace ::cppu;
|
|
|
|
using namespace ::osl;
|
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
#define NOTIFY_COLUMN_VALUE_CHANGE() \
|
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny()); \
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x; \
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
extern "C" void SAL_CALL createRegistryInfo_ORowSet()
|
|
|
|
{
|
|
|
|
static OMultiInstanceAutoRegistration< ORowSet > aAutoRegistration;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Reference< XInterface > ORowSet_CreateInstance(const Reference< XMultiServiceFactory >& _rxFactory)
|
|
|
|
{
|
|
|
|
return *(new ORowSet(_rxFactory));
|
|
|
|
}
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
ORowSet::ORowSet(const Reference< ::com::sun::star::lang::XMultiServiceFactory >& _xFac)
|
|
|
|
: ORowSet_BASE1(m_aMutex)
|
|
|
|
, ORowSetBase(ORowSet_BASE1::rBHelper)
|
|
|
|
, m_xServiceManager(_xFac)
|
2000-10-17 09:19:03 +00:00
|
|
|
// ,m_pParseTree(NULL)
|
2000-09-18 23:16:46 +00:00
|
|
|
,m_nFetchDirection(FetchDirection::FORWARD)
|
|
|
|
,m_nFetchSize(1)
|
|
|
|
,m_nResultSetConcurrency(ResultSetConcurrency::UPDATABLE)
|
|
|
|
,m_nResultSetType(ResultSetType::SCROLL_INSENSITIVE)
|
|
|
|
,m_nCommandType(CommandType::COMMAND)
|
|
|
|
,m_nMaxFieldSize(0)
|
|
|
|
,m_nTransactionIsolation(0)
|
|
|
|
,m_nPrivileges(0)
|
|
|
|
,m_nAsyncUpdateRowCount(0)
|
|
|
|
,m_nMaxRows(0)
|
|
|
|
,m_nQueryTimeOut(0)
|
|
|
|
,m_bUseEscapeProcessing(sal_True)
|
|
|
|
,m_bApplyFilter(sal_False)
|
|
|
|
,m_bIgnoreResult(sal_False)
|
|
|
|
,m_bInserted(sal_False)
|
|
|
|
,m_bDeleted(sal_False)
|
|
|
|
,m_bUpdated(sal_False)
|
|
|
|
,m_bCreateStatement(sal_True)
|
|
|
|
,m_bCanceled(sal_False)
|
|
|
|
,m_bRowObsolete(sal_False)
|
|
|
|
,m_bModified(sal_False)
|
|
|
|
,m_bOwnsResultRow(sal_False)
|
|
|
|
,m_bRebuildConnOnExecute(sal_False)
|
|
|
|
,m_bNew(sal_False)
|
|
|
|
,m_bIsBookmarable(sal_True)
|
|
|
|
{
|
|
|
|
|
|
|
|
m_pMySelf = this;
|
|
|
|
m_aActiveConnection <<= m_xActiveConnection;
|
|
|
|
|
|
|
|
sal_Int32 nRBT = PropertyAttribute::READONLY | PropertyAttribute::BOUND | PropertyAttribute::TRANSIENT;
|
|
|
|
sal_Int32 nRT = PropertyAttribute::READONLY | PropertyAttribute::TRANSIENT;
|
|
|
|
sal_Int32 nBT = PropertyAttribute::BOUND | PropertyAttribute::TRANSIENT;
|
|
|
|
|
|
|
|
// sdb.RowSet Properties
|
|
|
|
registerMayBeVoidProperty(PROPERTY_ACTIVECONNECTION,PROPERTY_ID_ACTIVECONNECTION, PropertyAttribute::MAYBEVOID|PropertyAttribute::TRANSIENT, &m_aActiveConnection, ::getCppuType(reinterpret_cast< Reference< XConnection >* >(NULL)));
|
|
|
|
registerProperty(PROPERTY_DATASOURCENAME, PROPERTY_ID_DATASOURCENAME, PropertyAttribute::BOUND, &m_aDataSourceName, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_COMMAND, PROPERTY_ID_COMMAND, PropertyAttribute::BOUND, &m_aCommand, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_COMMANDTYPE, PROPERTY_ID_COMMANDTYPE, PropertyAttribute::BOUND, &m_nCommandType, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
2000-10-17 09:19:03 +00:00
|
|
|
registerProperty(PROPERTY_ACTIVECOMMAND, PROPERTY_ID_ACTIVECOMMAND, nRBT, &m_aActiveCommand, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
2000-09-18 23:16:46 +00:00
|
|
|
registerProperty(PROPERTY_IGNORERESULT, PROPERTY_ID_IGNORERESULT, PropertyAttribute::BOUND, &m_bIgnoreResult, ::getBooleanCppuType());
|
|
|
|
registerProperty(PROPERTY_FILTER, PROPERTY_ID_FILTER, PropertyAttribute::BOUND, &m_aFilter, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_APPLYFILTER, PROPERTY_ID_APPLYFILTER, PropertyAttribute::BOUND, &m_bApplyFilter, ::getBooleanCppuType());
|
|
|
|
registerProperty(PROPERTY_ORDER, PROPERTY_ID_ORDER, PropertyAttribute::BOUND, &m_aOrder, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_PRIVILEGES, PROPERTY_ID_PRIVILEGES, nRT, &m_nPrivileges, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
2000-09-29 14:23:36 +00:00
|
|
|
registerProperty(PROPERTY_ISMODIFIED, PROPERTY_ID_ISMODIFIED, nBT, &m_bModified, ::getBooleanCppuType());
|
2000-09-18 23:16:46 +00:00
|
|
|
registerProperty(PROPERTY_ISNEW, PROPERTY_ID_ISNEW, nRBT, &m_bNew, ::getBooleanCppuType());
|
|
|
|
|
|
|
|
|
|
|
|
// sdbcx.ResultSet Properties
|
|
|
|
registerProperty(PROPERTY_ISBOOKMARKABLE, PROPERTY_ID_ISBOOKMARKABLE, nRT, &m_bIsBookmarable, ::getBooleanCppuType());
|
|
|
|
|
|
|
|
// sdbc.ResultSet Properties
|
|
|
|
// registerProperty(PROPERTY_CURSORNAME, PROPERTY_ID_CURSORNAME, PropertyAttribute::READONLY, &m_aCursorName, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_RESULTSETCONCURRENCY, PROPERTY_ID_RESULTSETCONCURRENCY, PropertyAttribute::TRANSIENT, &m_nResultSetConcurrency,::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_RESULTSETTYPE, PROPERTY_ID_RESULTSETTYPE, PropertyAttribute::TRANSIENT, &m_nResultSetType, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_FETCHDIRECTION, PROPERTY_ID_FETCHDIRECTION, PropertyAttribute::TRANSIENT, &m_nFetchDirection, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_FETCHSIZE, PROPERTY_ID_FETCHSIZE, PropertyAttribute::TRANSIENT, &m_nFetchSize, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
|
|
|
|
// sdbc.RowSet Properties
|
|
|
|
registerProperty(PROPERTY_URL, PROPERTY_ID_URL, 0, &m_aURL, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_TRANSACTIONISOLATION, PROPERTY_ID_TRANSACTIONISOLATION, PropertyAttribute::TRANSIENT, &m_nTransactionIsolation,::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerMayBeVoidProperty(PROPERTY_TYPEMAP, PROPERTY_ID_TYPEMAP, PropertyAttribute::MAYBEVOID|PropertyAttribute::TRANSIENT, &m_aTypeMap, ::getCppuType(reinterpret_cast< Reference< XNameAccess >* >(NULL)));
|
|
|
|
registerProperty(PROPERTY_USE_ESCAPE_PROCESSING,PROPERTY_ID_USE_ESCAPE_PROCESSING, 0, &m_bUseEscapeProcessing,::getBooleanCppuType() );
|
|
|
|
registerProperty(PROPERTY_QUERYTIMEOUT, PROPERTY_ID_QUERYTIMEOUT, PropertyAttribute::TRANSIENT, &m_nQueryTimeOut, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_MAXFIELDSIZE, PROPERTY_ID_MAXFIELDSIZE, PropertyAttribute::TRANSIENT, &m_nMaxFieldSize, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_MAXROWS, PROPERTY_ID_MAXROWS, 0, &m_nMaxRows, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)) );
|
|
|
|
registerProperty(PROPERTY_USER, PROPERTY_ID_USER, PropertyAttribute::TRANSIENT, &m_aUser, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_PASSWORD, PROPERTY_ID_PASSWORD, 0, &m_aPassword, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
|
|
|
|
registerProperty(PROPERTY_ISINSERTONLY, PROPERTY_ID_ISINSERTONLY, PropertyAttribute::BOUND, &m_bIgnoreResult, ::getBooleanCppuType());
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-10-11 10:21:40 +00:00
|
|
|
// typedef ::comphelper::OPropertyArrayUsageHelper<ORowSet> ORowSet_Prop;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
void SAL_CALL ORowSet::setFastPropertyValue_NoBroadcast(sal_Int32 nHandle,const Any& rValue) throw (Exception)
|
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
switch(nHandle)
|
|
|
|
{
|
|
|
|
case PROPERTY_ID_ISMODIFIED:
|
2000-10-17 09:19:03 +00:00
|
|
|
m_bModified = cppu::any2bool(rValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
break;
|
|
|
|
default:
|
2000-10-05 08:37:27 +00:00
|
|
|
OPropertyContainer::setFastPropertyValue_NoBroadcast(nHandle,rValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
}
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
switch(nHandle)
|
|
|
|
{
|
|
|
|
case PROPERTY_ID_ACTIVECONNECTION:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
m_bRebuildConnOnExecute = sal_False;
|
2000-10-17 09:19:03 +00:00
|
|
|
m_aActiveConnection >>= m_xActiveConnection;
|
2000-09-18 23:16:46 +00:00
|
|
|
break;
|
|
|
|
case PROPERTY_ID_APPLYFILTER:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_COMMAND:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_COMMANDTYPE:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_DATASOURCENAME:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_FETCHSIZE:
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_FILTER:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_ORDER:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_URL:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_USER:
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
break;
|
2000-10-17 09:19:03 +00:00
|
|
|
case PROPERTY_ID_TYPEMAP:
|
|
|
|
m_aTypeMap >>= m_xTypeMap;
|
|
|
|
break;
|
2000-09-29 14:23:36 +00:00
|
|
|
default:
|
|
|
|
;
|
2000-09-18 23:16:46 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::getFastPropertyValue(Any& rValue,sal_Int32 nHandle) const
|
|
|
|
{
|
|
|
|
if(m_pCache)
|
|
|
|
{
|
|
|
|
switch(nHandle)
|
|
|
|
{
|
|
|
|
case PROPERTY_ID_ISMODIFIED:
|
2000-10-17 09:19:03 +00:00
|
|
|
rValue.setValue(&m_bModified,::getCppuBooleanType());
|
2000-09-18 23:16:46 +00:00
|
|
|
break;
|
|
|
|
case PROPERTY_ID_ISNEW:
|
2000-10-17 09:19:03 +00:00
|
|
|
rValue.setValue(&m_bNew,::getCppuBooleanType());
|
2000-09-18 23:16:46 +00:00
|
|
|
break;
|
|
|
|
case PROPERTY_ID_PRIVILEGES:
|
|
|
|
rValue <<= m_pCache->m_nPrivileges;
|
|
|
|
break;
|
2000-10-17 09:19:03 +00:00
|
|
|
case PROPERTY_ID_ACTIVECONNECTION:
|
|
|
|
rValue <<= m_xActiveConnection;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_TYPEMAP:
|
|
|
|
rValue <<= m_xTypeMap;
|
|
|
|
break;
|
2000-09-18 23:16:46 +00:00
|
|
|
default:
|
|
|
|
ORowSetBase::getFastPropertyValue(rValue,nHandle);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
else
|
2000-10-17 09:19:03 +00:00
|
|
|
{
|
|
|
|
switch(nHandle)
|
|
|
|
{
|
|
|
|
case PROPERTY_ID_ACTIVECONNECTION:
|
|
|
|
rValue <<= m_xActiveConnection;
|
|
|
|
break;
|
|
|
|
case PROPERTY_ID_TYPEMAP:
|
|
|
|
rValue <<= m_xTypeMap;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ORowSetBase::getFastPropertyValue(rValue,nHandle);
|
|
|
|
}
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// com::sun::star::lang::XTypeProvider
|
|
|
|
Sequence< Type > SAL_CALL ORowSet::getTypes() throw (RuntimeException)
|
|
|
|
{
|
|
|
|
OTypeCollection aTypes(::getCppuType( (const Reference< XPropertySet > *)0 ),
|
|
|
|
::getCppuType( (const Reference< XFastPropertySet > *)0 ),
|
|
|
|
::getCppuType( (const Reference< XMultiPropertySet > *)0 ),
|
2000-10-11 10:21:40 +00:00
|
|
|
::comphelper::concatSequences(ORowSet_BASE1::getTypes(),ORowSetBase::getTypes()));
|
2000-09-18 23:16:46 +00:00
|
|
|
return aTypes.getTypes();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Sequence< sal_Int8 > SAL_CALL ORowSet::getImplementationId() throw (RuntimeException)
|
|
|
|
{
|
|
|
|
static OImplementationId * pId = 0;
|
|
|
|
if (! pId)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard( Mutex::getGlobalMutex() );
|
|
|
|
if (! pId)
|
|
|
|
{
|
|
|
|
static OImplementationId aId;
|
|
|
|
pId = &aId;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return pId->getImplementationId();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// com::sun::star::uno::XInterface
|
|
|
|
Any SAL_CALL ORowSet::queryInterface( const Type & rType ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
return ORowSet_BASE1::queryInterface( rType);
|
|
|
|
// Any aRet(::cppu::queryInterface(rType,static_cast< XPropertySet * >( this )));
|
|
|
|
// if (!aRet.hasValue())
|
|
|
|
// {
|
|
|
|
// aRet = ORowSet_BASE1::queryInterface(rType);
|
|
|
|
// if (!aRet.hasValue())
|
|
|
|
// aRet = ORowSet_BASE2::queryInterface(rType);
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// return aRet;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::acquire() throw(RuntimeException)
|
|
|
|
{
|
|
|
|
ORowSet_BASE1::acquire();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::release() throw(RuntimeException)
|
|
|
|
{
|
|
|
|
ORowSet_BASE1::release();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// com::sun::star::lang::XUnoTunnel
|
|
|
|
sal_Int64 SAL_CALL ORowSet::getSomething( const Sequence< sal_Int8 >& rId ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (rId.getLength() == 16 && 0 == rtl_compareMemory(getImplementationId().getConstArray(), rId.getConstArray(), 16 ) )
|
|
|
|
return (sal_Int64)this;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// com::sun::star::uno::XAggregation
|
|
|
|
Any SAL_CALL ORowSet::queryAggregation( const Type& rType ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
Any aRet(ORowSetBase::queryInterface(rType));
|
|
|
|
if (!aRet.hasValue())
|
|
|
|
aRet = ORowSet_BASE1::queryAggregation(rType);
|
|
|
|
return aRet;
|
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
rtl::OUString ORowSet::getImplementationName_Static( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
return rtl::OUString::createFromAscii("com.sun.star.sdb.dbaccess.ORowSet");
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// ::com::sun::star::lang::XServiceInfo
|
|
|
|
::rtl::OUString SAL_CALL ORowSet::getImplementationName( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
return getImplementationName_Static();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ORowSet::supportsService( const ::rtl::OUString& _rServiceName ) throw(RuntimeException)
|
|
|
|
{
|
2000-10-11 10:21:40 +00:00
|
|
|
return ::comphelper::findValue(getSupportedServiceNames(), _rServiceName, sal_True).getLength() != 0;
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
Sequence< ::rtl::OUString > ORowSet::getSupportedServiceNames_Static( ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
Sequence< rtl::OUString > aSNS( 5 );
|
|
|
|
aSNS[0] = SERVICE_SDBC_RESULTSET;
|
|
|
|
aSNS[1] = SERVICE_SDBC_ROWSET;
|
|
|
|
aSNS[2] = SERVICE_SDBCX_RESULTSET;
|
|
|
|
aSNS[3] = SERVICE_SDB_RESULTSET;
|
|
|
|
aSNS[4] = SERVICE_SDB_ROWSET;
|
|
|
|
return aSNS;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Sequence< ::rtl::OUString > SAL_CALL ORowSet::getSupportedServiceNames( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
return getSupportedServiceNames_Static();
|
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
Reference< XInterface > ORowSet::Create(const Reference< XMultiServiceFactory >& _rxFactory)
|
|
|
|
{
|
|
|
|
return ORowSet_CreateInstance(_rxFactory);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// OComponentHelper
|
|
|
|
void SAL_CALL ORowSet::disposing(void)
|
|
|
|
{
|
2000-10-05 08:37:27 +00:00
|
|
|
OPropertyContainer::disposing();
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
MutexGuard aGuard(m_aMutex);
|
|
|
|
|
|
|
|
// just because we want to clear all see freeResources()
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
freeResources();
|
|
|
|
|
|
|
|
ORowSetBase::disposing();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::freeResources()
|
|
|
|
{
|
2000-09-18 23:16:46 +00:00
|
|
|
MutexGuard aGuard(m_aMutex);
|
|
|
|
|
|
|
|
// free all clones
|
|
|
|
for (connectivity::OWeakRefArray::iterator i = m_aClones.begin(); m_aClones.end() != i; i++)
|
|
|
|
{
|
|
|
|
Reference< XComponent > xComp(i->get(), UNO_QUERY);
|
|
|
|
if (xComp.is())
|
|
|
|
xComp->dispose();
|
|
|
|
}
|
|
|
|
m_aClones.clear();
|
2000-09-29 14:23:36 +00:00
|
|
|
if (m_bCreateStatement)
|
|
|
|
{
|
|
|
|
delete m_pCache;
|
|
|
|
m_pCache = NULL;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
if(m_pColumns)
|
|
|
|
{
|
|
|
|
m_pColumns->disposing();
|
|
|
|
DELETEZ(m_pColumns);
|
|
|
|
}
|
|
|
|
m_aBookmark = Any();
|
|
|
|
m_bBeforeFirst = sal_True;
|
|
|
|
m_bAfterLast = sal_False;
|
|
|
|
m_bRowCountFinal= sal_False;
|
2000-10-17 09:19:03 +00:00
|
|
|
m_bNew = sal_False;
|
|
|
|
m_bModified = sal_False;
|
2000-09-29 14:23:36 +00:00
|
|
|
m_nRowCount = 0;
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// ::com::sun::star::lang::XEventListener
|
|
|
|
void SAL_CALL ORowSet::disposing( const ::com::sun::star::lang::EventObject& Source ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
// close rowset because the connection is going to be deleted (someone told me :-)
|
|
|
|
close();
|
|
|
|
{
|
|
|
|
MutexGuard aGuard( m_aMutex );
|
|
|
|
// m_xActiveConnection = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// XCloseable
|
|
|
|
void SAL_CALL ORowSet::close( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if(m_pCache)
|
|
|
|
m_pCache->close();
|
|
|
|
{
|
|
|
|
MutexGuard aGuard( m_aMutex );
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
}
|
|
|
|
// additionals things to set
|
|
|
|
m_bCreateStatement = sal_True;
|
|
|
|
m_xStatement = NULL;
|
|
|
|
m_xComposer = NULL;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-10-11 10:21:40 +00:00
|
|
|
// comphelper::OPropertyArrayUsageHelper
|
2000-09-18 23:16:46 +00:00
|
|
|
::cppu::IPropertyArrayHelper* ORowSet::createArrayHelper( ) const
|
|
|
|
{
|
|
|
|
Sequence< Property > aProps;
|
|
|
|
describeProperties(aProps);
|
|
|
|
return new ::cppu::OPropertyArrayHelper(aProps);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// cppu::OPropertySetHelper
|
|
|
|
::cppu::IPropertyArrayHelper& SAL_CALL ORowSet::getInfoHelper()
|
|
|
|
{
|
2000-10-11 10:21:40 +00:00
|
|
|
typedef ::comphelper::OPropertyArrayUsageHelper<ORowSet> ORowSet_PROP;
|
2000-09-18 23:16:46 +00:00
|
|
|
return *ORowSet_PROP::getArrayHelper();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// XRowUpdate
|
|
|
|
void SAL_CALL ORowSet::updateNull( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateNull(columnIndex);
|
2000-09-29 14:23:36 +00:00
|
|
|
firePropertyChange(columnIndex-1 ,Any());
|
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateBoolean( sal_Int32 columnIndex, sal_Bool x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateBoolean(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateByte( sal_Int32 columnIndex, sal_Int8 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateByte(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateShort( sal_Int32 columnIndex, sal_Int16 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateShort(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateInt( sal_Int32 columnIndex, sal_Int32 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateInt(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateLong( sal_Int32 columnIndex, sal_Int64 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateLong(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateFloat( sal_Int32 columnIndex, float x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateFloat(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateDouble( sal_Int32 columnIndex, double x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateDouble(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateString( sal_Int32 columnIndex, const ::rtl::OUString& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateString(columnIndex,x);
|
2000-09-29 14:23:36 +00:00
|
|
|
// we have to notify all listeners
|
2000-10-04 12:34:40 +00:00
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateBytes( sal_Int32 columnIndex, const Sequence< sal_Int8 >& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateBytes(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateDate( sal_Int32 columnIndex, const ::com::sun::star::util::Date& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateDate(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateTime( sal_Int32 columnIndex, const ::com::sun::star::util::Time& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateTime(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateTimestamp( sal_Int32 columnIndex, const ::com::sun::star::util::DateTime& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateTimestamp(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateBinaryStream( sal_Int32 columnIndex, const Reference< ::com::sun::star::io::XInputStream >& x, sal_Int32 length ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateBinaryStream(columnIndex,x,length);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = makeAny(x);
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateCharacterStream( sal_Int32 columnIndex, const Reference< ::com::sun::star::io::XInputStream >& x, sal_Int32 length ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateCharacterStream(columnIndex,x,length);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = makeAny(x);
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateObject( sal_Int32 columnIndex, const Any& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateObject(columnIndex,x);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::updateNumericObject( sal_Int32 columnIndex, const Any& x, sal_Int32 scale ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-10-04 12:34:40 +00:00
|
|
|
Any aOldValue((*(*m_aCurrentRow))[columnIndex].makeAny());
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->updateNumericObject(columnIndex,x,scale);
|
2000-10-04 12:34:40 +00:00
|
|
|
// we have to notify all listeners
|
|
|
|
(*(*m_aCurrentRow))[columnIndex] = x;
|
|
|
|
firePropertyChange(columnIndex-1 ,aOldValue);
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_True,sal_False);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XInterface > SAL_CALL ORowSet::getStatement( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
return m_xStatement;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// XResultSetUpdate
|
|
|
|
void SAL_CALL ORowSet::insertRow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
2000-10-17 09:19:03 +00:00
|
|
|
if(m_bModified)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
// remember old value for fire
|
2000-10-17 09:19:03 +00:00
|
|
|
sal_Bool bOld = m_bNew;
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
RowChangeEvent aEvt(*this,RowChangeAction::INSERT,1);
|
|
|
|
notifyAllListenersRowBeforeChange(aEvt);
|
|
|
|
m_pCache->insertRow();
|
|
|
|
m_aBookmark = m_pCache->getBookmark();
|
|
|
|
m_aCurrentRow = m_pCache->m_aMatrixIter;
|
|
|
|
notifyAllListenersRowChanged(aEvt);
|
|
|
|
|
|
|
|
// fire PROPERTY_ID_ISNEW
|
2000-10-17 09:19:03 +00:00
|
|
|
if(m_bNew != bOld)
|
|
|
|
fireProperty(PROPERTY_ID_ISNEW,m_bNew,bOld);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
|
|
|
// fire property modified
|
2000-10-17 09:19:03 +00:00
|
|
|
if(!m_bModified)
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_False,sal_True);
|
|
|
|
fireRowcount();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-09-29 14:23:36 +00:00
|
|
|
sal_Int32 SAL_CALL ORowSet::getRow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aRowCountMutex );
|
|
|
|
// check if we are inserting a row
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
return 0;
|
|
|
|
return ORowSetBase::getRow();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-09-18 23:16:46 +00:00
|
|
|
void SAL_CALL ORowSet::updateRow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
2000-10-17 09:19:03 +00:00
|
|
|
if(m_bModified)
|
2000-09-29 14:23:36 +00:00
|
|
|
{
|
|
|
|
RowChangeEvent aEvt(*this,RowChangeAction::UPDATE,1);
|
|
|
|
notifyAllListenersRowBeforeChange(aEvt);
|
|
|
|
m_pCache->updateRow();
|
|
|
|
m_aBookmark = m_pCache->getBookmark();
|
|
|
|
m_aCurrentRow = m_pCache->m_aMatrixIter;
|
|
|
|
notifyAllListenersRowChanged(aEvt);
|
|
|
|
|
|
|
|
// fire property modified
|
2000-10-17 09:19:03 +00:00
|
|
|
if(!m_bModified)
|
2000-09-29 14:23:36 +00:00
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_False,sal_True);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::fireProperty(sal_Int32 _nProperty,sal_Bool _bNew,sal_Bool _bOld)
|
|
|
|
{
|
|
|
|
Any aNew = bool2any(_bNew);
|
|
|
|
Any aOld = bool2any(_bOld);
|
|
|
|
fire(&_nProperty, &aNew, &aOld, 1, sal_False );
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::deleteRow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
if(m_aBookmark.hasValue())
|
|
|
|
m_pCache->moveToBookmark(m_aBookmark);
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
RowChangeEvent aEvt(*this,RowChangeAction::DELETE,1);
|
2000-09-29 14:23:36 +00:00
|
|
|
notifyAllListenersRowBeforeChange(aEvt);
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->deleteRow();
|
2000-09-29 14:23:36 +00:00
|
|
|
m_aBookmark = Any();
|
|
|
|
m_aCurrentRow = NULL;
|
|
|
|
notifyAllListenersRowChanged(aEvt);
|
|
|
|
fireRowcount();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::cancelRowUpdates( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
m_pCache->cancelRowUpdates();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-09-29 14:23:36 +00:00
|
|
|
void SAL_CALL ORowSet::addRowSetListener( const Reference< XRowSetListener >& listener ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
m_aListeners.addInterface(listener);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::removeRowSetListener( const Reference< XRowSetListener >& listener ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
m_aListeners.removeInterface(listener);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::notifyAllListeners()
|
|
|
|
{
|
|
|
|
EventObject aEvt(*m_pMySelf);
|
|
|
|
OInterfaceIteratorHelper aIter(m_aListeners);
|
|
|
|
while (aIter.hasMoreElements())
|
|
|
|
((XRowSetListener*)aIter.next())->rowSetChanged(aEvt);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::notifyAllListenersCursorMoved()
|
|
|
|
{
|
|
|
|
EventObject aEvt(*m_pMySelf);
|
|
|
|
OInterfaceIteratorHelper aIter(m_aListeners);
|
|
|
|
while (aIter.hasMoreElements())
|
|
|
|
((XRowSetListener*)aIter.next())->cursorMoved(aEvt);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::notifyAllListenersRowChanged(const RowChangeEvent &rEvt)
|
|
|
|
{
|
|
|
|
OInterfaceIteratorHelper aIter(m_aListeners);
|
|
|
|
while (aIter.hasMoreElements())
|
|
|
|
((XRowSetListener*)aIter.next())->rowChanged(rEvt);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::notifyAllListenersCursorBeforeMove()
|
|
|
|
{
|
|
|
|
EventObject aEvt(*m_pMySelf);
|
|
|
|
OInterfaceIteratorHelper aIter(m_aApproveListeners);
|
|
|
|
while (aIter.hasMoreElements())
|
|
|
|
((XRowSetApproveListener*)aIter.next())->approveCursorMove(aEvt);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::notifyAllListenersRowBeforeChange(const RowChangeEvent &rEvt)
|
|
|
|
{
|
|
|
|
OInterfaceIteratorHelper aIter(m_aApproveListeners);
|
|
|
|
while (aIter.hasMoreElements())
|
|
|
|
((XRowSetApproveListener*)aIter.next())->approveRowChange(rEvt);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::fireRowcount()
|
|
|
|
{
|
|
|
|
if(m_nRowCount != m_pCache->m_nRowCount)
|
|
|
|
{
|
|
|
|
sal_Int32 nHandle = PROPERTY_ID_ROWCOUNT;
|
|
|
|
Any aNew,aOld;
|
|
|
|
aNew <<= m_pCache->m_nRowCount;aOld <<= m_nRowCount;
|
|
|
|
fire(&nHandle,&aNew,&aOld,1,sal_False);
|
|
|
|
m_nRowCount = m_pCache->m_nRowCount;
|
|
|
|
}
|
|
|
|
if(!m_bRowCountFinal && m_bRowCountFinal != m_pCache->m_bRowCountFinal)
|
|
|
|
{
|
|
|
|
sal_Int32 nHandle = PROPERTY_ID_ISROWCOUNTFINAL;
|
|
|
|
Any aNew,aOld;
|
|
|
|
aNew <<= bool2any(m_pCache->m_bRowCountFinal);
|
|
|
|
aOld <<= bool2any(m_bRowCountFinal);
|
|
|
|
fire(&nHandle,&aNew,&aOld,1,sal_False);
|
|
|
|
m_bRowCountFinal = m_pCache->m_bRowCountFinal;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-09-18 23:16:46 +00:00
|
|
|
void SAL_CALL ORowSet::moveToInsertRow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
2000-09-29 14:23:36 +00:00
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
// remember old value for fire
|
2000-09-29 14:23:36 +00:00
|
|
|
if(m_aBookmark.hasValue())
|
|
|
|
m_pCache->moveToBookmark(m_aBookmark);
|
|
|
|
|
|
|
|
ORowSetMatrix::iterator aOldValues = m_pCache->m_aMatrixIter; // remember the old values
|
|
|
|
|
2000-10-17 09:19:03 +00:00
|
|
|
sal_Bool bOld = m_bNew;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
notifyAllListenersCursorBeforeMove();
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->moveToInsertRow();
|
2000-09-29 14:23:36 +00:00
|
|
|
m_aCurrentRow = m_pCache->m_aInsertRow;
|
|
|
|
notifyAllListenersCursorMoved();
|
|
|
|
ORowSetBase::firePropertyChange(aOldValues);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
// fire PROPERTY_ID_ISNEW
|
2000-10-17 09:19:03 +00:00
|
|
|
if(m_bNew != bOld)
|
|
|
|
fireProperty(PROPERTY_ID_ISNEW,m_bNew,bOld);
|
2000-09-29 14:23:36 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::moveToCurrentRow( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
if(m_pCache->m_bInserted)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
if(m_aBookmark.hasValue())
|
|
|
|
m_pCache->moveToBookmark(m_aBookmark);
|
|
|
|
|
|
|
|
notifyAllListenersCursorBeforeMove();
|
|
|
|
m_pCache->moveToCurrentRow();
|
|
|
|
notifyAllListenersCursorMoved();
|
|
|
|
|
|
|
|
checkInsert();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-09-29 14:23:36 +00:00
|
|
|
// XRow
|
|
|
|
sal_Bool SAL_CALL ORowSet::wasNull( ) throw(SQLException, RuntimeException)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
2000-09-29 14:23:36 +00:00
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
return m_pCache->m_bInserted ? (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex].isNull() : ORowSetBase::wasNull();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::rtl::OUString SAL_CALL ORowSet::getString( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getString(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Bool SAL_CALL ORowSet::getBoolean( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getBoolean(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int8 SAL_CALL ORowSet::getByte( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getByte(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int16 SAL_CALL ORowSet::getShort( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getShort(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int32 SAL_CALL ORowSet::getInt( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getInt(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
sal_Int64 SAL_CALL ORowSet::getLong( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getLong(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
float SAL_CALL ORowSet::getFloat( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getFloat(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
double SAL_CALL ORowSet::getDouble( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getDouble(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Sequence< sal_Int8 > SAL_CALL ORowSet::getBytes( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getBytes(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::com::sun::star::util::Date SAL_CALL ORowSet::getDate( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getDate(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::com::sun::star::util::Time SAL_CALL ORowSet::getTime( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getTime(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
::com::sun::star::util::DateTime SAL_CALL ORowSet::getTimestamp( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
return (*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex];
|
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getTimestamp(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< ::com::sun::star::io::XInputStream > SAL_CALL ORowSet::getBinaryStream( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
2000-10-11 10:21:40 +00:00
|
|
|
return new ::comphelper::SequenceInputStream((*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex].getSequence());
|
2000-09-29 14:23:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getBinaryStream(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< ::com::sun::star::io::XInputStream > SAL_CALL ORowSet::getCharacterStream( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
2000-09-18 23:16:46 +00:00
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
2000-09-29 14:23:36 +00:00
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
2000-10-11 10:21:40 +00:00
|
|
|
return new ::comphelper::SequenceInputStream((*(*m_pCache->m_aInsertRow))[m_nLastColumnIndex = columnIndex].getSequence());
|
2000-09-29 14:23:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return ORowSetBase::getCharacterStream(columnIndex);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Any SAL_CALL ORowSet::getObject( sal_Int32 columnIndex, const Reference< XNameAccess >& typeMap ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
|
|
|
|
return Any();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XRef > SAL_CALL ORowSet::getRef( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
return Reference< XRef >();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
2000-09-29 14:23:36 +00:00
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XBlob > SAL_CALL ORowSet::getBlob( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
|
|
|
|
return Reference< XBlob >();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XClob > SAL_CALL ORowSet::getClob( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
|
|
|
|
return Reference< XClob >();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Reference< XArray > SAL_CALL ORowSet::getArray( sal_Int32 columnIndex ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*m_pMySelf);
|
|
|
|
|
|
|
|
return Reference< XArray >();
|
|
|
|
}
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// XRowSet
|
|
|
|
void SAL_CALL ORowSet::execute( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
// tell everybody that we will change the result set
|
|
|
|
EventObject aEvt(*this);
|
|
|
|
OInterfaceIteratorHelper aApproveIter(m_aApproveListeners);
|
|
|
|
while (aApproveIter.hasMoreElements())
|
|
|
|
{
|
|
|
|
if (!((XRowSetApproveListener*)aApproveIter.next())->approveRowSetChange(aEvt))
|
|
|
|
throw RowSetVetoException();
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
freeResources();
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
ClearableMutexGuard aGuard( m_aMutex );
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
// calc the connection to be used
|
|
|
|
if (m_xActiveConnection.is() && m_bRebuildConnOnExecute)
|
|
|
|
// there was a setProperty(ActiveConnection), but a setProperty(DataSource) _after_ that, too
|
|
|
|
m_xActiveConnection = NULL;
|
|
|
|
|
|
|
|
calcConnection();
|
|
|
|
|
|
|
|
m_bRebuildConnOnExecute = sal_False;
|
|
|
|
::rtl::OUString aSql;
|
|
|
|
// do we need a new statement
|
|
|
|
if (m_bCreateStatement)
|
|
|
|
{
|
|
|
|
// if we need a new statement we have to free the previous used columns
|
|
|
|
// m_aColumns.disposing();
|
|
|
|
m_xStatement = NULL;
|
|
|
|
m_xComposer = NULL;
|
|
|
|
|
|
|
|
// Build the statement
|
|
|
|
sal_Bool bUseEscapeProcessing;
|
|
|
|
m_aActiveCommand = getCommand(bUseEscapeProcessing);
|
|
|
|
if (m_aActiveCommand.len())
|
|
|
|
m_xStatement = m_xActiveConnection->prepareStatement(
|
|
|
|
aSql = getComposedQuery(m_aActiveCommand, bUseEscapeProcessing));
|
|
|
|
|
|
|
|
Reference<XPropertySet> xProp(m_xStatement,UNO_QUERY);
|
|
|
|
xProp->setPropertyValue(PROPERTY_RESULTSETTYPE,makeAny(m_nResultSetType));
|
|
|
|
xProp->setPropertyValue(PROPERTY_RESULTSETCONCURRENCY,makeAny(m_nResultSetConcurrency));
|
|
|
|
xProp->setPropertyValue(PROPERTY_FETCHDIRECTION,makeAny((sal_Int32)m_nFetchDirection));
|
|
|
|
|
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
Reference<XNameAccess> xTables;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
Reference< XTablesSupplier > xMasterTables(m_xActiveConnection,UNO_QUERY);
|
|
|
|
if(xMasterTables.is())
|
|
|
|
xTables = xMasterTables->getTables();
|
|
|
|
else
|
|
|
|
{
|
2000-10-17 09:19:03 +00:00
|
|
|
OTableContainer* pTables = new OTableContainer(*this,m_aMutex,m_xActiveConnection);
|
2000-09-29 14:23:36 +00:00
|
|
|
Sequence< ::rtl::OUString > a;
|
2000-10-17 09:19:03 +00:00
|
|
|
pTables->construct(a,a);
|
2000-09-29 14:23:36 +00:00
|
|
|
xTables = pTables;
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
Reference<XParameters> xParam(m_xStatement,UNO_QUERY);
|
|
|
|
sal_Int32 i = 1;
|
|
|
|
for(ORowVector< ORowSetValue >::const_iterator aIter = m_aParameterRow.begin(); aIter != m_aParameterRow.end();++aIter,++i)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
if(aIter->isNull())
|
|
|
|
xParam->setNull(i,aIter->getTypeKind());
|
|
|
|
else
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-09-29 14:23:36 +00:00
|
|
|
switch(aIter->getTypeKind())
|
|
|
|
{
|
|
|
|
case DataType::CHAR:
|
|
|
|
case DataType::VARCHAR:
|
|
|
|
xParam->setString(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::DOUBLE:
|
|
|
|
case DataType::FLOAT:
|
|
|
|
case DataType::REAL:
|
|
|
|
case DataType::DECIMAL:
|
|
|
|
case DataType::NUMERIC:
|
|
|
|
xParam->setDouble(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::DATE:
|
|
|
|
xParam->setDate(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::TIME:
|
|
|
|
xParam->setTime(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::TIMESTAMP:
|
|
|
|
xParam->setTimestamp(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::BINARY:
|
|
|
|
case DataType::VARBINARY:
|
|
|
|
case DataType::LONGVARBINARY:
|
|
|
|
case DataType::LONGVARCHAR:
|
|
|
|
xParam->setBytes(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::BIT:
|
|
|
|
xParam->setBoolean(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::TINYINT:
|
|
|
|
xParam->setByte(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::SMALLINT:
|
|
|
|
xParam->setShort(i,*aIter);
|
|
|
|
break;
|
|
|
|
case DataType::INTEGER:
|
|
|
|
xParam->setInt(i,*aIter);
|
|
|
|
break;
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
}
|
2000-09-29 14:23:36 +00:00
|
|
|
Reference< XResultSet> xRs = m_xStatement->executeQuery();
|
2000-10-17 09:19:03 +00:00
|
|
|
m_pCache = new ORowSetCache(xRs,m_xComposer,m_aUpdateTableName,m_bModified,m_bNew);
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
if(!m_xColumns.is())
|
|
|
|
{
|
2000-10-17 09:19:03 +00:00
|
|
|
OSL_ENSHURE(0,"HELLO!");
|
|
|
|
// Reference<XColumnsSupplier> xColSup(_xComposer,UNO_QUERY);
|
|
|
|
// Reference<XNameAccess> xSelColumns = xColSup->getColumns();
|
|
|
|
// ::vos::ORef<OSQLColumns> rColumns = m_pIterator->getSelectColumns();
|
|
|
|
// if(rColumns.isValid())
|
|
|
|
// {
|
|
|
|
// ORowSetDataColumns_COLLECTION aColumns;
|
|
|
|
// ::std::vector< ::rtl::OUString> aNames;
|
|
|
|
// sal_Int32 i=1;
|
|
|
|
// m_aCurrentRow = m_pCache->getIterator();
|
|
|
|
// for(OSQLColumns::const_iterator aIter = rColumns->begin();aIter != rColumns->end();++aIter,++i)
|
|
|
|
// {
|
|
|
|
// ORowSetDataColumn* pColumn = new ORowSetDataColumn(getMetaData(),this,this,i,m_aCurrentRow,m_pCache->getEnd());
|
|
|
|
// aColumns.push_back(pColumn);
|
|
|
|
// pColumn->setName(getMetaData()->getColumnName(i));
|
|
|
|
// aNames.push_back(pColumn->getName());
|
|
|
|
// }
|
|
|
|
// m_pColumns = new ORowSetDataColumns(m_xActiveConnection->getMetaData()->supportsMixedCaseQuotedIdentifiers(),
|
|
|
|
// aColumns,*this,m_aColumnsMutex,aNames);
|
|
|
|
// }
|
2000-09-29 14:23:36 +00:00
|
|
|
}
|
|
|
|
else
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
|
|
|
ORowSetDataColumns_COLLECTION aColumns;
|
|
|
|
::std::vector< ::rtl::OUString> aNames;
|
2000-09-29 14:23:36 +00:00
|
|
|
|
2000-10-17 09:19:03 +00:00
|
|
|
::rtl::OUString aDescription;
|
2000-09-29 14:23:36 +00:00
|
|
|
Sequence< ::rtl::OUString> aSeq = m_xColumns->getElementNames();
|
|
|
|
const ::rtl::OUString* pBegin = aSeq.getConstArray();
|
|
|
|
const ::rtl::OUString* pEnd = pBegin + aSeq.getLength();
|
|
|
|
for(sal_Int32 i=1;pBegin != pEnd ;++pBegin,++i)
|
2000-09-18 23:16:46 +00:00
|
|
|
{
|
2000-10-17 09:19:03 +00:00
|
|
|
Reference<XPropertySet> xColumn;
|
|
|
|
m_xColumns->getByName(*pBegin) >>= xColumn;
|
|
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_DESCRIPTION))
|
|
|
|
aDescription = comphelper::getString(xColumn->getPropertyValue(PROPERTY_DESCRIPTION));
|
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
ORowSetDataColumn* pColumn = new ORowSetDataColumn( getMetaData(),
|
|
|
|
this,
|
|
|
|
this,
|
|
|
|
i,
|
2000-10-17 09:19:03 +00:00
|
|
|
aDescription,
|
2000-09-29 14:23:36 +00:00
|
|
|
m_pCache->getIterator(),
|
|
|
|
m_pCache->getEnd());
|
2000-09-18 23:16:46 +00:00
|
|
|
aColumns.push_back(pColumn);
|
2000-09-29 14:23:36 +00:00
|
|
|
pColumn->setName(*pBegin);
|
|
|
|
aNames.push_back(*pBegin);
|
|
|
|
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_ALIGN,xColumn->getPropertyValue(PROPERTY_ALIGN));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_NUMBERFORMAT,xColumn->getPropertyValue(PROPERTY_NUMBERFORMAT));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_RELATIVEPOSITION,xColumn->getPropertyValue(PROPERTY_RELATIVEPOSITION));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_WIDTH,xColumn->getPropertyValue(PROPERTY_WIDTH));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_HIDDEN,xColumn->getPropertyValue(PROPERTY_HIDDEN));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_CONTROLMODEL,xColumn->getPropertyValue(PROPERTY_CONTROLMODEL));
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
m_pColumns = new ORowSetDataColumns(m_xActiveConnection->getMetaData()->supportsMixedCaseQuotedIdentifiers(),
|
|
|
|
aColumns,*this,m_aColumnsMutex,aNames);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
}
|
|
|
|
// notify the rowset listeners
|
2000-09-29 14:23:36 +00:00
|
|
|
notifyAllListeners();
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// XRowSetApproveBroadcaster
|
|
|
|
void SAL_CALL ORowSet::addRowSetApproveListener( const Reference< XRowSetApproveListener >& listener ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
m_aApproveListeners.addInterface(listener);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::removeRowSetApproveListener( const Reference< XRowSetApproveListener >& listener ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
m_aApproveListeners.removeInterface(listener);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// XResultSetAccess
|
|
|
|
Reference< XResultSet > SAL_CALL ORowSet::createResultSet( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
if(m_xStatement.is())
|
|
|
|
{
|
|
|
|
ORowSetClone* pClone = new ORowSetClone(*this);
|
|
|
|
Reference< XResultSet > xRet(pClone);
|
|
|
|
m_aClones.push_back(WeakReferenceHelper(xRet));
|
|
|
|
return xRet;
|
|
|
|
}
|
|
|
|
return Reference< XResultSet >();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// ::com::sun::star::util::XCancellable
|
|
|
|
void SAL_CALL ORowSet::cancel( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(m_pCache)
|
|
|
|
m_pCache->cancel();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// ::com::sun::star::sdbcx::XDeleteRows
|
|
|
|
Sequence< sal_Int32 > SAL_CALL ORowSet::deleteRows( const Sequence< Any >& rows ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
if(!m_pCache)
|
|
|
|
throw FunctionSequenceException(*this);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
RowChangeEvent aEvt(*this,RowChangeAction::DELETE,rows.getLength());
|
|
|
|
// notify the rowset listeners
|
2000-09-29 14:23:36 +00:00
|
|
|
notifyAllListenersRowBeforeChange(aEvt);
|
|
|
|
|
|
|
|
Sequence< sal_Int32 > aRet = m_pCache->deleteRows(rows);
|
|
|
|
const Any* pBegin = rows.getConstArray();
|
|
|
|
const Any* pEnd = pBegin + rows.getLength();
|
|
|
|
for(;pBegin != pEnd;++pBegin)
|
|
|
|
{
|
2000-10-11 10:21:40 +00:00
|
|
|
if(::comphelper::compare(*pBegin,m_aBookmark))
|
2000-09-29 14:23:36 +00:00
|
|
|
m_aBookmark = Any();
|
|
|
|
}
|
2000-09-18 23:16:46 +00:00
|
|
|
|
2000-09-29 14:23:36 +00:00
|
|
|
aEvt.Rows = aRet.getLength();
|
|
|
|
notifyAllListenersRowChanged(aEvt);
|
|
|
|
fireRowcount();
|
|
|
|
return aRet;
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
Reference< XConnection > ORowSet::calcConnection() throw( SQLException, RuntimeException )
|
|
|
|
{
|
|
|
|
MutexGuard aGuard(m_aMutex);
|
|
|
|
if (!m_xActiveConnection.is())
|
|
|
|
{
|
|
|
|
if (m_aDataSourceName.len())
|
|
|
|
{
|
|
|
|
// is it a file url?
|
|
|
|
Reference< ::com::sun::star::container::XNameAccess > xNamingContext(m_xServiceManager->createInstance(SERVICE_SDB_DATABASECONTEXT), UNO_QUERY);
|
|
|
|
if (xNamingContext.is() && xNamingContext->hasByName(m_aDataSourceName))
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
Reference< XDataSource > xDataSource(Reference< XNamingService > (xNamingContext, UNO_QUERY)->getRegisteredObject(m_aDataSourceName), UNO_QUERY);
|
|
|
|
if (xDataSource.is())
|
|
|
|
m_xActiveConnection = xDataSource->getConnection(m_aUser, m_aPassword);
|
|
|
|
}
|
|
|
|
catch (SQLException &e)
|
|
|
|
{
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
#ifdef DEBUG
|
|
|
|
Reference<XDriverManager> xMan(m_xServiceManager->createInstance(::rtl::OUString::createFromAscii("com.sun.star.sdbc.DriverManager")),UNO_QUERY);
|
2000-10-05 13:52:16 +00:00
|
|
|
Sequence<PropertyValue> aInfo(2);
|
2000-09-29 14:23:36 +00:00
|
|
|
aInfo[0].Name = ::rtl::OUString::createFromAscii("CharSet");
|
|
|
|
aInfo[0].Value <<= RTL_TEXTENCODING_IBM_850;
|
2000-10-05 13:52:16 +00:00
|
|
|
aInfo[1].Name = ::rtl::OUString::createFromAscii("Extension");
|
|
|
|
aInfo[1].Value <<= ::rtl::OUString::createFromAscii("txt");
|
2000-09-29 14:23:36 +00:00
|
|
|
|
2000-10-05 13:52:16 +00:00
|
|
|
m_xActiveConnection = xMan->getConnectionWithInfo(::rtl::OUString::createFromAscii("sdbc:flat:file:///G|/Office50/user/database/"),aInfo);
|
2000-09-18 23:16:46 +00:00
|
|
|
if(!m_xActiveConnection.is())
|
|
|
|
#endif
|
|
|
|
throw SQLException();
|
|
|
|
|
|
|
|
}
|
|
|
|
// {
|
|
|
|
// Reference< XDatabaseEnvironment > xEnvironment(m_xServiceManager->createInstance(SERVICE_SDB_DATABASEENVIRONMENT), UNO_QUERY);
|
|
|
|
// if (xEnvironment.is())
|
|
|
|
// {
|
|
|
|
// Reference< XDataSource > xDataSource(xEnvironment->getDatabaseAccess(m_aDataSourceName), UNO_QUERY);
|
|
|
|
// if (xDataSource.is())
|
|
|
|
// m_xActiveConnection = xDataSource->getConnection(m_aUser, m_aPassword);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
// else if (m_aURL.len())
|
|
|
|
// {
|
|
|
|
// Reference< XDatabaseEnvironment > xEnvironment(m_xServiceManager->createInstance(SERVICE_SDB_DATABASEENVIRONMENT), UNO_QUERY);
|
|
|
|
// if (xEnvironment.is())
|
|
|
|
// {
|
|
|
|
// if (m_aUser.len())
|
|
|
|
// {
|
|
|
|
// Sequence< PropertyValue > aInfo(2);
|
|
|
|
// aInfo.getArray()[0].Name = rtl::OUString::createFromAscii("User");
|
|
|
|
// aInfo.getArray()[0].Value <<= m_aUser;
|
|
|
|
// aInfo.getArray()[1].Name = rtl::OUString::createFromAscii("Password");
|
|
|
|
// aInfo.getArray()[1].Value <<= m_aPassword;
|
|
|
|
// m_xActiveConnection = xEnvironment->getConnectionWithInfo(m_aURL, aInfo);
|
|
|
|
// }
|
|
|
|
// else
|
|
|
|
// m_xActiveConnection = xEnvironment->getConnection(m_aURL);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
|
|
|
|
// listen if the connection disappears
|
|
|
|
Reference< XComponent > xComponent(m_xActiveConnection, UNO_QUERY);
|
|
|
|
if (xComponent.is())
|
|
|
|
xComponent->addEventListener(this);
|
|
|
|
}
|
|
|
|
return m_xActiveConnection;
|
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
rtl::OUString ORowSet::getCommand(sal_Bool& bEscapeProcessing)
|
|
|
|
{
|
|
|
|
// create the sql command
|
|
|
|
// from a table name or get the command out of a query (not a view)
|
|
|
|
// the last use the command as it is
|
|
|
|
bEscapeProcessing = m_bUseEscapeProcessing;
|
|
|
|
rtl::OUString aQuery;
|
|
|
|
if (m_aCommand.len())
|
|
|
|
{
|
|
|
|
switch (m_nCommandType)
|
|
|
|
{
|
|
|
|
case CommandType::TABLE:
|
|
|
|
{
|
|
|
|
Reference< XTablesSupplier > xTablesAccess(m_xActiveConnection, UNO_QUERY);
|
|
|
|
if (xTablesAccess.is())
|
|
|
|
{
|
|
|
|
Reference< ::com::sun::star::container::XNameAccess > xTables(xTablesAccess->getTables());
|
|
|
|
if (xTables->hasByName(m_aCommand))
|
|
|
|
{
|
|
|
|
Reference< XPropertySet > xTable;
|
|
|
|
xTables->getByName(m_aCommand) >>= xTable;
|
|
|
|
|
|
|
|
Reference<XColumnsSupplier> xSup(xTable,UNO_QUERY);
|
|
|
|
if(xSup.is())
|
|
|
|
m_xColumns = xSup->getColumns();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
aQuery = rtl::OUString::createFromAscii("SELECT * FROM ");
|
2000-10-11 10:21:40 +00:00
|
|
|
aQuery += ::dbtools::quoteTableName(m_xActiveConnection->getMetaData(), m_aCommand);
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case CommandType::QUERY:
|
|
|
|
{
|
|
|
|
Reference< XQueriesSupplier > xQueriesAccess(m_xActiveConnection, UNO_QUERY);
|
|
|
|
if (xQueriesAccess.is())
|
|
|
|
{
|
|
|
|
Reference< ::com::sun::star::container::XNameAccess > xQueries(xQueriesAccess->getQueries());
|
|
|
|
if (xQueries->hasByName(m_aCommand))
|
|
|
|
{
|
|
|
|
Reference< XPropertySet > xQuery;
|
|
|
|
xQueries->getByName(m_aCommand) >>= xQuery;
|
|
|
|
xQuery->getPropertyValue(PROPERTY_COMMAND) >>= aQuery;
|
|
|
|
bEscapeProcessing = any2bool(xQuery->getPropertyValue(PROPERTY_USE_ESCAPE_PROCESSING));
|
|
|
|
|
|
|
|
::rtl::OUString aCatalog,aSchema,aTable;
|
|
|
|
xQuery->getPropertyValue(CONFIGKEY_QRYDESCR_UPDATE_CATALOGNAME) >>= aCatalog;
|
|
|
|
xQuery->getPropertyValue(CONFIGKEY_QRYDESCR_UPDATE_SCHEMANAME) >>= aSchema;
|
|
|
|
xQuery->getPropertyValue(CONFIGKEY_QRYDESCR_UPDATE_TABLENAME) >>= aTable;
|
|
|
|
|
|
|
|
composeTableName(m_xActiveConnection->getMetaData(),aCatalog,aSchema,aTable,m_aUpdateTableName,sal_False);
|
|
|
|
|
|
|
|
Reference<XColumnsSupplier> xSup(xQuery,UNO_QUERY);
|
|
|
|
if(xSup.is())
|
|
|
|
m_xColumns = xSup->getColumns();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} break;
|
|
|
|
default:
|
|
|
|
aQuery = m_aCommand;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return aQuery;
|
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
rtl::OUString ORowSet::getComposedQuery(const rtl::OUString& rQuery, sal_Bool bEscapeProcessing) throw( SQLException, RuntimeException )
|
|
|
|
{
|
|
|
|
// use query composer to make a useful query with filter and/or order by part
|
|
|
|
rtl::OUString aFilterStatement = rQuery;
|
|
|
|
if (bEscapeProcessing)
|
|
|
|
{
|
|
|
|
Reference< XSQLQueryComposerFactory > xFactory(m_xActiveConnection, UNO_QUERY);
|
|
|
|
if (xFactory.is())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
m_xComposer = xFactory->createQueryComposer();
|
|
|
|
m_xComposer->setQuery(rQuery);
|
|
|
|
|
|
|
|
if (m_aFilter.len() && m_bApplyFilter)
|
|
|
|
m_xComposer->setFilter(m_aFilter);
|
|
|
|
if (m_aOrder.len())
|
|
|
|
m_xComposer->setOrder(m_aOrder);
|
|
|
|
|
|
|
|
aFilterStatement = m_xComposer->getComposedQuery();
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
|
|
|
m_xComposer = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return aFilterStatement;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// XParameters
|
|
|
|
void SAL_CALL ORowSet::setNull( sal_Int32 parameterIndex, sal_Int32 sqlType ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
|
|
|
|
m_aParameterRow[parameterIndex-1].setNull();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setObjectNull( sal_Int32 parameterIndex, sal_Int32 sqlType, const ::rtl::OUString& typeName ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1].setNull();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setBoolean( sal_Int32 parameterIndex, sal_Bool x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setByte( sal_Int32 parameterIndex, sal_Int8 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = (sal_Int32)x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setShort( sal_Int32 parameterIndex, sal_Int16 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = (sal_Int32)x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setInt( sal_Int32 parameterIndex, sal_Int32 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setLong( sal_Int32 parameterIndex, sal_Int64 x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setFloat( sal_Int32 parameterIndex, float x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setDouble( sal_Int32 parameterIndex, double x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setString( sal_Int32 parameterIndex, const ::rtl::OUString& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setBytes( sal_Int32 parameterIndex, const Sequence< sal_Int8 >& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setDate( sal_Int32 parameterIndex, const ::com::sun::star::util::Date& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setTime( sal_Int32 parameterIndex, const ::com::sun::star::util::Time& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setTimestamp( sal_Int32 parameterIndex, const ::com::sun::star::util::DateTime& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow[parameterIndex-1] = x;
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setBinaryStream( sal_Int32 parameterIndex, const Reference< ::com::sun::star::io::XInputStream >& x, sal_Int32 length ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
try
|
|
|
|
{
|
|
|
|
Sequence <sal_Int8> aData;
|
|
|
|
x->readBytes(aData, length);
|
|
|
|
m_aParameterRow[parameterIndex-1] = aData;
|
|
|
|
x->closeInput();
|
|
|
|
}
|
|
|
|
catch( ... )
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setCharacterStream( sal_Int32 parameterIndex, const Reference< ::com::sun::star::io::XInputStream >& x, sal_Int32 length ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
try
|
|
|
|
{
|
|
|
|
Sequence <sal_Int8> aData;
|
|
|
|
rtl::OUString aDataStr;
|
|
|
|
// the data is given as character data and the length defines the character length
|
|
|
|
sal_Int32 nSize = x->readBytes(aData, length * sizeof(sal_Unicode));
|
|
|
|
if (nSize / sizeof(sal_Unicode))
|
|
|
|
aDataStr = rtl::OUString((sal_Unicode*)aData.getConstArray(), nSize / sizeof(sal_Unicode));
|
|
|
|
m_aParameterRow[parameterIndex-1] = aDataStr;
|
|
|
|
m_aParameterRow[parameterIndex-1].setTypeKind(DataType::LONGVARCHAR);
|
|
|
|
x->closeInput();
|
|
|
|
}
|
|
|
|
catch( ... )
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setObject( sal_Int32 parameterIndex, const Any& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
if (x.getValueTypeClass() == TypeClass_ANY)
|
|
|
|
setObject(parameterIndex, Any(*(Any*)x.getValue()));
|
|
|
|
else
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
switch (x.getValueTypeClass())
|
|
|
|
{
|
|
|
|
case TypeClass_VOID:
|
|
|
|
setNull(parameterIndex, DataType::SQLNULL);
|
|
|
|
break;
|
|
|
|
case TypeClass_STRING:
|
|
|
|
setString(parameterIndex, *(rtl::OUString*)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_BOOLEAN:
|
|
|
|
setBoolean(parameterIndex, *(sal_Bool *)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_BYTE:
|
|
|
|
setByte(parameterIndex, *(sal_Int8 *)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_UNSIGNED_SHORT:
|
|
|
|
case TypeClass_SHORT:
|
|
|
|
setShort(parameterIndex, *(sal_Int16*)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_CHAR:
|
|
|
|
setShort(parameterIndex, *(sal_Int16*)(sal_Unicode *)x.getValue());//XXX
|
|
|
|
break;
|
|
|
|
case TypeClass_LONG:
|
|
|
|
case TypeClass_UNSIGNED_LONG:
|
|
|
|
setInt(parameterIndex, *(sal_Int32*)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_FLOAT:
|
|
|
|
setFloat(parameterIndex, *(float*)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_DOUBLE:
|
|
|
|
setDouble(parameterIndex, *(double*)x.getValue());
|
|
|
|
break;
|
|
|
|
case TypeClass_SEQUENCE:
|
|
|
|
if (x.getValueType() == ::getCppuType((const Sequence< sal_Int8 > *)0))
|
|
|
|
setBytes(parameterIndex, *(Sequence<sal_Int8>*)x.getValue());
|
|
|
|
else
|
|
|
|
throw IllegalArgumentException();
|
|
|
|
break;
|
|
|
|
case TypeClass_STRUCT:
|
|
|
|
case TypeClass_INTERFACE:
|
|
|
|
if (x.getValueType() == ::getCppuType(static_cast<Reference< ::com::sun::star::io::XInputStream>*>(NULL)))
|
|
|
|
{
|
|
|
|
Reference< ::com::sun::star::io::XInputStream > xStream;
|
|
|
|
x >>= xStream;
|
|
|
|
setBinaryStream(parameterIndex, xStream, xStream->available());
|
|
|
|
}
|
|
|
|
else if (x.getValueType() == ::getCppuType((const ::com::sun::star::util::DateTime*)0))
|
|
|
|
setTimestamp(parameterIndex, *(::com::sun::star::util::DateTime*)x.getValue());
|
|
|
|
else if (x.getValueType() == ::getCppuType((const ::com::sun::star::util::Date*)0))
|
|
|
|
setDate(parameterIndex, *(::com::sun::star::util::Date*)x.getValue());
|
|
|
|
else if (x.getValueType() == ::getCppuType((const ::com::sun::star::util::Time*)0))
|
|
|
|
setTime(parameterIndex, *(::com::sun::star::util::Time*)x.getValue());
|
|
|
|
else
|
|
|
|
throw SQLException();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch( ... )
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setObjectWithInfo( sal_Int32 parameterIndex, const Any& x, sal_Int32 targetSqlType, sal_Int32 scale ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
else if (parameterIndex < 1)
|
|
|
|
throw SQLException();
|
|
|
|
else if (m_aParameterRow.size() < parameterIndex)
|
|
|
|
m_aParameterRow.resize(parameterIndex);
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
setObject(parameterIndex, x);
|
|
|
|
m_aParameterRow[parameterIndex-1].setTypeKind(targetSqlType);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setRef( sal_Int32 parameterIndex, const Reference< XRef >& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setBlob( sal_Int32 parameterIndex, const Reference< XBlob >& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setClob( sal_Int32 parameterIndex, const Reference< XClob >& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::setArray( sal_Int32 parameterIndex, const Reference< XArray >& x ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
throw SQLException();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void SAL_CALL ORowSet::clearParameters( ) throw(SQLException, RuntimeException)
|
|
|
|
{
|
|
|
|
if (ORowSet_BASE1::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
|
|
|
|
::osl::MutexGuard aGuard( m_aColumnsMutex );
|
|
|
|
m_aParameterRow.clear();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
2000-09-29 14:23:36 +00:00
|
|
|
void ORowSet::firePropertyChange(sal_Int32 _nPos,const Any& _rOldValue)
|
|
|
|
{
|
|
|
|
Reference< ::com::sun::star::lang::XUnoTunnel> xTunnel;
|
|
|
|
if((m_pColumns->getByIndex(_nPos) >>= xTunnel) && xTunnel.is())
|
|
|
|
{
|
|
|
|
OColumn* pColumn = (OColumn*)xTunnel->getSomething(OColumn::getUnoTunnelImplementationId());
|
|
|
|
if(pColumn)
|
|
|
|
pColumn->fireValueChange(_rOldValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
void ORowSet::checkInsert()
|
|
|
|
{
|
|
|
|
if(m_pCache->m_bInserted)
|
|
|
|
{
|
|
|
|
m_pCache->cancelInsert();
|
|
|
|
fireProperty(PROPERTY_ID_ISMODIFIED,sal_False,sal_True);
|
|
|
|
fireProperty(PROPERTY_ID_ISNEW,sal_False,sal_True);
|
|
|
|
}
|
|
|
|
}
|
2000-10-17 11:21:45 +00:00
|
|
|
// ***********************************************************
|
2000-09-18 23:16:46 +00:00
|
|
|
// ORowSetClone
|
2000-10-17 11:21:45 +00:00
|
|
|
// ***********************************************************
|
2000-09-18 23:16:46 +00:00
|
|
|
DBG_NAME(ORowSetClone);
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
ORowSetClone::ORowSetClone(ORowSet& rParent)
|
|
|
|
:OSubComponent(m_aMutex, rParent)
|
|
|
|
,ORowSetBase(OComponentHelper::rBHelper)
|
|
|
|
,m_nFetchDirection(rParent.m_nFetchDirection)
|
|
|
|
,m_nFetchSize(rParent.m_nFetchSize)
|
|
|
|
,m_nResultSetConcurrency(ResultSetConcurrency::READ_ONLY)
|
|
|
|
,m_nResultSetType(rParent.m_nResultSetType)
|
|
|
|
|
|
|
|
,m_bDeleted(rParent.m_bDeleted)
|
|
|
|
,m_bRowObsolete(rParent.m_bRowObsolete)
|
|
|
|
,m_nPosition(rParent.m_nPosition)
|
|
|
|
,m_bIsBookmarable(sal_True)
|
|
|
|
{
|
|
|
|
DBG_CTOR(ORowSetClone, NULL);
|
|
|
|
|
|
|
|
m_pMySelf = this;
|
|
|
|
m_bClone = sal_True;
|
|
|
|
|
|
|
|
m_bBeforeFirst = rParent.m_bBeforeFirst;
|
|
|
|
m_bAfterLast = rParent.m_bAfterLast;
|
2000-10-17 09:19:03 +00:00
|
|
|
// m_pIterator = rParent.m_pIterator;
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache = rParent.m_pCache;
|
2000-09-29 14:23:36 +00:00
|
|
|
m_aBookmark = rParent.m_aBookmark;
|
2000-09-18 23:16:46 +00:00
|
|
|
|
|
|
|
// m_pCache = rParent.m_pCache->createClone();
|
|
|
|
|
|
|
|
ORowSetDataColumns_COLLECTION aColumns;
|
|
|
|
::std::vector< ::rtl::OUString> aNames;
|
|
|
|
|
2000-10-17 09:19:03 +00:00
|
|
|
::rtl::OUString aDescription;
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
Sequence< ::rtl::OUString> aSeq = rParent.m_pColumns->getElementNames();
|
|
|
|
const ::rtl::OUString* pBegin = aSeq.getConstArray();
|
|
|
|
const ::rtl::OUString* pEnd = pBegin + aSeq.getLength();
|
|
|
|
for(sal_Int32 i=1;pBegin != pEnd ;++pBegin,++i)
|
|
|
|
{
|
2000-10-17 09:19:03 +00:00
|
|
|
Reference<XPropertySet> xColumn;
|
|
|
|
rParent.m_pColumns->getByName(*pBegin) >>= xColumn;
|
|
|
|
if(xColumn->getPropertySetInfo()->hasPropertyByName(PROPERTY_DESCRIPTION))
|
|
|
|
aDescription = comphelper::getString(xColumn->getPropertyValue(PROPERTY_DESCRIPTION));
|
|
|
|
|
2000-09-18 23:16:46 +00:00
|
|
|
ORowSetColumn* pColumn = new ORowSetColumn( rParent.getMetaData(),
|
|
|
|
this,
|
|
|
|
i,
|
2000-10-17 09:19:03 +00:00
|
|
|
aDescription,
|
2000-09-18 23:16:46 +00:00
|
|
|
m_pCache->getIterator(),
|
|
|
|
m_pCache->getEnd());
|
|
|
|
aColumns.push_back(pColumn);
|
|
|
|
pColumn->setName(*pBegin);
|
|
|
|
aNames.push_back(*pBegin);
|
|
|
|
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_ALIGN,xColumn->getPropertyValue(PROPERTY_ALIGN));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_NUMBERFORMAT,xColumn->getPropertyValue(PROPERTY_NUMBERFORMAT));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_RELATIVEPOSITION,xColumn->getPropertyValue(PROPERTY_RELATIVEPOSITION));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_WIDTH,xColumn->getPropertyValue(PROPERTY_WIDTH));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_HIDDEN,xColumn->getPropertyValue(PROPERTY_HIDDEN));
|
|
|
|
pColumn->setFastPropertyValue_NoBroadcast(PROPERTY_ID_CONTROLMODEL,xColumn->getPropertyValue(PROPERTY_CONTROLMODEL));
|
|
|
|
|
|
|
|
}
|
|
|
|
m_pColumns = new ORowSetDataColumns(rParent.m_xActiveConnection->getMetaData()->supportsMixedCaseQuotedIdentifiers(),
|
|
|
|
aColumns,*this,m_aMutex,aNames);
|
|
|
|
|
|
|
|
sal_Int32 nRT = PropertyAttribute::READONLY | PropertyAttribute::TRANSIENT;
|
|
|
|
|
|
|
|
// sdb.RowSet Properties
|
|
|
|
// registerProperty(PROPERTY_CURSORNAME, PROPERTY_ID_CURSORNAME, PropertyAttribute::READONLY, &m_aDataSourceName, ::getCppuType(reinterpret_cast< ::rtl::OUString*>(NULL)));
|
|
|
|
|
|
|
|
registerProperty(PROPERTY_RESULTSETCONCURRENCY, PROPERTY_ID_RESULTSETCONCURRENCY, PropertyAttribute::READONLY, &m_nResultSetConcurrency,::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_RESULTSETTYPE, PROPERTY_ID_RESULTSETTYPE, PropertyAttribute::READONLY, &m_nResultSetType, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_FETCHDIRECTION, PROPERTY_ID_FETCHDIRECTION, PropertyAttribute::TRANSIENT, &m_nFetchDirection, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_FETCHSIZE, PROPERTY_ID_FETCHSIZE, PropertyAttribute::TRANSIENT, &m_nFetchSize, ::getCppuType(reinterpret_cast< sal_Int32*>(NULL)));
|
|
|
|
registerProperty(PROPERTY_ISBOOKMARKABLE, PROPERTY_ID_ISBOOKMARKABLE, nRT, &m_bIsBookmarable, ::getBooleanCppuType());
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
ORowSetClone::~ORowSetClone()
|
|
|
|
{
|
|
|
|
DBG_DTOR(ORowSetClone, NULL);
|
|
|
|
}
|
|
|
|
// com::sun::star::lang::XTypeProvider
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Sequence< Type > ORowSetClone::getTypes() throw (RuntimeException)
|
|
|
|
{
|
2000-10-11 10:21:40 +00:00
|
|
|
return ::comphelper::concatSequences(OSubComponent::getTypes(),ORowSetBase::getTypes());
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
// com::sun::star::uno::XInterface
|
|
|
|
//--------------------------------------------------------------------------
|
|
|
|
Any ORowSetClone::queryInterface( const Type & rType ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
Any aRet = ORowSetBase::queryInterface(rType);
|
|
|
|
if(!aRet.hasValue())
|
|
|
|
aRet = OSubComponent::queryInterface(rType);
|
|
|
|
return aRet;
|
|
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
void ORowSetClone::acquire() throw(::com::sun::star::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
OSubComponent::acquire();
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
void ORowSetClone::release() throw(::com::sun::star::uno::RuntimeException)
|
|
|
|
{
|
|
|
|
OSubComponent::release();
|
|
|
|
}
|
|
|
|
|
|
|
|
// XServiceInfo
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
rtl::OUString ORowSetClone::getImplementationName( ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
return rtl::OUString::createFromAscii("com.sun.star.sdb.ORowSetClone");
|
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
sal_Bool ORowSetClone::supportsService( const ::rtl::OUString& _rServiceName ) throw (RuntimeException)
|
|
|
|
{
|
2000-10-11 10:21:40 +00:00
|
|
|
return ::comphelper::findValue(getSupportedServiceNames(), _rServiceName, sal_True).getLength() != 0;
|
2000-09-18 23:16:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
Sequence< ::rtl::OUString > ORowSetClone::getSupportedServiceNames( ) throw (RuntimeException)
|
|
|
|
{
|
|
|
|
Sequence< ::rtl::OUString > aSNS( 2 );
|
|
|
|
aSNS[0] = SERVICE_SDBC_RESULTSET;
|
|
|
|
aSNS[1] = SERVICE_SDB_RESULTSET;
|
|
|
|
return aSNS;
|
|
|
|
}
|
|
|
|
|
|
|
|
// OComponentHelper
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
void ORowSetClone::disposing()
|
|
|
|
{
|
|
|
|
ORowSetBase::disposing();
|
|
|
|
OSubComponent::disposing();
|
|
|
|
}
|
|
|
|
|
|
|
|
// XCloseable
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
void ORowSetClone::close(void) throw( SQLException, RuntimeException )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MutexGuard aGuard( m_aMutex );
|
|
|
|
if (OComponentHelper::rBHelper.bDisposed)
|
|
|
|
throw DisposedException();
|
|
|
|
}
|
|
|
|
dispose();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
2000-10-11 10:21:40 +00:00
|
|
|
// comphelper::OPropertyArrayUsageHelper
|
2000-09-18 23:16:46 +00:00
|
|
|
::cppu::IPropertyArrayHelper* ORowSetClone::createArrayHelper( ) const
|
|
|
|
{
|
|
|
|
Sequence< Property > aProps;
|
|
|
|
describeProperties(aProps);
|
|
|
|
return new ::cppu::OPropertyArrayHelper(aProps);
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// cppu::OPropertySetHelper
|
|
|
|
::cppu::IPropertyArrayHelper& SAL_CALL ORowSetClone::getInfoHelper()
|
|
|
|
{
|
2000-10-11 10:21:40 +00:00
|
|
|
typedef ::comphelper::OPropertyArrayUsageHelper<ORowSetClone> ORowSetClone_PROP;
|
2000-09-18 23:16:46 +00:00
|
|
|
return *ORowSetClone_PROP::getArrayHelper();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
Sequence< sal_Int8 > SAL_CALL ORowSetClone::getImplementationId() throw (RuntimeException)
|
|
|
|
{
|
|
|
|
static OImplementationId * pId = 0;
|
|
|
|
if (! pId)
|
|
|
|
{
|
|
|
|
MutexGuard aGuard( Mutex::getGlobalMutex() );
|
|
|
|
if (! pId)
|
|
|
|
{
|
|
|
|
static OImplementationId aId;
|
|
|
|
pId = &aId;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return pId->getImplementationId();
|
|
|
|
}
|
|
|
|
// -------------------------------------------------------------------------
|
|
|
|
// com::sun::star::lang::XUnoTunnel
|
|
|
|
sal_Int64 SAL_CALL ORowSetClone::getSomething( const Sequence< sal_Int8 >& rId ) throw(RuntimeException)
|
|
|
|
{
|
|
|
|
if (rId.getLength() == 16 && 0 == rtl_compareMemory(getImplementationId().getConstArray(), rId.getConstArray(), 16 ) )
|
|
|
|
return (sal_Int64)this;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|