blob: 42f43a98249e9313a704f43b6cf3b7c404ef4dca [file] [log] [blame]
/**************************************************************
*
* 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 SD_FRAMEWORK_MODULE_CONTROLLER_HXX
#define SD_FRAMEWORK_MODULE_CONTROLLER_HXX
#include "MutexOwner.hxx"
#include <osl/mutex.hxx>
#include <com/sun/star/drawing/framework/XModuleController.hpp>
#include <com/sun/star/uno/XComponentContext.hpp>
#include <com/sun/star/lang/XInitialization.hpp>
#include <com/sun/star/frame/XController.hpp>
#include <cppuhelper/compbase2.hxx>
#include <boost/scoped_ptr.hpp>
#include <set>
namespace css = ::com::sun::star;
namespace {
typedef ::cppu::WeakComponentImplHelper2 <
css::drawing::framework::XModuleController,
css::lang::XInitialization
> ModuleControllerInterfaceBase;
} // end of anonymous namespace.
namespace sd { namespace framework {
/** The ModuleController has to tasks:
1. It reads the
org.openoffice.Office.Impress/MultiPaneGUI/Framework/ResourceFactories
configuration data that maps from resource URLs to service names of
factories that can create resources for the URLs. When the
configuration controller wants to create a resource for which it does
not have a factory, it asks the ModuleController to provide one. The
ModuleController looks up the service name registered for the URL of the
resource and instantiates this service. The service is expected to
register on its creation a factory for the resource in question.
2. The ModuleController reads on its creation
org.openoffice.Office.Impress/MultiPaneGUI/Framework/StartupServices
configuration data and instantiates all listed services. These servces
can then register as listeners at the ConfigurationController or do
whatever they like.
*/
class ModuleController
: private sd::MutexOwner,
public ModuleControllerInterfaceBase
{
public:
static css::uno::Reference<
css::drawing::framework::XModuleController>
CreateInstance (
const css::uno::Reference<css::uno::XComponentContext>&
rxContext);
virtual void SAL_CALL disposing (void);
// XModuleController
virtual void SAL_CALL requestResource(const ::rtl::OUString& rsResourceURL)
throw (css::uno::RuntimeException);
// XInitialization
virtual void SAL_CALL initialize(
const css::uno::Sequence<css::uno::Any>& aArguments)
throw (css::uno::Exception, css::uno::RuntimeException);
private:
css::uno::Reference<
css::frame::XController> mxController;
class ResourceToFactoryMap;
::boost::scoped_ptr<ResourceToFactoryMap> mpResourceToFactoryMap;
class LoadedFactoryContainer;
::boost::scoped_ptr<LoadedFactoryContainer> mpLoadedFactories;
ModuleController (
const css::uno::Reference<css::uno::XComponentContext>& rxContext)
throw();
ModuleController (void); // Not implemented.
ModuleController (const ModuleController&); // Not implemented.
virtual ~ModuleController (void) throw();
/** Load a list of URL to service mappings from the
/org.openoffice.Office.Impress/MultiPaneGUI/Framework/ResourceFactories
configuration entry. The mappings are stored in the
mpResourceToFactoryMap member.
*/
void LoadFactories (const css::uno::Reference<css::uno::XComponentContext>& rxContext);
/** Called for every entry in the ResourceFactories configuration entry.
*/
void ProcessFactory (const ::std::vector<css::uno::Any>& rValues);
/** Instantiate all startup services that are found in the
/org.openoffice.Office.Impress/MultiPaneGUI/Framework/StartupServices
configuration entry. This method is called once when a new
ModuleController object is created.
*/
void InstantiateStartupServices (void);
/** Called for one entry in the StartupServices configuration list this
method instantiates the service described by the entry. It does not
hold references to the new object so that the object will be
destroyed on function exit when it does not register itself
somewhere. It typically will register as
XConfigurationChangeListener at the configuration controller.
*/
void ProcessStartupService (const ::std::vector<css::uno::Any>& rValues);
};
} } // end of namespace sd::framework
#endif