/**************************************************************
 * 
 * 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
 * 
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 * 
 *************************************************************/



#ifndef _UCBHELPER_RESULTSETHELPER_HXX
#define _UCBHELPER_RESULTSETHELPER_HXX

#include <osl/mutex.hxx>
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
#include <com/sun/star/lang/XTypeProvider.hpp>
#include <com/sun/star/lang/XServiceInfo.hpp>
#include <com/sun/star/ucb/XDynamicResultSet.hpp>
#include <com/sun/star/ucb/XCommandEnvironment.hpp>
#include <com/sun/star/ucb/OpenCommandArgument2.hpp>
#include <cppuhelper/weak.hxx>
#include <ucbhelper/macros.hxx>
#include <ucbhelper/contenthelper.hxx>
#include "ucbhelper/ucbhelperdllapi.h"

namespace cppu {
	class OInterfaceContainerHelper;
}

namespace ucbhelper {

//=========================================================================

#define DYNAMICRESULTSET_SERVICE_NAME "com.sun.star.ucb.DynamicResultSet"

//=========================================================================

/**
  * This is an abstract base class for implementations of the service
  * com.sun.star.ucb.DynamicResultSet, which is the result of the command
  * "open" executed at a UCB folder content.
  *
  * Features of the base class implementation:
  * - standard interfaces ( XInterface, XTypeProvider, XServiceInfo )
  *	- all required interfaces for service com::sun::star::ucb::DynamicResultSet
  */
class UCBHELPER_DLLPUBLIC ResultSetImplHelper :
				public cppu::OWeakObject,
				public com::sun::star::lang::XTypeProvider,
				public com::sun::star::lang::XServiceInfo,
				public com::sun::star::ucb::XDynamicResultSet
{
	cppu::OInterfaceContainerHelper* m_pDisposeEventListeners;
	sal_Bool						 m_bStatic;
	sal_Bool						 m_bInitDone;

protected:
	osl::Mutex						 					 m_aMutex;
	com::sun::star::ucb::OpenCommandArgument2			 m_aCommand;
	com::sun::star::uno::Reference<
		com::sun::star::lang::XMultiServiceFactory >	 m_xSMgr;
	// Resultset #1
	com::sun::star::uno::Reference<
		com::sun::star::sdbc::XResultSet > 				 m_xResultSet1;
	// Resultset #2
	com::sun::star::uno::Reference<
		com::sun::star::sdbc::XResultSet > 				 m_xResultSet2;
	// Resultset changes listener.
	com::sun::star::uno::Reference<
		com::sun::star::ucb::XDynamicResultSetListener > m_xListener;

private:
	UCBHELPER_DLLPRIVATE void init( sal_Bool bStatic );

	/**
	  * Your implementation of this method has to fill the protected member
	  * m_xResultSet1. This resultset must implement a complete static
	  * resultset ( service com.sun.star.ucb.ContentResultSet ). This method
	  * will be called at most once in the life of your implementation object.
	  * After this method was called, the type of this resultset will be
	  * "static". There is no way to change the type afterwards.
	  * If this method gets called the client wants to use your resultset
	  * exclusively statically. You may deploy this factum to optimize your
	  * implementation (i.e. "switch off" all changes detection code in
	  * your implementation).
	  * Note that you may use the class ucb::ResultSet to implement the
	  * static resultset, that is required here.
	  */
	UCBHELPER_DLLPRIVATE virtual void initStatic() = 0;

	/**
	  * Your implementation of this method has to fill the protected members
	  * m_xResultSet1 and m_xResultSet2 of this base class. Each of these
	  * resultsets must implement a complete static resultset
	  * ( service com.sun.star.ucb.ContentResultSet ). This method will be
	  * called at most once in the life of your implementation object.
	  * After this method was called, the type of this resultset will be
	  * "dynamic". There is no way to change the type afterwards.
	  * If this method gets called the client wants to use your resultset
	  * exclusively dynamically. This means, it is interested in getting
	  * notifications on changes of data of the resultset contents. ( These
	  * changes are to propagate by your implementation throw the member
	  * m_xListener of this base class ).
	  * If your implementation cannot detect changes of relevant data, you
	  * may fill m_xResultSet1 and m_xResultSet2 with the same static resultset
	  * implementation object. This normally will be the same instance you put
	  * into m_xResultSet1 when initStatic() is called.
	  */
	UCBHELPER_DLLPRIVATE virtual void initDynamic() = 0;

public:
	/**
	  * Construtor.
	  *
	  * @param rxSMgr is a Service Manager.
	  */
	ResultSetImplHelper(
			const com::sun::star::uno::Reference<
				com::sun::star::lang::XMultiServiceFactory >& rxSMgr );

	/**
	  * Construtor.
	  *
	  * @param rxSMgr is a Service Manager.
	  * @param rCommand is the paramter for the open command that produces
	  *        this resultset.
	  */
	ResultSetImplHelper(
			const com::sun::star::uno::Reference<
				com::sun::star::lang::XMultiServiceFactory >& rxSMgr,
			const com::sun::star::ucb::OpenCommandArgument2& rCommand );

	/**
	  * Destructor.
	  */
	virtual ~ResultSetImplHelper();

	// XInterface
	XINTERFACE_DECL()

	// XTypeProvider
	XTYPEPROVIDER_DECL()

    // XServiceInfo
	XSERVICEINFO_NOFACTORY_DECL()

	// XComponent ( base class of XDynamicResultSet )
    virtual void SAL_CALL
	dispose()
		throw( com::sun::star::uno::RuntimeException );
    virtual void SAL_CALL
	addEventListener( const com::sun::star::uno::Reference<
							com::sun::star::lang::XEventListener >& Listener )
		throw( com::sun::star::uno::RuntimeException );
    virtual void SAL_CALL
	removeEventListener( const com::sun::star::uno::Reference<
							com::sun::star::lang::XEventListener >& Listener )
		throw( com::sun::star::uno::RuntimeException );

	// XDynamicResultSet
    virtual com::sun::star::uno::Reference<
				com::sun::star::sdbc::XResultSet > SAL_CALL
	getStaticResultSet()
		throw( com::sun::star::ucb::ListenerAlreadySetException,
		com::sun::star::uno::RuntimeException );
    virtual void SAL_CALL
	setListener( const com::sun::star::uno::Reference<
					com::sun::star::ucb::XDynamicResultSetListener >& Listener )
		throw( com::sun::star::ucb::ListenerAlreadySetException,
			   com::sun::star::uno::RuntimeException );
	virtual void SAL_CALL
	connectToCache( const com::sun::star::uno::Reference<
						com::sun::star::ucb::XDynamicResultSet > & xCache )
		throw( com::sun::star::ucb::ListenerAlreadySetException,
			   com::sun::star::ucb::AlreadyInitializedException,
			   com::sun::star::ucb::ServiceNotFoundException,
			   com::sun::star::uno::RuntimeException );

	/**
	  * The implemetation of this method always returns 0. Override this
	  * method, if necassary.
	  */
    virtual sal_Int16 SAL_CALL
	getCapabilities()
		throw( com::sun::star::uno::RuntimeException );

	//////////////////////////////////////////////////////////////////////
	// Non-interface methods.
	//////////////////////////////////////////////////////////////////////

	/**
	  * This method returns, whether the resultset is static or dynamic.
	  * If neither getStatic() nor getDynamic() was called, the type
	  * of the resultset is "dynamic".
	  *
	  * @return true, if the resultset type is "static". False, otherwise.
	  */
	sal_Bool isStatic() const { return m_bStatic; }
};

}

#endif /* !_UCBHELPER_RESULTSETHELPER_HXX */
