office-gobmx/include/ucbhelper/resultset.hxx
Noel Grandin 57c5f98083 loplugin:constmethod in comphelper,ucbhelper
Change-Id: I27a860fbbedd2174c60c199af18cae76e02abc25
Reviewed-on: https://gerrit.libreoffice.org/43759
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
2017-10-25 08:32:27 +02:00

450 lines
17 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#ifndef INCLUDED_UCBHELPER_RESULTSET_HXX
#define INCLUDED_UCBHELPER_RESULTSET_HXX
#include <com/sun/star/lang/XTypeProvider.hpp>
#include <com/sun/star/lang/XServiceInfo.hpp>
#include <com/sun/star/lang/XComponent.hpp>
#include <com/sun/star/ucb/ResultSetException.hpp>
#include <com/sun/star/ucb/XCommandEnvironment.hpp>
#include <com/sun/star/ucb/XContentAccess.hpp>
#include <com/sun/star/sdbc/XResultSet.hpp>
#include <com/sun/star/sdbc/XResultSetMetaDataSupplier.hpp>
#include <com/sun/star/sdbc/XRow.hpp>
#include <com/sun/star/sdbc/XCloseable.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <rtl/ref.hxx>
#include <salhelper/simplereferenceobject.hxx>
#include <cppuhelper/weak.hxx>
#include <ucbhelper/macros.hxx>
#include <ucbhelper/ucbhelperdllapi.h>
#include <memory>
namespace ucbhelper {
#define RESULTSET_SERVICE_NAME "com.sun.star.ucb.ContentResultSet"
class ResultSetDataSupplier;
struct ResultSet_Impl;
/**
* This is an implementation of the service com.sun.star.ucb.ContentResultSet.
* It can be used to implement the method XDynamicResultSet::getStaticResultSet,
* which needs to be implemented for instance to implement the command "open"
* at folder objects. This class uses a user supplied ResultSetDataSupplier
* object to request data on demand.
*
* @see ResultSetDataSupplier
*/
class UCBHELPER_DLLPUBLIC ResultSet :
public cppu::OWeakObject,
public css::lang::XTypeProvider,
public css::lang::XServiceInfo,
public css::lang::XComponent,
public css::ucb::XContentAccess,
public css::sdbc::XResultSet,
public css::sdbc::XResultSetMetaDataSupplier,
public css::sdbc::XRow,
public css::sdbc::XCloseable,
public css::beans::XPropertySet
{
std::unique_ptr<ResultSet_Impl> m_pImpl;
public:
/**
* Construction.
*
* @param rxSMgr is a Service Manager.
* @param rProperties is a sequence of properties for that the resultset
* shall be able to obtain the values.
* @param rDataSupplier is a supplier for the resultset data.
*/
ResultSet(
const css::uno::Reference< css::uno::XComponentContext >& rxContext,
const css::uno::Sequence< css::beans::Property >& rProperties,
const rtl::Reference< ResultSetDataSupplier >& rDataSupplier );
/**
* Construction.
*
* @param rxSMgr is a Service Manager.
* @param rProperties is a sequence of properties for that the resultset
* shall be able to obtain the values.
* @param rDataSupplier is a supplier for the resultset data.
* @param rxEnv is the environment for interactions, progress propagation,
* ...
*/
ResultSet(
const css::uno::Reference< css::uno::XComponentContext >& rxContext,
const css::uno::Sequence< css::beans::Property >& rProperties,
const rtl::Reference< ResultSetDataSupplier >& rDataSupplier,
const css::uno::Reference< css::ucb::XCommandEnvironment >& rxEnv );
virtual ~ResultSet() override;
// XInterface
virtual css::uno::Any SAL_CALL queryInterface( const css::uno::Type & rType ) override;
virtual void SAL_CALL acquire()
throw() override;
virtual void SAL_CALL release()
throw() override;
// XTypeProvider
virtual css::uno::Sequence< sal_Int8 > SAL_CALL
getImplementationId() override;
virtual css::uno::Sequence< css::uno::Type > SAL_CALL
getTypes() override;
// XServiceInfo
virtual OUString SAL_CALL getImplementationName() override;
virtual sal_Bool SAL_CALL supportsService( const OUString& ServiceName ) override;
virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() override;
// XComponent
virtual void SAL_CALL
dispose() override;
virtual void SAL_CALL
addEventListener( const css::uno::Reference< css::lang::XEventListener >& Listener ) override;
virtual void SAL_CALL
removeEventListener( const css::uno::Reference< css::lang::XEventListener >& Listener ) override;
// XContentAccess
virtual OUString SAL_CALL
queryContentIdentifierString() override;
virtual css::uno::Reference< css::ucb::XContentIdentifier > SAL_CALL
queryContentIdentifier() override;
virtual css::uno::Reference< css::ucb::XContent > SAL_CALL
queryContent() override;
// XResultSetMetaDataSupplier
virtual css::uno::Reference< css::sdbc::XResultSetMetaData > SAL_CALL
getMetaData() override;
// XResultSet
virtual sal_Bool SAL_CALL
next() override;
virtual sal_Bool SAL_CALL
isBeforeFirst() override;
virtual sal_Bool SAL_CALL
isAfterLast() override;
virtual sal_Bool SAL_CALL
isFirst() override;
virtual sal_Bool SAL_CALL
isLast() override;
virtual void SAL_CALL
beforeFirst() override;
virtual void SAL_CALL
afterLast() override;
virtual sal_Bool SAL_CALL
first() override;
virtual sal_Bool SAL_CALL
last() override;
virtual sal_Int32 SAL_CALL
getRow() override;
virtual sal_Bool SAL_CALL
absolute( sal_Int32 row ) override;
virtual sal_Bool SAL_CALL
relative( sal_Int32 rows ) override;
virtual sal_Bool SAL_CALL
previous() override;
virtual void SAL_CALL
refreshRow() override;
virtual sal_Bool SAL_CALL
rowUpdated() override;
virtual sal_Bool SAL_CALL
rowInserted() override;
virtual sal_Bool SAL_CALL
rowDeleted() override;
virtual css::uno::Reference< css::uno::XInterface > SAL_CALL
getStatement() override;
// XRow
virtual sal_Bool SAL_CALL
wasNull() override;
virtual OUString SAL_CALL
getString( sal_Int32 columnIndex ) override;
virtual sal_Bool SAL_CALL
getBoolean( sal_Int32 columnIndex ) override;
virtual sal_Int8 SAL_CALL
getByte( sal_Int32 columnIndex ) override;
virtual sal_Int16 SAL_CALL
getShort( sal_Int32 columnIndex ) override;
virtual sal_Int32 SAL_CALL
getInt( sal_Int32 columnIndex ) override;
virtual sal_Int64 SAL_CALL
getLong( sal_Int32 columnIndex ) override;
virtual float SAL_CALL
getFloat( sal_Int32 columnIndex ) override;
virtual double SAL_CALL
getDouble( sal_Int32 columnIndex ) override;
virtual css::uno::Sequence< sal_Int8 > SAL_CALL
getBytes( sal_Int32 columnIndex ) override;
virtual css::util::Date SAL_CALL
getDate( sal_Int32 columnIndex ) override;
virtual css::util::Time SAL_CALL
getTime( sal_Int32 columnIndex ) override;
virtual css::util::DateTime SAL_CALL
getTimestamp( sal_Int32 columnIndex ) override;
virtual css::uno::Reference<
css::io::XInputStream > SAL_CALL
getBinaryStream( sal_Int32 columnIndex ) override;
virtual css::uno::Reference<
css::io::XInputStream > SAL_CALL
getCharacterStream( sal_Int32 columnIndex ) override;
virtual css::uno::Any SAL_CALL
getObject( sal_Int32 columnIndex,
const css::uno::Reference< css::container::XNameAccess >& typeMap ) override;
virtual css::uno::Reference< css::sdbc::XRef > SAL_CALL
getRef( sal_Int32 columnIndex ) override;
virtual css::uno::Reference<
css::sdbc::XBlob > SAL_CALL
getBlob( sal_Int32 columnIndex ) override;
virtual css::uno::Reference< css::sdbc::XClob > SAL_CALL
getClob( sal_Int32 columnIndex ) override;
virtual css::uno::Reference< css::sdbc::XArray > SAL_CALL
getArray( sal_Int32 columnIndex ) override;
// XCloseable
virtual void SAL_CALL
close() override;
// XPropertySet
virtual css::uno::Reference< css::beans::XPropertySetInfo > SAL_CALL
getPropertySetInfo() override;
virtual void SAL_CALL
setPropertyValue( const OUString& aPropertyName,
const css::uno::Any& aValue ) override;
virtual css::uno::Any SAL_CALL
getPropertyValue( const OUString& PropertyName ) override;
virtual void SAL_CALL
addPropertyChangeListener( const OUString& aPropertyName,
const css::uno::Reference< css::beans::XPropertyChangeListener >& xListener ) override;
virtual void SAL_CALL
removePropertyChangeListener( const OUString& aPropertyName,
const css::uno::Reference< css::beans::XPropertyChangeListener >& aListener ) override;
virtual void SAL_CALL
addVetoableChangeListener( const OUString& PropertyName,
const css::uno::Reference< css::beans::XVetoableChangeListener >& aListener ) override;
virtual void SAL_CALL
removeVetoableChangeListener( const OUString& PropertyName,
const css::uno::Reference< css::beans::XVetoableChangeListener >& aListener ) override;
// Non-interface methods.
/**
* This method propagates property value changes to all registered
* listeners.
*
* @param rEvt is a property change event.
*/
void propertyChanged(
const css::beans::PropertyChangeEvent& rEvt ) const;
/**
* This method should be called by the data supplier for the result set
* to indicate that there were new data obtained from the data source.
*
* @param nOld is the old count of rows; must be non-negative.
* @param nnew is the new count of rows; must be non-negative.
*/
void rowCountChanged( sal_uInt32 nOld, sal_uInt32 nNew );
/**
* This method should be called by the data supplier for the result set
* to indicate that there were all rows obtained from the data source.
*/
void rowCountFinal();
/**
* This method returns a sequence containing all properties ( not the
* values! ) of the result set.
*
* @return a sequence of properties.
*/
const css::uno::Sequence< css::beans::Property >&
getProperties() const;
/**
* This method returns the environment to use for interactions, progress
* propagation, ... It can by empty.
*
* @return an environment or an empty reference.
*/
const css::uno::Reference< css::ucb::XCommandEnvironment >&
getEnvironment() const;
};
/**
* This is the base class for an object that supplies data to a result set
*
* @see ResultSet
*/
class ResultSetDataSupplier : public salhelper::SimpleReferenceObject
{
friend class ResultSet;
// No ref, otherwise we get a cyclic reference between supplier and set!
// Will be set from ResultSet ctor.
ResultSet* m_pResultSet;
public:
ResultSetDataSupplier() : m_pResultSet( nullptr ) {}
/**
* This method returns the resultset this supplier belongs to.
*
* @return the resultset for that the supplier supplies data.
*/
rtl::Reference< ResultSet > getResultSet() const { return m_pResultSet; }
/**
* This method returns the identifier string of the content at the
* specified index.
*
* @param nIndex is the zero-based index within the logical data array
* of the supplier; must be non-negative.
* @return the content's identifier string.
*/
virtual OUString queryContentIdentifierString( sal_uInt32 nIndex ) = 0;
/**
* This method returns the identifier of the content at the specified index.
*
* @param nIndex is the zero-based index within the logical data array
* of the supplier; must be non-negative.
* @return the content's identifier.
*/
virtual css::uno::Reference< css::ucb::XContentIdentifier >
queryContentIdentifier( sal_uInt32 nIndex ) = 0;
/**
* This method returns the content at the specified index.
*
* @param nIndex is the zero-based index within the logical data array
* of the supplier; must be non-negative.
* @return the content.
*/
virtual css::uno::Reference< css::ucb::XContent >
queryContent( sal_uInt32 nIndex ) = 0;
/**
* This method returns whether there is a content at the specified index.
*
* @param nIndex is the zero-based index within the logical data array
* of the supplier; must be non-negative.
* @return true, if there is a content at the given index.
*/
virtual bool getResult( sal_uInt32 nIndex ) = 0;
/**
* This method returns the total count of objects in the logical data array
* of the supplier. The implementation of this method may be very
* "expensive", because it can be necessary to obtain all data in order
* to determine the count. Therefore the ResultSet implementation calls
* it very seldom.
*
* @return the total count of objects; will always be non-negative.
*/
virtual sal_uInt32 totalCount() = 0;
/**
* This method returns the count of objects obtained so far. There is no
* for the implementation to obtain all objects at once. It can obtain
* all data on demand.
*
* The implementation should call m_pResultSet->rowCountChanged(...)
* every time it has inserted a new entry in its logical result array.
*
* @return the count of objects obtained so far; will always be
* non-negative.
*/
virtual sal_uInt32 currentCount() = 0;
/**
* This method returns whether the value returned by currentCount() is
* "final". This is the case, if that there was all data obtained by the
* supplier and the current count won't increase any more.
*
* The implementation should call m_pResultSet->rowCountFinal(...) if
* it has inserted all entries in its logical result array.
*
* @return true, if the value returned by currentCount() won't change
anymore.
*/
virtual bool isCountFinal() = 0;
/**
* This method returns an object for accessing the property values at
* the specified index. The implementation may use the helper class
* ucb::PropertyValueSet to provide the return value.
*
* @param nIndex is the zero-based index within the logical data array
* of the supplier.
* @return the object for accessing the property values.
*/
virtual css::uno::Reference< css::sdbc::XRow >
queryPropertyValues( sal_uInt32 nIndex ) = 0;
/**
* This method is called to instruct the supplier to release the (possibly
* presnt) property values at the given index.
*
* @param nIndex is the zero-based index within the logical data array
* of the supplier.
*/
virtual void releasePropertyValues( sal_uInt32 nIndex ) = 0;
/**
* This method will be called by the resultset implementation in order
* to instruct the data supplier to release all resources it has
* allocated so far. In case the supplier is collecting data
* asynchronously, that process must be stopped.
*/
virtual void close() = 0;
/**
* This method will be called by the resultset implementation in order
* check, whether an error has occurred while collecting data. The
* implementation of this method must throw an exception in that case.
*
* Note: An exception thrown to indicate an error must always be thrown
* by the thread that created the data supplier. If the supplier collects
* data asynchronously ( i.e. in a separate thread ) and an error
* occurs, throwing of the appropriate exception must be deferred
* until validate() is called by the ResultSet implementation from
* inside the main thread.
* In case data are obtained synchronously, the ResultSetException can
* be thrown directly.
*
* @exception ResultSetException thrown, if an error has occurred
*/
virtual void validate() = 0;
};
}
#endif /* ! INCLUDED_UCBHELPER_RESULTSET_HXX */
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */