Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #include <resultset.hxx>
21 : #include "dbastrings.hrc"
22 : #include "apitools.hxx"
23 : #include <com/sun/star/lang/DisposedException.hpp>
24 : #include <com/sun/star/sdbc/ResultSetType.hpp>
25 : #include <cppuhelper/typeprovider.hxx>
26 : #include <comphelper/property.hxx>
27 : #include <comphelper/sequence.hxx>
28 : #include <comphelper/types.hxx>
29 : #include <tools/debug.hxx>
30 : #include <tools/diagnose_ex.h>
31 : #include <datacolumn.hxx>
32 : #include <com/sun/star/beans/PropertyAttribute.hpp>
33 : #include <connectivity/dbexception.hxx>
34 : #include <connectivity/dbtools.hxx>
35 : #include <cppuhelper/exc_hlp.hxx>
36 : #include <osl/thread.h>
37 : #include <rtl/logfile.hxx>
38 :
39 :
40 : using namespace ::com::sun::star::sdbc;
41 : using namespace ::com::sun::star::sdbcx;
42 : using namespace ::com::sun::star::beans;
43 : using namespace ::com::sun::star::uno;
44 : using namespace ::com::sun::star::lang;
45 : using namespace ::com::sun::star::container;
46 : using namespace ::cppu;
47 : using namespace ::osl;
48 : using namespace dbaccess;
49 : using namespace dbtools;
50 :
51 : DBG_NAME(OResultSet)
52 :
53 0 : OResultSet::OResultSet(const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSet >& _xResultSet,
54 : const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _xStatement,
55 : sal_Bool _bCaseSensitive)
56 : :OResultSetBase(m_aMutex)
57 : ,OPropertySetHelper(OResultSetBase::rBHelper)
58 : ,m_xDelegatorResultSet(_xResultSet)
59 : ,m_aWarnings( Reference< XWarningsSupplier >( _xResultSet, UNO_QUERY ) )
60 0 : ,m_bIsBookmarkable(sal_False)
61 : {
62 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::OResultSet" );
63 : DBG_CTOR(OResultSet, NULL);
64 :
65 0 : m_pColumns = new OColumns(*this, m_aMutex, _bCaseSensitive, ::std::vector< ::rtl::OUString>(), NULL,NULL);
66 :
67 : try
68 : {
69 0 : m_aStatement = _xStatement;
70 0 : m_xDelegatorResultSetUpdate = m_xDelegatorResultSetUpdate.query( m_xDelegatorResultSet );
71 0 : m_xDelegatorRow = m_xDelegatorRow.query( m_xDelegatorResultSet );
72 0 : m_xDelegatorRowUpdate = m_xDelegatorRowUpdate.query( m_xDelegatorResultSet );
73 :
74 0 : Reference< XPropertySet > xSet(m_xDelegatorResultSet, UNO_QUERY);
75 0 : xSet->getPropertyValue(PROPERTY_RESULTSETTYPE) >>= m_nResultSetType;
76 0 : xSet->getPropertyValue(PROPERTY_RESULTSETCONCURRENCY) >>= m_nResultSetConcurrency;
77 :
78 : // test for Bookmarks
79 0 : if (ResultSetType::FORWARD_ONLY != m_nResultSetType)
80 : {
81 0 : Reference <XPropertySetInfo > xInfo(xSet->getPropertySetInfo());
82 0 : if (xInfo->hasPropertyByName(PROPERTY_ISBOOKMARKABLE))
83 : {
84 0 : m_bIsBookmarkable = ::comphelper::getBOOL(xSet->getPropertyValue(PROPERTY_ISBOOKMARKABLE));
85 : OSL_ENSURE( !m_bIsBookmarkable || Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY).is(),
86 : "OResultSet::OResultSet: aggregate is inconsistent in it's bookmarkable attribute!" );
87 0 : m_bIsBookmarkable = m_bIsBookmarkable && Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY).is();
88 0 : }
89 0 : }
90 : }
91 0 : catch(Exception&)
92 : {
93 : }
94 0 : }
95 :
96 0 : OResultSet::~OResultSet()
97 : {
98 0 : m_pColumns->acquire();
99 0 : m_pColumns->disposing();
100 0 : delete m_pColumns;
101 :
102 : DBG_DTOR(OResultSet, NULL);
103 0 : }
104 :
105 : // com::sun::star::lang::XTypeProvider
106 0 : Sequence< Type > OResultSet::getTypes() throw (RuntimeException)
107 : {
108 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getTypes" );
109 0 : OTypeCollection aTypes(::getCppuType( (const Reference< XPropertySet > *)0 ),
110 0 : OResultSetBase::getTypes());
111 :
112 0 : return aTypes.getTypes();
113 : }
114 :
115 0 : Sequence< sal_Int8 > OResultSet::getImplementationId() throw (RuntimeException)
116 : {
117 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getImplementationId" );
118 : static OImplementationId * pId = 0;
119 0 : if (! pId)
120 : {
121 0 : MutexGuard aGuard( Mutex::getGlobalMutex() );
122 0 : if (! pId)
123 : {
124 0 : static OImplementationId aId;
125 0 : pId = &aId;
126 0 : }
127 : }
128 0 : return pId->getImplementationId();
129 : }
130 :
131 : // com::sun::star::uno::XInterface
132 0 : Any OResultSet::queryInterface( const Type & rType ) throw (RuntimeException)
133 : {
134 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::queryInterface" );
135 0 : Any aIface = OResultSetBase::queryInterface( rType );
136 0 : if (!aIface.hasValue())
137 : aIface = ::cppu::queryInterface(
138 : rType,
139 0 : static_cast< XPropertySet * >( this ));
140 :
141 0 : return aIface;
142 : }
143 :
144 0 : void OResultSet::acquire() throw ()
145 : {
146 0 : OResultSetBase::acquire();
147 0 : }
148 :
149 0 : void OResultSet::release() throw ()
150 : {
151 0 : OResultSetBase::release();
152 0 : }
153 :
154 :
155 : // OResultSetBase
156 0 : void OResultSet::disposing()
157 : {
158 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::disposing" );
159 0 : OPropertySetHelper::disposing();
160 :
161 0 : MutexGuard aGuard(m_aMutex);
162 :
163 : // free the columns
164 0 : m_pColumns->disposing();
165 :
166 : // close the pending result set
167 0 : Reference< XCloseable > (m_xDelegatorResultSet, UNO_QUERY)->close();
168 :
169 0 : m_xDelegatorResultSet = NULL;
170 0 : m_xDelegatorRow = NULL;
171 0 : m_xDelegatorRowUpdate = NULL;
172 :
173 0 : m_aStatement = Reference< XInterface >();
174 0 : }
175 :
176 : // XCloseable
177 0 : void OResultSet::close(void) throw( SQLException, RuntimeException )
178 : {
179 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::close" );
180 : {
181 0 : MutexGuard aGuard( m_aMutex );
182 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
183 : }
184 0 : dispose();
185 0 : }
186 :
187 : // XServiceInfo
188 0 : rtl::OUString OResultSet::getImplementationName( ) throw(RuntimeException)
189 : {
190 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getImplementationName" );
191 0 : return rtl::OUString("com.sun.star.sdb.OResultSet");
192 : }
193 :
194 0 : sal_Bool OResultSet::supportsService( const ::rtl::OUString& _rServiceName ) throw (RuntimeException)
195 : {
196 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::supportsService" );
197 0 : return ::comphelper::findValue(getSupportedServiceNames(), _rServiceName, sal_True).getLength() != 0;
198 : }
199 :
200 0 : Sequence< ::rtl::OUString > OResultSet::getSupportedServiceNames( ) throw (RuntimeException)
201 : {
202 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getSupportedServiceNames" );
203 0 : Sequence< ::rtl::OUString > aSNS( 2 );
204 0 : aSNS[0] = SERVICE_SDBC_RESULTSET;
205 0 : aSNS[1] = SERVICE_SDB_RESULTSET;
206 0 : return aSNS;
207 : }
208 :
209 : // com::sun::star::beans::XPropertySet
210 0 : Reference< XPropertySetInfo > OResultSet::getPropertySetInfo() throw (RuntimeException)
211 : {
212 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getPropertySetInfo" );
213 0 : return createPropertySetInfo( getInfoHelper() ) ;
214 : }
215 :
216 : // comphelper::OPropertyArrayUsageHelper
217 0 : ::cppu::IPropertyArrayHelper* OResultSet::createArrayHelper( ) const
218 : {
219 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::createArrayHelper" );
220 0 : BEGIN_PROPERTY_HELPER(6)
221 0 : DECL_PROP1(CURSORNAME, ::rtl::OUString, READONLY);
222 0 : DECL_PROP0(FETCHDIRECTION, sal_Int32);
223 0 : DECL_PROP0(FETCHSIZE, sal_Int32);
224 0 : DECL_PROP1_BOOL(ISBOOKMARKABLE, READONLY);
225 0 : DECL_PROP1(RESULTSETCONCURRENCY, sal_Int32, READONLY);
226 0 : DECL_PROP1(RESULTSETTYPE, sal_Int32, READONLY);
227 0 : END_PROPERTY_HELPER();
228 : }
229 :
230 : // cppu::OPropertySetHelper
231 0 : ::cppu::IPropertyArrayHelper& OResultSet::getInfoHelper()
232 : {
233 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getInfoHelper" );
234 0 : return *getArrayHelper();
235 : }
236 :
237 0 : sal_Bool OResultSet::convertFastPropertyValue(Any & rConvertedValue, Any & rOldValue, sal_Int32 nHandle, const Any& rValue ) throw( IllegalArgumentException )
238 : {
239 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::convertFastPropertyValue" );
240 : // be lazy ...
241 0 : rConvertedValue = rValue;
242 0 : getFastPropertyValue( rOldValue, nHandle );
243 0 : return sal_True;
244 : }
245 :
246 0 : void OResultSet::setFastPropertyValue_NoBroadcast( sal_Int32 nHandle, const Any& rValue ) throw (Exception)
247 : {
248 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::setFastPropertyValue_NoBroadcast" );
249 : // set it for the driver result set
250 0 : Reference< XPropertySet > xSet(m_xDelegatorResultSet, UNO_QUERY);
251 0 : switch (nHandle)
252 : {
253 : case PROPERTY_ID_FETCHDIRECTION:
254 0 : xSet->setPropertyValue(PROPERTY_FETCHDIRECTION, rValue);
255 0 : break;
256 : case PROPERTY_ID_FETCHSIZE:
257 0 : xSet->setPropertyValue(PROPERTY_FETCHSIZE, rValue);
258 0 : break;
259 : default:
260 : OSL_FAIL("unknown Property");
261 0 : }
262 0 : }
263 :
264 0 : void OResultSet::getFastPropertyValue( Any& rValue, sal_Int32 nHandle ) const
265 : {
266 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getFastPropertyValue" );
267 0 : switch (nHandle)
268 : {
269 : case PROPERTY_ID_ISBOOKMARKABLE:
270 : {
271 0 : sal_Bool bVal = m_bIsBookmarkable;
272 0 : rValue.setValue(&bVal, getBooleanCppuType());
273 0 : } break;
274 : default:
275 : {
276 : // get the property name
277 0 : ::rtl::OUString aPropName;
278 : sal_Int16 nAttributes;
279 0 : const_cast<OResultSet*>(this)->getInfoHelper().
280 0 : fillPropertyMembersByHandle(&aPropName, &nAttributes, nHandle);
281 : OSL_ENSURE(!aPropName.isEmpty(), "property not found?");
282 :
283 : // now read the value
284 0 : rValue = Reference< XPropertySet >(m_xDelegatorResultSet, UNO_QUERY)->getPropertyValue(aPropName);
285 : }
286 : }
287 0 : }
288 :
289 : // XWarningsSupplier
290 0 : Any OResultSet::getWarnings(void) throw( SQLException, RuntimeException )
291 : {
292 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getWarnings" );
293 0 : MutexGuard aGuard(m_aMutex);
294 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
295 0 : return m_aWarnings.getWarnings();
296 : }
297 :
298 0 : void OResultSet::clearWarnings(void) throw( SQLException, RuntimeException )
299 : {
300 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::clearWarnings" );
301 0 : MutexGuard aGuard(m_aMutex);
302 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
303 0 : m_aWarnings.clearWarnings();
304 0 : }
305 :
306 : // ::com::sun::star::sdbc::XResultSetMetaDataSupplier
307 0 : Reference< XResultSetMetaData > OResultSet::getMetaData(void) throw( SQLException, RuntimeException )
308 : {
309 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getMetaData" );
310 0 : MutexGuard aGuard(m_aMutex);
311 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
312 :
313 0 : return Reference< XResultSetMetaDataSupplier >(m_xDelegatorResultSet, UNO_QUERY)->getMetaData();
314 : }
315 :
316 : // ::com::sun::star::sdbc::XColumnLocate
317 0 : sal_Int32 OResultSet::findColumn(const rtl::OUString& columnName) throw( SQLException, RuntimeException )
318 : {
319 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::findColumn" );
320 0 : MutexGuard aGuard(m_aMutex);
321 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
322 :
323 0 : return Reference< XColumnLocate >(m_xDelegatorResultSet, UNO_QUERY)->findColumn(columnName);
324 : }
325 :
326 : namespace
327 : {
328 0 : static Reference< XDatabaseMetaData > lcl_getDBMetaDataFromStatement_nothrow( const Reference< XInterface >& _rxStatement )
329 : {
330 0 : Reference< XDatabaseMetaData > xDBMetaData;
331 : try
332 : {
333 0 : Reference< XStatement > xStatement( _rxStatement, UNO_QUERY );
334 0 : Reference< XPreparedStatement > xPreparedStatement( _rxStatement, UNO_QUERY );
335 0 : Reference< XConnection > xConn;
336 0 : if ( xStatement.is() )
337 0 : xConn = xStatement->getConnection();
338 0 : else if ( xPreparedStatement.is() )
339 0 : xConn = xPreparedStatement->getConnection();
340 0 : if ( xConn.is() )
341 0 : xDBMetaData = xConn->getMetaData();
342 : }
343 0 : catch( const Exception& )
344 : {
345 : DBG_UNHANDLED_EXCEPTION();
346 : }
347 0 : return xDBMetaData;
348 : }
349 : }
350 :
351 : // ::com::sun::star::sdbcx::XColumnsSupplier
352 0 : Reference< ::com::sun::star::container::XNameAccess > OResultSet::getColumns(void) throw( RuntimeException )
353 : {
354 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getColumns" );
355 0 : MutexGuard aGuard(m_aMutex);
356 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
357 :
358 : // do we have to populate the columns
359 0 : if (!m_pColumns->isInitialized())
360 : {
361 : // get the metadata
362 0 : Reference< XResultSetMetaData > xMetaData = Reference< XResultSetMetaDataSupplier >(m_xDelegatorResultSet, UNO_QUERY)->getMetaData();
363 :
364 0 : sal_Int32 nColCount = 0;
365 : // do we have columns
366 : try
367 : {
368 0 : Reference< XDatabaseMetaData > xDBMetaData( lcl_getDBMetaDataFromStatement_nothrow( getStatement() ) );
369 0 : nColCount = xMetaData->getColumnCount();
370 :
371 0 : for ( sal_Int32 i = 0; i < nColCount; ++i)
372 : {
373 : // retrieve the name of the column
374 0 : rtl::OUString sName = xMetaData->getColumnName(i + 1);
375 0 : ODataColumn* pColumn = new ODataColumn(xMetaData, m_xDelegatorRow, m_xDelegatorRowUpdate, i + 1, xDBMetaData);
376 :
377 : // don't silently assume that the name is unique - result set implementations
378 : // are allowed to return duplicate names, but we are required to have
379 : // unique column names
380 0 : if ( m_pColumns->hasByName( sName ) )
381 0 : sName = ::dbtools::createUniqueName( m_pColumns, sName );
382 :
383 0 : m_pColumns->append( sName, pColumn );
384 0 : }
385 : }
386 0 : catch ( const SQLException& )
387 : {
388 : DBG_UNHANDLED_EXCEPTION();
389 : }
390 0 : m_pColumns->setInitialized();
391 :
392 : #if OSL_DEBUG_LEVEL > 0
393 : // some sanity checks. Especially in case we auto-adjusted the column names above,
394 : // this might be reasonable
395 : try
396 : {
397 : const Reference< XNameAccess > xColNames( static_cast< XNameAccess* >( m_pColumns ), UNO_SET_THROW );
398 : const Sequence< ::rtl::OUString > aNames( xColNames->getElementNames() );
399 : OSL_POSTCOND( aNames.getLength() == nColCount,
400 : "OResultSet::getColumns: invalid column count!" );
401 : for ( const ::rtl::OUString* pName = aNames.getConstArray();
402 : pName != aNames.getConstArray() + aNames.getLength();
403 : ++pName
404 : )
405 : {
406 : Reference< XPropertySet > xColProps( xColNames->getByName( *pName ), UNO_QUERY_THROW );
407 : ::rtl::OUString sName;
408 : OSL_VERIFY( xColProps->getPropertyValue( PROPERTY_NAME ) >>= sName );
409 : OSL_POSTCOND( sName == *pName, "OResultSet::getColumns: invalid column name!" );
410 : }
411 :
412 : }
413 : catch( const Exception& )
414 : {
415 : DBG_UNHANDLED_EXCEPTION();
416 : }
417 : #endif
418 : }
419 0 : return m_pColumns;
420 : }
421 :
422 : // ::com::sun::star::sdbc::XRow
423 0 : sal_Bool OResultSet::wasNull(void) throw( SQLException, RuntimeException )
424 : {
425 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::wasNull" );
426 0 : MutexGuard aGuard(m_aMutex);
427 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
428 :
429 0 : return m_xDelegatorRow->wasNull();
430 : }
431 :
432 0 : rtl::OUString OResultSet::getString(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
433 : {
434 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getString" );
435 0 : MutexGuard aGuard(m_aMutex);
436 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
437 :
438 0 : return m_xDelegatorRow->getString(columnIndex);
439 : }
440 :
441 0 : sal_Bool OResultSet::getBoolean(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
442 : {
443 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getBoolean" );
444 0 : MutexGuard aGuard(m_aMutex);
445 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
446 :
447 0 : return m_xDelegatorRow->getBoolean(columnIndex);
448 : }
449 :
450 0 : sal_Int8 OResultSet::getByte(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
451 : {
452 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getByte" );
453 0 : MutexGuard aGuard(m_aMutex);
454 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
455 :
456 0 : return m_xDelegatorRow->getByte(columnIndex);
457 : }
458 :
459 0 : sal_Int16 OResultSet::getShort(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
460 : {
461 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getShort" );
462 0 : MutexGuard aGuard(m_aMutex);
463 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
464 :
465 0 : return m_xDelegatorRow->getShort(columnIndex);
466 : }
467 :
468 0 : sal_Int32 OResultSet::getInt(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
469 : {
470 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getInt" );
471 0 : MutexGuard aGuard(m_aMutex);
472 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
473 :
474 0 : return m_xDelegatorRow->getInt(columnIndex);
475 : }
476 :
477 0 : sal_Int64 OResultSet::getLong(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
478 : {
479 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getLong" );
480 0 : MutexGuard aGuard(m_aMutex);
481 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
482 :
483 0 : return m_xDelegatorRow->getLong(columnIndex);
484 : }
485 :
486 0 : float OResultSet::getFloat(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
487 : {
488 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getFloat" );
489 0 : MutexGuard aGuard(m_aMutex);
490 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
491 :
492 0 : return m_xDelegatorRow->getFloat(columnIndex);
493 : }
494 :
495 0 : double OResultSet::getDouble(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
496 : {
497 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getDouble" );
498 0 : MutexGuard aGuard(m_aMutex);
499 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
500 :
501 0 : return m_xDelegatorRow->getDouble(columnIndex);
502 : }
503 :
504 0 : Sequence< sal_Int8 > OResultSet::getBytes(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
505 : {
506 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getBytes" );
507 0 : MutexGuard aGuard(m_aMutex);
508 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
509 :
510 0 : return m_xDelegatorRow->getBytes(columnIndex);
511 : }
512 :
513 0 : ::com::sun::star::util::Date OResultSet::getDate(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
514 : {
515 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getDate" );
516 0 : MutexGuard aGuard(m_aMutex);
517 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
518 :
519 0 : return m_xDelegatorRow->getDate(columnIndex);
520 : }
521 :
522 0 : ::com::sun::star::util::Time OResultSet::getTime(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
523 : {
524 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getTime" );
525 0 : MutexGuard aGuard(m_aMutex);
526 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
527 :
528 0 : return m_xDelegatorRow->getTime(columnIndex);
529 : }
530 :
531 0 : ::com::sun::star::util::DateTime OResultSet::getTimestamp(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
532 : {
533 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getTimestamp" );
534 0 : MutexGuard aGuard(m_aMutex);
535 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
536 :
537 0 : return m_xDelegatorRow->getTimestamp(columnIndex);
538 : }
539 :
540 0 : Reference< ::com::sun::star::io::XInputStream > OResultSet::getBinaryStream(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
541 : {
542 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getBinaryStream" );
543 0 : MutexGuard aGuard(m_aMutex);
544 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
545 :
546 0 : return m_xDelegatorRow->getBinaryStream(columnIndex);
547 : }
548 :
549 0 : Reference< ::com::sun::star::io::XInputStream > OResultSet::getCharacterStream(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
550 : {
551 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getCharacterStream" );
552 0 : MutexGuard aGuard(m_aMutex);
553 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
554 :
555 0 : return m_xDelegatorRow->getCharacterStream(columnIndex);
556 : }
557 :
558 0 : Any OResultSet::getObject(sal_Int32 columnIndex, const Reference< ::com::sun::star::container::XNameAccess > & typeMap) throw( SQLException, RuntimeException )
559 : {
560 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getObject" );
561 0 : MutexGuard aGuard(m_aMutex);
562 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
563 :
564 0 : return m_xDelegatorRow->getObject(columnIndex, typeMap);
565 : }
566 :
567 0 : Reference< XRef > OResultSet::getRef(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
568 : {
569 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getRef" );
570 0 : MutexGuard aGuard(m_aMutex);
571 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
572 :
573 0 : return m_xDelegatorRow->getRef(columnIndex);
574 : }
575 :
576 0 : Reference< XBlob > OResultSet::getBlob(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
577 : {
578 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getBlob" );
579 0 : MutexGuard aGuard(m_aMutex);
580 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
581 :
582 0 : return m_xDelegatorRow->getBlob(columnIndex);
583 : }
584 :
585 0 : Reference< XClob > OResultSet::getClob(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
586 : {
587 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getClob" );
588 0 : MutexGuard aGuard(m_aMutex);
589 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
590 :
591 0 : return m_xDelegatorRow->getClob(columnIndex);
592 : }
593 :
594 0 : Reference< XArray > OResultSet::getArray(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
595 : {
596 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getArray" );
597 0 : MutexGuard aGuard(m_aMutex);
598 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
599 :
600 0 : return m_xDelegatorRow->getArray(columnIndex);
601 : }
602 :
603 : // ::com::sun::star::sdbc::XRowUpdate
604 0 : void OResultSet::updateNull(sal_Int32 columnIndex) throw( SQLException, RuntimeException )
605 : {
606 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateNull" );
607 0 : MutexGuard aGuard(m_aMutex);
608 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
609 :
610 0 : checkReadOnly();
611 :
612 0 : m_xDelegatorRowUpdate->updateNull(columnIndex);
613 0 : }
614 :
615 0 : void OResultSet::updateBoolean(sal_Int32 columnIndex, sal_Bool x) throw( SQLException, RuntimeException )
616 : {
617 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateBoolean" );
618 0 : MutexGuard aGuard(m_aMutex);
619 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
620 :
621 0 : checkReadOnly();
622 :
623 0 : m_xDelegatorRowUpdate->updateBoolean(columnIndex, x);
624 0 : }
625 :
626 0 : void OResultSet::updateByte(sal_Int32 columnIndex, sal_Int8 x) throw( SQLException, RuntimeException )
627 : {
628 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateByte" );
629 0 : MutexGuard aGuard(m_aMutex);
630 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
631 :
632 0 : checkReadOnly();
633 :
634 0 : m_xDelegatorRowUpdate->updateByte(columnIndex, x);
635 0 : }
636 :
637 0 : void OResultSet::updateShort(sal_Int32 columnIndex, sal_Int16 x) throw( SQLException, RuntimeException )
638 : {
639 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateShort" );
640 0 : MutexGuard aGuard(m_aMutex);
641 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
642 :
643 0 : checkReadOnly();
644 :
645 0 : m_xDelegatorRowUpdate->updateShort(columnIndex, x);
646 0 : }
647 :
648 0 : void OResultSet::updateInt(sal_Int32 columnIndex, sal_Int32 x) throw( SQLException, RuntimeException )
649 : {
650 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateInt" );
651 0 : MutexGuard aGuard(m_aMutex);
652 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
653 :
654 0 : checkReadOnly();
655 :
656 0 : m_xDelegatorRowUpdate->updateInt(columnIndex, x);
657 0 : }
658 :
659 0 : void OResultSet::updateLong(sal_Int32 columnIndex, sal_Int64 x) throw( SQLException, RuntimeException )
660 : {
661 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateLong" );
662 0 : MutexGuard aGuard(m_aMutex);
663 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
664 :
665 0 : checkReadOnly();
666 :
667 0 : m_xDelegatorRowUpdate->updateLong(columnIndex, x);
668 0 : }
669 :
670 0 : void OResultSet::updateFloat(sal_Int32 columnIndex, float x) throw( SQLException, RuntimeException )
671 : {
672 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateFloat" );
673 0 : MutexGuard aGuard(m_aMutex);
674 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
675 :
676 0 : checkReadOnly();
677 :
678 0 : m_xDelegatorRowUpdate->updateFloat(columnIndex, x);
679 0 : }
680 :
681 0 : void OResultSet::updateDouble(sal_Int32 columnIndex, double x) throw( SQLException, RuntimeException )
682 : {
683 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateDouble" );
684 0 : MutexGuard aGuard(m_aMutex);
685 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
686 :
687 0 : checkReadOnly();
688 :
689 0 : m_xDelegatorRowUpdate->updateDouble(columnIndex, x);
690 0 : }
691 :
692 0 : void OResultSet::updateString(sal_Int32 columnIndex, const rtl::OUString& x) throw( SQLException, RuntimeException )
693 : {
694 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateString" );
695 0 : MutexGuard aGuard(m_aMutex);
696 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
697 :
698 0 : checkReadOnly();
699 :
700 0 : m_xDelegatorRowUpdate->updateString(columnIndex, x);
701 0 : }
702 :
703 0 : void OResultSet::updateBytes(sal_Int32 columnIndex, const Sequence< sal_Int8 >& x) throw( SQLException, RuntimeException )
704 : {
705 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateBytes" );
706 0 : MutexGuard aGuard(m_aMutex);
707 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
708 :
709 0 : checkReadOnly();
710 :
711 0 : m_xDelegatorRowUpdate->updateBytes(columnIndex, x);
712 0 : }
713 :
714 0 : void OResultSet::updateDate(sal_Int32 columnIndex, const ::com::sun::star::util::Date& x) throw( SQLException, RuntimeException )
715 : {
716 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateDate" );
717 0 : MutexGuard aGuard(m_aMutex);
718 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
719 :
720 0 : checkReadOnly();
721 :
722 0 : m_xDelegatorRowUpdate->updateDate(columnIndex, x);
723 0 : }
724 :
725 0 : void OResultSet::updateTime(sal_Int32 columnIndex, const ::com::sun::star::util::Time& x) throw( SQLException, RuntimeException )
726 : {
727 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateTime" );
728 0 : MutexGuard aGuard(m_aMutex);
729 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
730 :
731 0 : checkReadOnly();
732 :
733 0 : m_xDelegatorRowUpdate->updateTime(columnIndex, x);
734 0 : }
735 :
736 0 : void OResultSet::updateTimestamp(sal_Int32 columnIndex, const ::com::sun::star::util::DateTime& x) throw( SQLException, RuntimeException )
737 : {
738 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateTimestamp" );
739 0 : MutexGuard aGuard(m_aMutex);
740 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
741 :
742 0 : checkReadOnly();
743 :
744 0 : m_xDelegatorRowUpdate->updateTimestamp(columnIndex, x);
745 0 : }
746 :
747 0 : void OResultSet::updateBinaryStream(sal_Int32 columnIndex, const Reference< ::com::sun::star::io::XInputStream > & x, sal_Int32 length) throw( SQLException, RuntimeException )
748 : {
749 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateBinaryStream" );
750 0 : MutexGuard aGuard(m_aMutex);
751 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
752 :
753 0 : checkReadOnly();
754 :
755 0 : m_xDelegatorRowUpdate->updateBinaryStream(columnIndex, x, length);
756 0 : }
757 :
758 0 : void OResultSet::updateCharacterStream(sal_Int32 columnIndex, const Reference< ::com::sun::star::io::XInputStream > & x, sal_Int32 length) throw( SQLException, RuntimeException )
759 : {
760 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateCharacterStream" );
761 0 : MutexGuard aGuard(m_aMutex);
762 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
763 :
764 0 : checkReadOnly();
765 :
766 0 : m_xDelegatorRowUpdate->updateCharacterStream(columnIndex, x, length);
767 0 : }
768 :
769 0 : void OResultSet::updateNumericObject(sal_Int32 columnIndex, const Any& x, sal_Int32 scale) throw( SQLException, RuntimeException )
770 : {
771 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateNumericObject" );
772 0 : MutexGuard aGuard(m_aMutex);
773 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
774 :
775 0 : checkReadOnly();
776 :
777 0 : m_xDelegatorRowUpdate->updateNumericObject(columnIndex, x, scale);
778 0 : }
779 :
780 0 : void OResultSet::updateObject(sal_Int32 columnIndex, const Any& x) throw( SQLException, RuntimeException )
781 : {
782 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateObject" );
783 0 : MutexGuard aGuard(m_aMutex);
784 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
785 :
786 0 : checkReadOnly();
787 :
788 0 : m_xDelegatorRowUpdate->updateObject(columnIndex, x);
789 0 : }
790 :
791 : // ::com::sun::star::sdbc::XResultSet
792 0 : sal_Bool OResultSet::next(void) throw( SQLException, RuntimeException )
793 : {
794 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::next" );
795 0 : MutexGuard aGuard(m_aMutex);
796 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
797 :
798 0 : return m_xDelegatorResultSet->next();
799 : }
800 :
801 0 : sal_Bool OResultSet::isBeforeFirst(void) throw( SQLException, RuntimeException )
802 : {
803 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::isBeforeFirst" );
804 0 : MutexGuard aGuard(m_aMutex);
805 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
806 :
807 0 : return m_xDelegatorResultSet->isBeforeFirst();
808 : }
809 :
810 0 : sal_Bool OResultSet::isAfterLast(void) throw( SQLException, RuntimeException )
811 : {
812 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::isAfterLast" );
813 0 : MutexGuard aGuard(m_aMutex);
814 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
815 :
816 0 : return m_xDelegatorResultSet->isAfterLast();
817 : }
818 :
819 0 : sal_Bool OResultSet::isFirst(void) throw( SQLException, RuntimeException )
820 : {
821 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::isFirst" );
822 0 : MutexGuard aGuard(m_aMutex);
823 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
824 :
825 0 : return m_xDelegatorResultSet->isFirst();
826 : }
827 :
828 0 : sal_Bool OResultSet::isLast(void) throw( SQLException, RuntimeException )
829 : {
830 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::isLast" );
831 0 : MutexGuard aGuard(m_aMutex);
832 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
833 :
834 0 : return m_xDelegatorResultSet->isLast();
835 : }
836 :
837 0 : void OResultSet::beforeFirst(void) throw( SQLException, RuntimeException )
838 : {
839 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::beforeFirst" );
840 0 : MutexGuard aGuard(m_aMutex);
841 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
842 :
843 0 : m_xDelegatorResultSet->beforeFirst();
844 0 : }
845 :
846 0 : void OResultSet::afterLast(void) throw( SQLException, RuntimeException )
847 : {
848 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::afterLast" );
849 0 : MutexGuard aGuard(m_aMutex);
850 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
851 :
852 0 : m_xDelegatorResultSet->afterLast();
853 0 : }
854 :
855 0 : sal_Bool OResultSet::first(void) throw( SQLException, RuntimeException )
856 : {
857 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::first" );
858 0 : MutexGuard aGuard(m_aMutex);
859 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
860 :
861 0 : return m_xDelegatorResultSet->first();
862 : }
863 :
864 0 : sal_Bool OResultSet::last(void) throw( SQLException, RuntimeException )
865 : {
866 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::last" );
867 0 : MutexGuard aGuard(m_aMutex);
868 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
869 :
870 0 : return m_xDelegatorResultSet->last();
871 : }
872 :
873 0 : sal_Int32 OResultSet::getRow(void) throw( SQLException, RuntimeException )
874 : {
875 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getRow" );
876 0 : MutexGuard aGuard(m_aMutex);
877 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
878 :
879 0 : return m_xDelegatorResultSet->getRow();
880 : }
881 :
882 0 : sal_Bool OResultSet::absolute(sal_Int32 row) throw( SQLException, RuntimeException )
883 : {
884 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::absolute" );
885 0 : MutexGuard aGuard(m_aMutex);
886 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
887 :
888 0 : return m_xDelegatorResultSet->absolute(row);
889 : }
890 :
891 0 : sal_Bool OResultSet::relative(sal_Int32 rows) throw( SQLException, RuntimeException )
892 : {
893 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::relative" );
894 0 : MutexGuard aGuard(m_aMutex);
895 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
896 :
897 0 : return m_xDelegatorResultSet->relative(rows);
898 : }
899 :
900 0 : sal_Bool OResultSet::previous(void) throw( SQLException, RuntimeException )
901 : {
902 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::previous" );
903 0 : MutexGuard aGuard(m_aMutex);
904 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
905 :
906 0 : return m_xDelegatorResultSet->previous();
907 : }
908 :
909 0 : void OResultSet::refreshRow(void) throw( SQLException, RuntimeException )
910 : {
911 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::refreshRow" );
912 0 : MutexGuard aGuard(m_aMutex);
913 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
914 :
915 0 : m_xDelegatorResultSet->refreshRow();
916 0 : }
917 :
918 0 : sal_Bool OResultSet::rowUpdated(void) throw( SQLException, RuntimeException )
919 : {
920 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::rowUpdated" );
921 0 : MutexGuard aGuard(m_aMutex);
922 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
923 :
924 0 : return m_xDelegatorResultSet->rowUpdated();
925 : }
926 :
927 0 : sal_Bool OResultSet::rowInserted(void) throw( SQLException, RuntimeException )
928 : {
929 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::rowInserted" );
930 0 : MutexGuard aGuard(m_aMutex);
931 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
932 :
933 0 : return m_xDelegatorResultSet->rowInserted();
934 : }
935 :
936 0 : sal_Bool OResultSet::rowDeleted(void) throw( SQLException, RuntimeException )
937 : {
938 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::rowDeleted" );
939 0 : MutexGuard aGuard(m_aMutex);
940 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
941 :
942 0 : return m_xDelegatorResultSet->rowDeleted();
943 : }
944 :
945 0 : Reference< XInterface > OResultSet::getStatement(void) throw( SQLException, RuntimeException )
946 : {
947 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getStatement" );
948 0 : MutexGuard aGuard(m_aMutex);
949 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
950 :
951 0 : return m_aStatement;
952 : }
953 :
954 : // ::com::sun::star::sdbcx::XRowLocate
955 0 : Any OResultSet::getBookmark(void) throw( SQLException, RuntimeException )
956 : {
957 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::getBookmark" );
958 0 : MutexGuard aGuard(m_aMutex);
959 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
960 :
961 0 : checkBookmarkable();
962 :
963 0 : return Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY)->getBookmark();
964 : }
965 :
966 0 : sal_Bool OResultSet::moveToBookmark(const Any& bookmark) throw( SQLException, RuntimeException )
967 : {
968 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::moveToBookmark" );
969 0 : MutexGuard aGuard(m_aMutex);
970 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
971 :
972 0 : checkBookmarkable();
973 :
974 0 : return Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY)->moveToBookmark(bookmark);
975 : }
976 :
977 0 : sal_Bool OResultSet::moveRelativeToBookmark(const Any& bookmark, sal_Int32 rows) throw( SQLException, RuntimeException )
978 : {
979 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::moveRelativeToBookmark" );
980 0 : MutexGuard aGuard(m_aMutex);
981 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
982 :
983 0 : checkBookmarkable();
984 :
985 0 : return Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY)->moveRelativeToBookmark(bookmark, rows);
986 : }
987 :
988 0 : sal_Int32 OResultSet::compareBookmarks(const Any& _first, const Any& _second) throw( SQLException, RuntimeException )
989 : {
990 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::compareBookmarks" );
991 0 : MutexGuard aGuard(m_aMutex);
992 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
993 :
994 0 : checkBookmarkable();
995 :
996 0 : return Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY)->compareBookmarks(_first, _second);
997 : }
998 :
999 0 : sal_Bool OResultSet::hasOrderedBookmarks(void) throw( SQLException, RuntimeException )
1000 : {
1001 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::hasOrderedBookmarks" );
1002 0 : MutexGuard aGuard(m_aMutex);
1003 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1004 :
1005 0 : checkBookmarkable();
1006 :
1007 0 : return Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY)->hasOrderedBookmarks();
1008 : }
1009 :
1010 0 : sal_Int32 OResultSet::hashBookmark(const Any& bookmark) throw( SQLException, RuntimeException )
1011 : {
1012 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::hashBookmark" );
1013 0 : MutexGuard aGuard(m_aMutex);
1014 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1015 :
1016 0 : checkBookmarkable();
1017 :
1018 0 : return Reference< XRowLocate >(m_xDelegatorResultSet, UNO_QUERY)->hashBookmark(bookmark);
1019 : }
1020 :
1021 : // ::com::sun::star::sdbc::XResultSetUpdate
1022 0 : void OResultSet::insertRow(void) throw( SQLException, RuntimeException )
1023 : {
1024 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::insertRow" );
1025 0 : MutexGuard aGuard(m_aMutex);
1026 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1027 :
1028 0 : checkReadOnly();
1029 :
1030 0 : m_xDelegatorResultSetUpdate->insertRow();
1031 0 : }
1032 :
1033 0 : void OResultSet::updateRow(void) throw( SQLException, RuntimeException )
1034 : {
1035 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::updateRow" );
1036 0 : MutexGuard aGuard(m_aMutex);
1037 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1038 :
1039 0 : checkReadOnly();
1040 :
1041 0 : m_xDelegatorResultSetUpdate->updateRow();
1042 0 : }
1043 :
1044 0 : void OResultSet::deleteRow(void) throw( SQLException, RuntimeException )
1045 : {
1046 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::deleteRow" );
1047 0 : MutexGuard aGuard(m_aMutex);
1048 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1049 :
1050 0 : checkReadOnly();
1051 :
1052 0 : m_xDelegatorResultSetUpdate->deleteRow();
1053 0 : }
1054 :
1055 0 : void OResultSet::cancelRowUpdates(void) throw( SQLException, RuntimeException )
1056 : {
1057 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::cancelRowUpdates" );
1058 0 : MutexGuard aGuard(m_aMutex);
1059 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1060 :
1061 0 : checkReadOnly();
1062 :
1063 0 : m_xDelegatorResultSetUpdate->cancelRowUpdates();
1064 0 : }
1065 :
1066 0 : void OResultSet::moveToInsertRow(void) throw( SQLException, RuntimeException )
1067 : {
1068 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::moveToInsertRow" );
1069 0 : MutexGuard aGuard(m_aMutex);
1070 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1071 :
1072 0 : checkReadOnly();
1073 :
1074 0 : m_xDelegatorResultSetUpdate->moveToInsertRow();
1075 0 : }
1076 :
1077 0 : void OResultSet::moveToCurrentRow(void) throw( SQLException, RuntimeException )
1078 : {
1079 : RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::moveToCurrentRow" );
1080 0 : MutexGuard aGuard(m_aMutex);
1081 0 : ::connectivity::checkDisposed(OResultSetBase::rBHelper.bDisposed);
1082 :
1083 0 : checkReadOnly();
1084 :
1085 0 : m_xDelegatorResultSetUpdate->moveToCurrentRow();
1086 0 : }
1087 :
1088 0 : void OResultSet::checkReadOnly() const
1089 : {
1090 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::checkReadOnly" );
1091 0 : if ( ( m_nResultSetConcurrency == ResultSetConcurrency::READ_ONLY )
1092 0 : || !m_xDelegatorResultSetUpdate.is()
1093 : )
1094 0 : throwSQLException( "The result set is read-only.", SQL_GENERAL_ERROR, *const_cast< OResultSet* >( this ) );
1095 0 : }
1096 :
1097 0 : void OResultSet::checkBookmarkable() const
1098 : {
1099 : //RTL_LOGFILE_CONTEXT_AUTHOR( aLogger, "dbaccess", "Ocke.Janssen@sun.com", "OResultSet::checkBookmarkable" );
1100 0 : if ( !m_bIsBookmarkable )
1101 0 : throwSQLException( "The result set does not have bookmark support.", SQL_GENERAL_ERROR, *const_cast< OResultSet* >( this ) );
1102 0 : }
1103 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|