diff options
Diffstat (limited to 'sw/source/uibase/app/swdll.cxx')
-rw-r--r-- | sw/source/uibase/app/swdll.cxx | 164 |
1 files changed, 164 insertions, 0 deletions
diff --git a/sw/source/uibase/app/swdll.cxx b/sw/source/uibase/app/swdll.cxx new file mode 100644 index 000000000000..cb6d19e079e1 --- /dev/null +++ b/sw/source/uibase/app/swdll.cxx @@ -0,0 +1,164 @@ +/* -*- 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 . + */ + +#include <config_features.h> + +#include <svx/svdobj.hxx> + +#include "globdoc.hrc" + +#include <swdll.hxx> +#include <wdocsh.hxx> +#include <globdoc.hxx> +#include <initui.hxx> +#include <swmodule.hxx> +#include <swtypes.hxx> +#include <init.hxx> +#include <dobjfac.hxx> +#include <cfgid.h> + +#include <com/sun/star/frame/Desktop.hpp> +#include <unotools/moduleoptions.hxx> +#include <comphelper/scoped_disposing_ptr.hxx> +#include <comphelper/processfactory.hxx> + +#include <svx/fmobjfac.hxx> +#include <svx/svdfield.hxx> +#include <svx/objfac3d.hxx> + +#include <unomid.h> + +#include "swdllimpl.hxx" + +using namespace com::sun::star; + +namespace +{ + //Holds a SwDLL and release it on exit, or dispose of the + //default XComponent, whichever comes first + class SwDLLInstance : public comphelper::scoped_disposing_solar_mutex_reset_ptr<SwDLL> + { + public: + SwDLLInstance() : comphelper::scoped_disposing_solar_mutex_reset_ptr<SwDLL>(uno::Reference<lang::XComponent>( frame::Desktop::create(comphelper::getProcessComponentContext()), uno::UNO_QUERY_THROW), new SwDLL) + { + } + }; + + struct theSwDLLInstance : public rtl::Static<SwDLLInstance, theSwDLLInstance> {}; +} + +namespace SwGlobals +{ + void ensure() + { + theSwDLLInstance::get(); + } + + sw::Filters & getFilters() + { + return theSwDLLInstance::get().get()->getFilters(); + } +} + +SwDLL::SwDLL() +{ + // the SdModule must be created + SwModule** ppShlPtr = (SwModule**) GetAppData(SHL_WRITER); + if ( *ppShlPtr ) + return; + + SvtModuleOptions aOpt; + SfxObjectFactory* pDocFact = 0; + SfxObjectFactory* pGlobDocFact = 0; + if ( aOpt.IsWriter() ) + { + pDocFact = &SwDocShell::Factory(); + pGlobDocFact = &SwGlobalDocShell::Factory(); + } + + SfxObjectFactory* pWDocFact = &SwWebDocShell::Factory(); + + SwModule* pModule = new SwModule( pWDocFact, pDocFact, pGlobDocFact ); + *ppShlPtr = pModule; + + pWDocFact->SetDocumentServiceName(OUString("com.sun.star.text.WebDocument")); + + if ( aOpt.IsWriter() ) + { + pGlobDocFact->SetDocumentServiceName(OUString("com.sun.star.text.GlobalDocument")); + pDocFact->SetDocumentServiceName(OUString("com.sun.star.text.TextDocument")); + } + + // register SvDraw-Fields + SdrRegisterFieldClasses(); + + // register 3D-Objekt-Factory + E3dObjFactory(); + + // register form::component::Form-Objekt-Factory + FmFormObjFactory(); + + SdrObjFactory::InsertMakeObjectHdl( LINK( &aSwObjectFactory, SwObjectFactory, MakeObject ) ); + + SAL_INFO( "sw.ui", "Init Core/UI/Filter" ); + // Initialisation of Statics + ::_InitCore(); + filters_.reset(new sw::Filters); + ::_InitUI(); + + pModule->InitAttrPool(); + // now SWModule can create its Pool + + // register your view-factories here + RegisterFactories(); + +#if HAVE_FEATURE_DESKTOP + // register your shell-interfaces here + RegisterInterfaces(); + + // register your controllers here + RegisterControls(); +#endif +} + +SwDLL::~SwDLL() +{ + // Pool has to be deleted before statics are + SW_MOD()->RemoveAttrPool(); + + ::_FinitUI(); + filters_.reset(); + ::_FinitCore(); + // sign out Objekt-Factory + SdrObjFactory::RemoveMakeObjectHdl(LINK(&aSwObjectFactory, SwObjectFactory, MakeObject )); +#if 0 + // the SwModule must be destroyed + SwModule** ppShlPtr = (SwModule**) GetAppData(SHL_WRITER); + delete (*ppShlPtr); + (*ppShlPtr) = NULL; +#endif +} + +sw::Filters & SwDLL::getFilters() +{ + OSL_ASSERT(filters_); + return *filters_.get(); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |