[Libreoffice-commits] core.git: Branch 'feature/components' - 40 commits - framework/inc framework/source framework/util solenv/bin svtools/Library_svt.mk svtools/source svtools/util

Matúš Kukan matus.kukan at collabora.com
Fri Jan 10 07:13:59 PST 2014


Rebased ref, commits from common ancestor:
commit ade31558aa0538e4c766a0353d47157abe437cbc
Author: Matúš Kukan <matus.kukan at collabora.com>
Date:   Thu Jan 9 20:58:27 2014 +0100

    fwk: Use constructor feature for DocumentAcceleratorConfiguration.
    
    Change-Id: I14daf6409bf0d651d7b23246ba3855f647b3d1ef

diff --git a/framework/source/accelerators/documentacceleratorconfiguration.cxx b/framework/source/accelerators/documentacceleratorconfiguration.cxx
index d9e8689..6ded8bb 100644
--- a/framework/source/accelerators/documentacceleratorconfiguration.cxx
+++ b/framework/source/accelerators/documentacceleratorconfiguration.cxx
@@ -17,40 +17,90 @@
  *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
  */
 
-#include <accelerators/documentacceleratorconfiguration.hxx>
+#include <accelerators/acceleratorconfiguration.hxx>
+#include <accelerators/istoragelistener.hxx>
+#include <accelerators/presethandler.hxx>
 
 #include <xml/acceleratorconfigurationreader.hxx>
-
 #include <xml/acceleratorconfigurationwriter.hxx>
-
 #include <xml/saxnamespacefilter.hxx>
 
 #include <threadhelp/readguard.hxx>
 #include <threadhelp/writeguard.hxx>
-
+#include <macros/xinterface.hxx>
+#include <macros/xtypeprovider.hxx>
+#include <macros/xserviceinfo.hxx>
 #include <acceleratorconst.h>
 #include <services.h>
 
-#include <com/sun/star/io/XActiveDataSource.hpp>
+#include <com/sun/star/lang/XInitialization.hpp>
+#include <com/sun/star/ui/XUIConfigurationStorage.hpp>
 
-#include <com/sun/star/io/XSeekable.hpp>
-
-#include <com/sun/star/io/XTruncate.hpp>
+#include <cppuhelper/implbase2.hxx>
+#include <comphelper/sequenceashashmap.hxx>
+#include <i18nlangtag/languagetag.hxx>
+#include <rtl/ref.hxx>
 
-#include <com/sun/star/embed/ElementModes.hpp>
+using namespace framework;
 
-#include <com/sun/star/xml/sax/InputSource.hpp>
+namespace {
 
-#include <com/sun/star/xml/sax/XParser.hpp>
+/**
+    implements a read/write access to a document
+    based accelerator configuration.
+ */
 
-#include <comphelper/sequenceashashmap.hxx>
-#include <i18nlangtag/languagetag.hxx>
+typedef ::cppu::ImplInheritanceHelper2<
+             XMLBasedAcceleratorConfiguration,
+             css::lang::XServiceInfo,
+             css::lang::XInitialization > DocumentAcceleratorConfiguration_BASE;
 
-namespace framework
+class DocumentAcceleratorConfiguration : public DocumentAcceleratorConfiguration_BASE
 {
+private:
 
-//-----------------------------------------------
-// XInterface, XTypeProvider, XServiceInfo
+    //----------------------------------
+    /** points to the root storage of the outside document,
+        where we can read/save our configuration data. */
+    css::uno::Reference< css::embed::XStorage > m_xDocumentRoot;
+
+//______________________________________
+// interface
+
+public:
+
+    /** initialize this instance and fill the internal cache.
+
+        @param  xSMGR
+                reference to an uno service manager, which is used internaly.
+     */
+    DocumentAcceleratorConfiguration(const css::uno::Reference< css::uno::XComponentContext >& xContext);
+    virtual ~DocumentAcceleratorConfiguration();
+
+    // XInterface, XTypeProvider, XServiceInfo
+    DECLARE_XSERVICEINFO
+
+    // XInitialization
+    virtual void SAL_CALL initialize(const css::uno::Sequence< css::uno::Any >& lArguments)
+        throw(css::uno::Exception       ,
+              css::uno::RuntimeException);
+
+    // XUIConfigurationStorage
+    virtual void SAL_CALL setStorage(const css::uno::Reference< css::embed::XStorage >& xStorage)
+        throw(css::uno::RuntimeException);
+
+    virtual sal_Bool SAL_CALL hasStorage()
+        throw(css::uno::RuntimeException);
+
+private:
+
+    /** read all data into the cache. */
+    void impl_ts_fillCache();
+
+    /** forget all currently cached data AND(!)
+        forget all currently used storages. */
+    void impl_ts_clearCache();
+};
 
 DEFINE_XSERVICEINFO_MULTISERVICE_2(DocumentAcceleratorConfiguration                   ,
                                    ::cppu::OWeakObject                                ,
@@ -185,4 +235,20 @@ void DocumentAcceleratorConfiguration::impl_ts_clearCache()
 
 } // namespace framework
 
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface * SAL_CALL
+com_sun_star_comp_framework_DocumentAcceleratorConfiguration_get_implementation(
+        css::uno::XComponentContext * context,
+        uno_Sequence * arguments)
+{
+    assert(arguments != 0);
+    rtl::Reference<DocumentAcceleratorConfiguration> x(
+            new DocumentAcceleratorConfiguration(context));
+    css::uno::Sequence<css::uno::Any> aArgs(
+            reinterpret_cast<css::uno::Any *>(arguments->elements),
+            arguments->nElements);
+    x->initialize(aArgs);
+    x->acquire();
+    return static_cast<cppu::OWeakObject *>(x.get());
+}
+
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/framework/source/inc/accelerators/documentacceleratorconfiguration.hxx b/framework/source/inc/accelerators/documentacceleratorconfiguration.hxx
deleted file mode 100644
index fdf4045..0000000
--- a/framework/source/inc/accelerators/documentacceleratorconfiguration.hxx
+++ /dev/null
@@ -1,111 +0,0 @@
-/* -*- 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_FRAMEWORK_SOURCE_INC_ACCELERATORS_DOCUMENTACCELERATORCONFIGURATION_HXX
-#define INCLUDED_FRAMEWORK_SOURCE_INC_ACCELERATORS_DOCUMENTACCELERATORCONFIGURATION_HXX
-
-#include <accelerators/acceleratorconfiguration.hxx>
-#include <accelerators/istoragelistener.hxx>
-#include <accelerators/presethandler.hxx>
-
-#include <macros/xinterface.hxx>
-#include <macros/xtypeprovider.hxx>
-#include <macros/xserviceinfo.hxx>
-
-#include <com/sun/star/lang/XInitialization.hpp>
-#include <com/sun/star/ui/XUIConfigurationStorage.hpp>
-
-#include <cppuhelper/implbase2.hxx>
-// definition
-
-namespace framework
-{
-
-//__________________________________________
-/**
-    implements a read/write access to a document
-    based accelerator configuration.
- */
-
-typedef ::cppu::ImplInheritanceHelper2<
-             XMLBasedAcceleratorConfiguration,
-             css::lang::XServiceInfo,
-             css::lang::XInitialization > DocumentAcceleratorConfiguration_BASE;
-
-class DocumentAcceleratorConfiguration : public DocumentAcceleratorConfiguration_BASE
-{
-    //______________________________________
-    // member
-
-    private:
-
-        //----------------------------------
-        /** points to the root storage of the outside document,
-            where we can read/save our configuration data. */
-        css::uno::Reference< css::embed::XStorage > m_xDocumentRoot;
-
-    //______________________________________
-    // interface
-
-    public:
-
-        //----------------------------------
-        /** initialize this instance and fill the internal cache.
-
-            @param  xSMGR
-                    reference to an uno service manager, which is used internaly.
-         */
-        DocumentAcceleratorConfiguration(const css::uno::Reference< css::uno::XComponentContext >& xContext);
-        virtual ~DocumentAcceleratorConfiguration();
-
-        // XInterface, XTypeProvider, XServiceInfo
-        DECLARE_XSERVICEINFO
-
-        // XInitialization
-        virtual void SAL_CALL initialize(const css::uno::Sequence< css::uno::Any >& lArguments)
-            throw(css::uno::Exception       ,
-                  css::uno::RuntimeException);
-
-        // XUIConfigurationStorage
-        virtual void SAL_CALL setStorage(const css::uno::Reference< css::embed::XStorage >& xStorage)
-            throw(css::uno::RuntimeException);
-
-        virtual sal_Bool SAL_CALL hasStorage()
-            throw(css::uno::RuntimeException);
-
-    //______________________________________
-    // helper
-
-    private:
-
-        //----------------------------------
-        /** read all data into the cache. */
-        void impl_ts_fillCache();
-
-        //----------------------------------
-        /** forget all currently cached data AND(!)
-            forget all currently used storages. */
-        void impl_ts_clearCache();
-};
-
-} // namespace framework
-
-#endif // INCLUDED_FRAMEWORK_SOURCE_INC_ACCELERATORS_DOCUMENTACCELERATORCONFIGURATION_HXX
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/framework/source/register/registerservices.cxx b/framework/source/register/registerservices.cxx
index c056ad1..e1c2c9c 100644
--- a/framework/source/register/registerservices.cxx
+++ b/framework/source/register/registerservices.cxx
@@ -35,7 +35,6 @@
 =================================================================================================================*/
 #include <services/desktop.hxx>
 #include <uielement/controlmenucontroller.hxx>
-#include <accelerators/documentacceleratorconfiguration.hxx>
 #include <uielement/recentfilesmenucontroller.hxx>
 #include <services/sessionlistener.hxx>
 
@@ -44,7 +43,6 @@
 COMPONENTGETFACTORY ( fwk,
                         IFFACTORY( ::framework::Desktop                                 )   else
                         IFFACTORY( ::framework::ControlMenuController                   )   else
-                        IFFACTORY( ::framework::DocumentAcceleratorConfiguration        )   else
                         IFFACTORY( ::framework::RecentFilesMenuController               )   else
                         IFFACTORY( ::framework::SessionListener                         )   else
                         IFFACTORY( ::framework::SessionListener                         )   else
diff --git a/framework/util/fwk.component b/framework/util/fwk.component
index 2680717..a7c33c0 100644
--- a/framework/util/fwk.component
+++ b/framework/util/fwk.component
@@ -36,7 +36,8 @@
   <implementation name="com.sun.star.comp.framework.Desktop">
     <service name="com.sun.star.frame.Desktop"/>
   </implementation>
-  <implementation name="com.sun.star.comp.framework.DocumentAcceleratorConfiguration">
+  <implementation name="com.sun.star.comp.framework.DocumentAcceleratorConfiguration"
+      constructor="com_sun_star_comp_framework_DocumentAcceleratorConfiguration_get_implementation">
     <service name="com.sun.star.ui.DocumentAcceleratorConfiguration"/>
   </implementation>
   <implementation name="org.apache.openoffice.comp.framework.ContextChangeEventMultiplexer">
commit 49fe81621bf544f8031a5c477abb2c1d0c3827de
Author: Matúš Kukan <matus.kukan at collabora.com>
Date:   Thu Jan 9 20:53:32 2014 +0100

    fwk: Use constructor feature for Frame.
    
    Change-Id: I5f7ee46671b22d17c5cb060f96342727d566fa21

diff --git a/framework/inc/dispatch/dispatchprovider.hxx b/framework/inc/dispatch/dispatchprovider.hxx
index 741930a..6c6e928 100644
--- a/framework/inc/dispatch/dispatchprovider.hxx
+++ b/framework/inc/dispatch/dispatchprovider.hxx
@@ -20,8 +20,6 @@
 #ifndef INCLUDED_FRAMEWORK_INC_DISPATCH_DISPATCHPROVIDER_HXX
 #define INCLUDED_FRAMEWORK_INC_DISPATCH_DISPATCHPROVIDER_HXX
 
-#include <services/frame.hxx>
-
 #include <classes/protocolhandlercache.hxx>
 #include <threadhelp/threadhelpbase.hxx>
 
@@ -35,7 +33,9 @@
 #include <com/sun/star/frame/XDispatchProvider.hpp>
 #include <com/sun/star/util/URL.hpp>
 #include <com/sun/star/frame/DispatchDescriptor.hpp>
+#include <com/sun/star/frame/XFrame.hpp>
 #include <com/sun/star/beans/PropertyValue.hpp>
+#include <com/sun/star/uno/XComponentContext.hpp>
 
 #include <cppuhelper/implbase1.hxx>
 #include <cppuhelper/weakref.hxx>
diff --git a/framework/inc/dispatch/interceptionhelper.hxx b/framework/inc/dispatch/interceptionhelper.hxx
index 529256b..cceb602 100644
--- a/framework/inc/dispatch/interceptionhelper.hxx
+++ b/framework/inc/dispatch/interceptionhelper.hxx
@@ -20,13 +20,11 @@
 #ifndef INCLUDED_FRAMEWORK_INC_DISPATCH_INTERCEPTIONHELPER_HXX
 #define INCLUDED_FRAMEWORK_INC_DISPATCH_INTERCEPTIONHELPER_HXX
 
-#include <services/frame.hxx>
 #include <threadhelp/threadhelpbase.hxx>
 #include <macros/xinterface.hxx>
 #include <macros/generic.hxx>
 #include <general.h>
 
-#include <com/sun/star/lang/XMultiServiceFactory.hpp>
 #include <com/sun/star/frame/XDispatchProviderInterception.hpp>
 #include <com/sun/star/frame/XDispatchProviderInterceptor.hpp>
 #include <com/sun/star/frame/XDispatchProvider.hpp>
diff --git a/framework/inc/dispatch/menudispatcher.hxx b/framework/inc/dispatch/menudispatcher.hxx
index 7a957d5..8a6c25a 100644
--- a/framework/inc/dispatch/menudispatcher.hxx
+++ b/framework/inc/dispatch/menudispatcher.hxx
@@ -21,7 +21,6 @@
 #define INCLUDED_FRAMEWORK_INC_DISPATCH_MENUDISPATCHER_HXX
 
 #include <classes/taskcreator.hxx>
-#include <services/frame.hxx>
 #include <macros/generic.hxx>
 #include <macros/xinterface.hxx>
 #include <macros/xtypeprovider.hxx>
@@ -40,6 +39,7 @@
 #include <com/sun/star/frame/XLoadEventListener.hpp>
 #include <com/sun/star/frame/XDesktop.hpp>
 #include <com/sun/star/frame/FeatureStateEvent.hpp>
+#include <com/sun/star/frame/XFrame.hpp>
 #include <com/sun/star/frame/XFrameActionListener.hpp>
 
 #include <cppuhelper/implbase2.hxx>
diff --git a/framework/inc/dispatch/popupmenudispatcher.hxx b/framework/inc/dispatch/popupmenudispatcher.hxx
index c2fe7de..3ec5d83 100644
--- a/framework/inc/dispatch/popupmenudispatcher.hxx
+++ b/framework/inc/dispatch/popupmenudispatcher.hxx
@@ -20,7 +20,6 @@
 #ifndef INCLUDED_FRAMEWORK_INC_DISPATCH_POPUPMENUDISPATCHER_HXX
 #define INCLUDED_FRAMEWORK_INC_DISPATCH_POPUPMENUDISPATCHER_HXX
 
-#include <services/frame.hxx>
 #include <macros/xinterface.hxx>
 #include <macros/xtypeprovider.hxx>
 #include <macros/xserviceinfo.hxx>
diff --git a/framework/inc/services/frame.hxx b/framework/inc/services/frame.hxx
deleted file mode 100644
index ebd4001..0000000
--- a/framework/inc/services/frame.hxx
+++ /dev/null
@@ -1,450 +0,0 @@
-/* -*- 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_FRAMEWORK_INC_SERVICES_FRAME_HXX
-#define INCLUDED_FRAMEWORK_INC_SERVICES_FRAME_HXX
-
-#include <classes/framecontainer.hxx>
-#include <classes/propertysethelper.hxx>
-#include <threadhelp/resetableguard.hxx>
-#include <threadhelp/writeguard.hxx>
-#include <threadhelp/readguard.hxx>
-#include <threadhelp/threadhelpbase.hxx>
-
-#include <threadhelp/transactionbase.hxx>
-#include <macros/generic.hxx>
-#include <macros/xinterface.hxx>
-#include <macros/xtypeprovider.hxx>
-#include <macros/xserviceinfo.hxx>
-#include <general.h>
-
-#include <com/sun/star/awt/XTopWindowListener.hpp>
-#include <com/sun/star/awt/XWindow.hpp>
-#include <com/sun/star/awt/XTopWindow.hpp>
-#include <com/sun/star/awt/XWindowListener.hpp>
-#include <com/sun/star/awt/XFocusListener.hpp>
-#include <com/sun/star/awt/FocusEvent.hpp>
-#include <com/sun/star/datatransfer/dnd/XDropTargetListener.hpp>
-#include <com/sun/star/document/XActionLockable.hpp>
-#include <com/sun/star/lang/XEventListener.hpp>
-#include <com/sun/star/frame/XComponentLoader.hpp>
-#include <com/sun/star/frame/XController.hpp>
-#include <com/sun/star/frame/XDispatch.hpp>
-#include <com/sun/star/frame/XDispatchProviderInterceptor.hpp>
-#include <com/sun/star/frame/XFrame2.hpp>
-#include <com/sun/star/frame/XFrameActionListener.hpp>
-#include <com/sun/star/frame/XLayoutManager2.hpp>
-#include <com/sun/star/frame/XTitle.hpp>
-#include <com/sun/star/frame/XTitleChangeBroadcaster.hpp>
-#include <com/sun/star/task/XStatusIndicator.hpp>
-#include <com/sun/star/util/XCloseable.hpp>
-
-#include <unotools/cmdoptions.hxx>
-#include <cppuhelper/interfacecontainer.hxx>
-#include <cppuhelper/weak.hxx>
-#include <rtl/string.hxx>
-
-namespace framework{
-
-// This enum can be used to set different active states of frames
-enum EActiveState
-{
-    E_INACTIVE      ,   // I'am not a member of active path in tree and i don't have the focus.
-    E_ACTIVE        ,   // I'am in the middle of an active path in tree and i don't have the focus.
-    E_FOCUS             // I have the focus now. I must a member of an active path!
-};
-
-class WindowCommandDispatch;
-
-/*-************************************************************************************************************//**
-    @short      implements a normal frame of hierarchy
-    @descr      An instance of these class can be a normal node in frame tree. A frame support influencing of his
-                subtree, find of subframes, activate- and deactivate-mechanism as well as
-                set/get of a frame window, component or controller.
-
-    @attention  This implementation supports three states: a)uninitialized, b)working, c)disposed
-                If you call wrong methods in modes a) or c) ... you will get some exceptions.
-                How you should work with this service:
-                    i)      create it by using "xServiceManager->createInstance(...)"
-                    ii)     call XInitialization::initialize() with a valid window reference or use createInstanceWithArguments() at i)
-                    iii)    works with object
-                    iv)     dispose object by calling XComponent::dispose()
-                After iv) all further requests are rejected by exceptions! (DisposedException)
-
-    @base       ThreadHelpBase
-                    help to guarantee correct initialized lock member at startup
-    @base       TransactionBase
-                    help to implement unbreakable interface calls
-    @base       OBroadcastHelper
-                OPropertySetHelper
-                    implements the property set
-    @base       OWeakObject
-                    provides the refcount and XInterface, XWeak
-
-    @devstatus  ready to use
-    @threadsafe yes
-*//*-*************************************************************************************************************/
-class Frame :   // interfaces
-                public  css::lang::XTypeProvider                    ,
-                public  css::lang::XServiceInfo                     ,
-                public  css::frame::XFrame2                         ,
-                public  css::awt::XWindowListener                   ,   // => XEventListener
-                public  css::awt::XTopWindowListener                ,
-                public  css::awt::XFocusListener                    ,
-                public  css::document::XActionLockable              ,
-                public  css::util::XCloseable                       ,   // => XCloseBroadcaster
-                public  css::frame::XComponentLoader                ,
-                public  css::frame::XTitle                          ,
-                public  css::frame::XTitleChangeBroadcaster         ,
-                // base classes
-                // Order is necessary for right initialization of this class!
-                public  ThreadHelpBase                              ,
-                public  TransactionBase                             ,
-                public  PropertySetHelper                           ,   // helper implements ThreadHelpbase, TransactionBase, XPropertySet, XPropertySetInfo
-                public  ::cppu::OWeakObject                             // helper implements XInterface, XWeak
-{
-    //-------------------------------------------------------------------------------------------------------------
-    //  public methods
-    //-------------------------------------------------------------------------------------------------------------
-
-    public:
-
-        //---------------------------------------------------------------------------------------------------------
-        //  constructor / destructor
-        //---------------------------------------------------------------------------------------------------------
-                  Frame( const css::uno::Reference< css::uno::XComponentContext >& xContext );
-        virtual ~Frame(                                                                     );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XInterface, XTypeProvider, XServiceInfo
-        //---------------------------------------------------------------------------------------------------------
-        FWK_DECLARE_XINTERFACE
-        FWK_DECLARE_XTYPEPROVIDER
-        DECLARE_XSERVICEINFO
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XComponentLoader
-        //---------------------------------------------------------------------------------------------------------
-        virtual css::uno::Reference< css::lang::XComponent >        SAL_CALL loadComponentFromURL               ( const OUString&                                                        sURL                ,
-                                                                                                                  const OUString&                                                        sTargetFrameName    ,
-                                                                                                                        sal_Int32                                                               nSearchFlags        ,
-                                                                                                                  const css::uno::Sequence< css::beans::PropertyValue >&                        lArguments          ) throw( css::io::IOException                ,
-                                                                                                                                                                                                                             css::lang::IllegalArgumentException ,
-                                                                                                                                                                                                                             css::uno::RuntimeException          );
-
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XFramesSupplier
-        //---------------------------------------------------------------------------------------------------------
-        virtual css::uno::Reference< css::frame::XFrames >          SAL_CALL getFrames                          (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual css::uno::Reference< css::frame::XFrame >           SAL_CALL getActiveFrame                     (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL setActiveFrame                     (   const   css::uno::Reference< css::frame::XFrame >&                          xFrame              ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XFrame
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL initialize                         (   const   css::uno::Reference< css::awt::XWindow >&                           xWindow             ) throw( css::uno::RuntimeException );
-        virtual css::uno::Reference< css::awt::XWindow >            SAL_CALL getContainerWindow                 (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL setCreator                         (   const   css::uno::Reference< css::frame::XFramesSupplier >&                 xCreator            ) throw( css::uno::RuntimeException );
-        virtual css::uno::Reference< css::frame::XFramesSupplier >  SAL_CALL getCreator                         (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual OUString                                     SAL_CALL getName                            (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL setName                            (   const   OUString&                                                    sName               ) throw( css::uno::RuntimeException );
-        virtual css::uno::Reference< css::frame::XFrame >           SAL_CALL findFrame                          (   const   OUString&                                                    sTargetFrameName    ,
-                                                                                                                            sal_Int32                                                           nSearchFlags        ) throw( css::uno::RuntimeException );
-        virtual sal_Bool                                            SAL_CALL isTop                              (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL activate                           (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL deactivate                         (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual sal_Bool                                            SAL_CALL isActive                           (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL contextChanged                     (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual sal_Bool                                            SAL_CALL setComponent                       (   const   css::uno::Reference< css::awt::XWindow >&                           xComponentWindow    ,
-                                                                                                                    const   css::uno::Reference< css::frame::XController >&                     xController         ) throw( css::uno::RuntimeException );
-        virtual css::uno::Reference< css::awt::XWindow >            SAL_CALL getComponentWindow                 (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual css::uno::Reference< css::frame::XController >      SAL_CALL getController                      (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL addFrameActionListener             (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL removeFrameActionListener          (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XComponent
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL dispose                            (                                                                                                   ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL addEventListener                   (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL removeEventListener                (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XStatusIndicatorFactory
-        //---------------------------------------------------------------------------------------------------------
-        virtual css::uno::Reference< css::task::XStatusIndicator >  SAL_CALL createStatusIndicator              (                                                                                                   ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XDispatchProvider
-        //---------------------------------------------------------------------------------------------------------
-        virtual css::uno::Reference< css::frame::XDispatch >        SAL_CALL queryDispatch                      (   const   css::util::URL&                                                     aURL                ,
-                                                                                                                    const   OUString&                                                    sTargetFrameName    ,
-                                                                                                                            sal_Int32                                                           nSearchFlags        ) throw( css::uno::RuntimeException );
-        virtual css::uno::Sequence<
-                    css::uno::Reference< css::frame::XDispatch > >  SAL_CALL queryDispatches                    (   const   css::uno::Sequence< css::frame::DispatchDescriptor >&               lDescriptor         ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XDispatchProviderInterception
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL registerDispatchProviderInterceptor(   const   css::uno::Reference< css::frame::XDispatchProviderInterceptor >&    xInterceptor        ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL releaseDispatchProviderInterceptor (   const   css::uno::Reference< css::frame::XDispatchProviderInterceptor >&    xInterceptor        ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XDispatchInformationProvider
-        //---------------------------------------------------------------------------------------------------------
-        virtual css::uno::Sequence< sal_Int16 >                       SAL_CALL getSupportedCommandGroups         (                       ) throw (css::uno::RuntimeException);
-        virtual css::uno::Sequence< css::frame::DispatchInformation > SAL_CALL getConfigurableDispatchInformation(sal_Int16 nCommandGroup) throw (css::uno::RuntimeException);
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XWindowListener
-        //  Attention: windowResized() and windowShown() are implement only! All other are empty!
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL windowResized                      (   const   css::awt::WindowEvent&                                              aEvent              ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL windowMoved                        (   const   css::awt::WindowEvent&                                              /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
-        virtual void                                                SAL_CALL windowShown                        (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL windowHidden                       (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XFocusListener
-        //  Attention: focusLost() not implemented yet!
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL focusGained                        (   const   css::awt::FocusEvent&                                               aEvent              ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL focusLost                          (   const   css::awt::FocusEvent&                                               /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XTopWindowListener
-        //  Attention: windowActivated(), windowDeactivated() and windowClosing() are implement only! All other are empty!
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL windowActivated                    (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL windowDeactivated                  (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL windowOpened                       (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
-        virtual void                                                SAL_CALL windowClosing                      (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
-        virtual void                                                SAL_CALL windowClosed                       (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
-        virtual void                                                SAL_CALL windowMinimized                    (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
-        virtual void                                                SAL_CALL windowNormalized                   (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XEventListener
-        //---------------------------------------------------------------------------------------------------------
-        virtual void                                                SAL_CALL disposing                          (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XActionLockable
-        //---------------------------------------------------------------------------------------------------------
-        virtual sal_Bool    SAL_CALL isActionLocked  (                 ) throw( css::uno::RuntimeException );
-        virtual void        SAL_CALL addActionLock   (                 ) throw( css::uno::RuntimeException );
-        virtual void        SAL_CALL removeActionLock(                 ) throw( css::uno::RuntimeException );
-        virtual void        SAL_CALL setActionLocks  ( sal_Int16 nLock ) throw( css::uno::RuntimeException );
-        virtual sal_Int16   SAL_CALL resetActionLocks(                 ) throw( css::uno::RuntimeException );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XCloseable
-        //---------------------------------------------------------------------------------------------------------
-        virtual void SAL_CALL close( sal_Bool bDeliverOwnership ) throw( css::util::CloseVetoException,
-                                                                         css::uno::RuntimeException   );
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XCloseBroadcaster
-        //---------------------------------------------------------------------------------------------------------
-        virtual void SAL_CALL addCloseListener   ( const css::uno::Reference< css::util::XCloseListener >& xListener ) throw (css::uno::RuntimeException);
-        virtual void SAL_CALL removeCloseListener( const css::uno::Reference< css::util::XCloseListener >& xListener ) throw (css::uno::RuntimeException);
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XTitle
-        //---------------------------------------------------------------------------------------------------------
-        virtual OUString SAL_CALL getTitle(                               ) throw (css::uno::RuntimeException);
-        virtual void            SAL_CALL setTitle( const OUString& sTitle ) throw (css::uno::RuntimeException);
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XTitleChangeBroadcaster
-        //---------------------------------------------------------------------------------------------------------
-        virtual void SAL_CALL addTitleChangeListener   ( const css::uno::Reference< css::frame::XTitleChangeListener >& xListener) throw (css::uno::RuntimeException);
-        virtual void SAL_CALL removeTitleChangeListener( const css::uno::Reference< css::frame::XTitleChangeListener >& xListenr ) throw (css::uno::RuntimeException);
-
-
-        //---------------------------------------------------------------------------------------------------------
-        //  XFrame2 attributes
-        //---------------------------------------------------------------------------------------------------------
-        virtual css::uno::Reference<css::container::XNameContainer> SAL_CALL getUserDefinedAttributes() throw (css::uno::RuntimeException);
-
-        virtual css::uno::Reference<css::frame::XDispatchRecorderSupplier> SAL_CALL getDispatchRecorderSupplier() throw (css::uno::RuntimeException);
-        virtual void SAL_CALL setDispatchRecorderSupplier(const css::uno::Reference<css::frame::XDispatchRecorderSupplier>&) throw (css::uno::RuntimeException);
-
-        virtual css::uno::Reference<css::uno::XInterface> SAL_CALL getLayoutManager() throw (css::uno::RuntimeException);
-        virtual void SAL_CALL setLayoutManager(const css::uno::Reference<css::uno::XInterface>&) throw (css::uno::RuntimeException);
-
-
-        //---------------------------------------------------------------------------------------------------------
-        //  PropertySetHelper => XPropertySet, XPropertySetInfo
-        //---------------------------------------------------------------------------------------------------------
-    private:
-
-        void impl_initializePropInfo();
-
-        virtual void SAL_CALL impl_setPropertyValue(const OUString& sProperty,
-                                                          sal_Int32        nHandle  ,
-                                                    const css::uno::Any&   aValue   );
-
-        virtual css::uno::Any SAL_CALL impl_getPropertyValue(const OUString& sProperty,
-                                                                   sal_Int32        nHandle  );
-
-    //-------------------------------------------------------------------------------------------------------------
-    //  private methods
-    //-------------------------------------------------------------------------------------------------------------
-
-    private:
-
-        /*-****************************************************************************************************//**
-            @short      helper methods
-            @descr      Follow methods are needed at different points of our code (more then ones!).
-
-            @attention  Threadsafe methods are signed by "implts_..."!
-        *//*-*****************************************************************************************************/
-
-        // threadsafe
-        void                                                    implts_sendFrameActionEvent     ( const css::frame::FrameAction&                        aAction          );
-        void                                                    implts_resizeComponentWindow    (                                                                        );
-        void                                                    implts_setIconOnWindow          (                                                                        );
-        void                                                    implts_startWindowListening     (                                                                        );
-        void                                                    implts_stopWindowListening      (                                                                        );
-        void                                                    implts_saveWindowAttributes     (                                                                        );
-        void                                                    implts_checkSuicide             (                                                                        );
-        void                                                    implts_forgetSubFrames          (                                                                        );
-        DECL_LINK( implts_windowClosing, void* );
-        css::uno::Reference< css::awt::XTopWindow >             impl_searchTopWindow            ( const css::uno::Reference< css::awt::XWindow >&       xWindow          );
-
-        // non threadsafe
-        void                                                    impl_checkMenuCloser            (                                                                        );
-        void                                                    impl_setCloser                  ( const css::uno::Reference< css::frame::XFrame2 >&     xFrame           ,
-                                                                                                        sal_Bool                                        bState           );
-        void                                                    impl_disposeContainerWindow     (       css::uno::Reference< css::awt::XWindow >&       xWindow          );
-        static const css::uno::Sequence< css::beans::Property > impl_getStaticPropertyDescriptor(                                                                        );
-
-    //-------------------------------------------------------------------------------------------------------------
-    //  debug methods
-    //  (should be private everyway!)
-    //-------------------------------------------------------------------------------------------------------------
-
-        /*-****************************************************************************************************//**
-            @short      debug-method to check incoming parameter of some other mehods of this class
-            @descr      The following methods are used to check parameters for other methods
-                        of this class. The return value is used directly for an ASSERT(...).
-
-            @attention  This methods are static and can't use our member directly! It's better for threadsafe code...
-                        because we call it with references or pointer to check variables ... and must make it safe
-                        by himself!
-
-            @seealso    ASSERTs in implementation!
-
-            @param      references to checking variables
-            @return     sal_True  ,on invalid parameter
-            @return     sal_False ,otherwise
-
-            @onerror    We return sal_True
-        *//*-*****************************************************************************************************/
-
-    private:
-
-        static sal_Bool implcp_ctor                                (   const   css::uno::Reference< css::uno::XComponentContext >&                 xContext            );
-        static sal_Bool implcp_setActiveFrame                      (   const   css::uno::Reference< css::frame::XFrame >&                          xFrame              );
-        static sal_Bool implcp_addFrameActionListener              (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           );
-        static sal_Bool implcp_removeFrameActionListener           (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           );
-        static sal_Bool implcp_addEventListener                    (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           );
-        static sal_Bool implcp_removeEventListener                 (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           );
-        static sal_Bool implcp_windowResized                       (   const   css::awt::WindowEvent&                                              aEvent              );
-        static sal_Bool implcp_focusGained                         (   const   css::awt::FocusEvent&                                               aEvent              );
-        static sal_Bool implcp_windowActivated                     (   const   css::lang::EventObject&                                             aEvent              );
-        static sal_Bool implcp_windowDeactivated                   (   const   css::lang::EventObject&                                             aEvent              );
-        static sal_Bool implcp_disposing                           (   const   css::lang::EventObject&                                             aEvent              );
-
-    //*************************************************************************************************************
-    //  variables
-    //  -threadsafe by own read/write lock "m_aLock"
-    //*************************************************************************************************************
-    private:
-
-        css::uno::Reference< css::uno::XComponentContext >                      m_xContext                          ;   /// reference to factory, which has create this instance
-        css::uno::Reference< css::task::XStatusIndicatorFactory >               m_xIndicatorFactoryHelper           ;   /// reference to factory helper to create status indicator objects
-        css::uno::WeakReference< css::task::XStatusIndicator >                  m_xIndicatorInterception            ;   /// points to an external set progress, which should be used instead of the internal one.
-        css::uno::Reference< css::frame::XDispatchProvider >                    m_xDispatchHelper                   ;   /// helper for XDispatch/Provider and interception interfaces
-        css::uno::Reference< css::frame::XFrames >                              m_xFramesHelper                     ;   /// helper for XFrames, XIndexAccess and XElementAccess interfaces
-        ::cppu::OMultiTypeInterfaceContainerHelper                              m_aListenerContainer                ;   /// container for ALL Listener
-        css::uno::Reference< css::frame::XFramesSupplier >                      m_xParent                           ;   /// parent of this frame
-        css::uno::Reference< css::awt::XWindow >                                m_xContainerWindow                  ;   /// containerwindow of this frame for embedded components
-        css::uno::Reference< css::awt::XWindow >                                m_xComponentWindow                  ;   /// window of the actual component
-        css::uno::Reference< css::frame::XController >                          m_xController                       ;   /// controller of the actual frame
-        css::uno::Reference< css::datatransfer::dnd::XDropTargetListener >      m_xDropTargetListener               ;   /// listen to drag & drop
-        EActiveState                                                            m_eActiveState                      ;   /// state, if i'am a member of active path in tree or i have the focus or ...
-        OUString                                                         m_sName                             ;   /// name of this frame
-        sal_Bool                                                                m_bIsFrameTop                       ;   /// frame has no parent or the parent is a taskor the desktop
-        sal_Bool                                                                m_bConnected                        ;   /// due to FrameActionEvent
-        sal_Int16                                                               m_nExternalLockCount                ;
-        css::uno::Reference< css::frame::XDispatchRecorderSupplier >            m_xDispatchRecorderSupplier         ;   /// is used for dispatch recording and will be set/get from outside. Frame provide it only!
-        SvtCommandOptions                                                       m_aCommandOptions                   ;   /// ref counted class to support disabling commands defined by configuration file
-        sal_Bool                                                                m_bSelfClose                        ;   /// in case of CloseVetoException on method close() wqs thrown by ourself - we must close ourself later if no internal processes are running
-        sal_Bool                                                                m_bIsHidden                         ;   /// indicates, if this frame is used in hidden mode or not
-        static css::uno::WeakReference< css::frame::XFrame2 >                   m_xCloserFrame                      ;   /// holds the only frame, which must show the special closer menu item (can be NULL!)
-        css::uno::Reference< ::css::frame::XLayoutManager2 >                    m_xLayoutManager                    ;   /// is used to layout the child windows of the frame.
-        css::uno::Reference< css::frame::XDispatchInformationProvider >         m_xDispatchInfoHelper               ;
-        css::uno::Reference< css::frame::XTitle >                               m_xTitleHelper                      ;
-
-        WindowCommandDispatch*                                                  m_pWindowCommandDispatch            ;
-
-    protected:
-
-        FrameContainer                                                          m_aChildFrameContainer              ;   /// array of child frames
-
-        inline css::uno::Reference< css::uno::XComponentContext > impl_getComponentContext()
-        {
-            ReadGuard aReadLock( m_aLock );
-            return m_xContext;
-        }
-
-        inline OUString impl_getName()
-        {
-            ReadGuard aReadLock( m_aLock );
-            return m_sName;
-        }
-
-        inline css::uno::Reference< css::awt::XWindow > impl_getContainerWindow()
-        {
-            ReadGuard aReadLock( m_aLock );
-            return m_xContainerWindow;
-        }
-
-        inline css::uno::Reference< css::frame::XDispatchProvider > impl_getDispatchHelper()
-        {
-            ReadGuard aReadLock( m_aLock );
-            return m_xDispatchHelper;
-        }
-
-        inline css::uno::Reference< css::frame::XFramesSupplier > impl_getParent()
-        {
-            ReadGuard aReadLock( m_aLock );
-            return m_xParent;
-        }
-
-};      // class Frame
-
-}       // namespace framework
-
-#endif // INCLUDED_FRAMEWORK_INC_SERVICES_FRAME_HXX
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/framework/source/dispatch/interceptionhelper.cxx b/framework/source/dispatch/interceptionhelper.cxx
index ca358e5..c782ec6 100644
--- a/framework/source/dispatch/interceptionhelper.cxx
+++ b/framework/source/dispatch/interceptionhelper.cxx
@@ -18,6 +18,8 @@
  */
 
 #include <dispatch/interceptionhelper.hxx>
+#include <threadhelp/readguard.hxx>
+#include <threadhelp/writeguard.hxx>
 
 #include <com/sun/star/frame/XInterceptorInfo.hpp>
 
diff --git a/framework/source/dispatch/menudispatcher.cxx b/framework/source/dispatch/menudispatcher.cxx
index 751487a..fbf1ba1 100644
--- a/framework/source/dispatch/menudispatcher.cxx
+++ b/framework/source/dispatch/menudispatcher.cxx
@@ -21,6 +21,7 @@
 #include <general.h>
 #include <framework/menuconfiguration.hxx>
 #include <framework/addonmenu.hxx>
+#include <threadhelp/resetableguard.hxx>
 #include <services.h>
 
 #include <com/sun/star/frame/FrameSearchFlag.hpp>
diff --git a/framework/source/dispatch/popupmenudispatcher.cxx b/framework/source/dispatch/popupmenudispatcher.cxx
index c30629d..a360ed0 100644
--- a/framework/source/dispatch/popupmenudispatcher.cxx
+++ b/framework/source/dispatch/popupmenudispatcher.cxx
@@ -21,10 +21,14 @@
 #include <general.h>
 #include <framework/menuconfiguration.hxx>
 #include <framework/addonmenu.hxx>
+#include <threadhelp/readguard.hxx>
+#include <threadhelp/resetableguard.hxx>
+#include <threadhelp/writeguard.hxx>
 #include <services.h>
 #include <properties.h>
 
 #include <com/sun/star/frame/FrameSearchFlag.hpp>
+#include <com/sun/star/frame/XLayoutManager2.hpp>
 #include <com/sun/star/awt/WindowAttribute.hpp>
 #include <com/sun/star/awt/WindowDescriptor.hpp>
 #include <com/sun/star/awt/PosSize.hpp>
@@ -34,6 +38,7 @@
 #include <com/sun/star/beans/XPropertySet.hpp>
 #include <com/sun/star/container/XEnumeration.hpp>
 #include <com/sun/star/uri/UriReferenceFactory.hpp>
+#include <com/sun/star/ui/XUIElement.hpp>
 
 #include <ucbhelper/content.hxx>
 #include <osl/mutex.hxx>
diff --git a/framework/source/register/registerservices.cxx b/framework/source/register/registerservices.cxx
index 0366b83..c056ad1 100644
--- a/framework/source/register/registerservices.cxx
+++ b/framework/source/register/registerservices.cxx
@@ -34,7 +34,6 @@
                              )
 =================================================================================================================*/
 #include <services/desktop.hxx>
-#include <services/frame.hxx>
 #include <uielement/controlmenucontroller.hxx>
 #include <accelerators/documentacceleratorconfiguration.hxx>
 #include <uielement/recentfilesmenucontroller.hxx>
@@ -44,7 +43,6 @@
 
 COMPONENTGETFACTORY ( fwk,
                         IFFACTORY( ::framework::Desktop                                 )   else
-                        IFFACTORY( ::framework::Frame                                   )   else
                         IFFACTORY( ::framework::ControlMenuController                   )   else
                         IFFACTORY( ::framework::DocumentAcceleratorConfiguration        )   else
                         IFFACTORY( ::framework::RecentFilesMenuController               )   else
diff --git a/framework/source/services/frame.cxx b/framework/source/services/frame.cxx
index 44221a0..db05038 100644
--- a/framework/source/services/frame.cxx
+++ b/framework/source/services/frame.cxx
@@ -17,9 +17,7 @@
  *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
  */
 
-#include <services/frame.hxx>
 #include <dispatch/dispatchprovider.hxx>
-
 #include <dispatch/interceptionhelper.hxx>
 #include <dispatch/closedispatcher.hxx>
 #include <dispatch/windowcommanddispatch.hxx>
@@ -32,7 +30,17 @@
 #include <framework/framelistanalyzer.hxx>
 #include <helper/dockingareadefaultacceptor.hxx>
 #include <dispatch/dispatchinformationprovider.hxx>
+#include <classes/framecontainer.hxx>
+#include <classes/propertysethelper.hxx>
+#include <threadhelp/resetableguard.hxx>
+#include <threadhelp/writeguard.hxx>
+#include <threadhelp/readguard.hxx>
+#include <threadhelp/threadhelpbase.hxx>
 #include <threadhelp/transactionguard.hxx>
+#include <threadhelp/transactionbase.hxx>
+#include <macros/xserviceinfo.hxx>
+#include <general.h>
+
 #include <pattern/window.hxx>
 #include <services.h>
 #include <properties.h>
@@ -41,24 +49,18 @@
 #include <com/sun/star/awt/XDevice.hpp>
 #include <com/sun/star/awt/XTopWindow.hpp>
 #include <com/sun/star/awt/PosSize.hpp>
-#include <com/sun/star/awt/XWindowPeer.hpp>
-#include <com/sun/star/awt/XVclWindowPeer.hpp>
-#include <com/sun/star/awt/XDataTransferProviderAccess.hpp>
-#include <com/sun/star/awt/WindowAttribute.hpp>
 #include <com/sun/star/beans/PropertyAttribute.hpp>
 #include <com/sun/star/beans/PropertyValue.hpp>
 #include <com/sun/star/beans/XPropertySet.hpp>
-#include <com/sun/star/beans/XMaterialHolder.hpp>
 #include <com/sun/star/container/XIndexAccess.hpp>
 #include <com/sun/star/datatransfer/dnd/XDropTarget.hpp>
+#include <com/sun/star/frame/XFrame2.hpp>
 #include <com/sun/star/frame/XModel.hpp>
 #include <com/sun/star/frame/XTitleChangeBroadcaster.hpp>
 #include <com/sun/star/frame/LayoutManager.hpp>
 #include <com/sun/star/frame/XDesktop.hpp>
 #include <com/sun/star/frame/FrameSearchFlag.hpp>
-#include <com/sun/star/lang/XInitialization.hpp>
 #include <com/sun/star/lang/DisposedException.hpp>
-#include <com/sun/star/task/XStatusIndicatorSupplier.hpp>
 #include <com/sun/star/task/StatusIndicatorFactory.hpp>
 #include <com/sun/star/task/JobExecutor.hpp>
 #include <com/sun/star/task/XJobExecutor.hpp>
@@ -71,6 +73,9 @@
 #include <cppuhelper/typeprovider.hxx>
 #include <cppuhelper/factory.hxx>
 #include <cppuhelper/proptypehlp.hxx>
+#include <cppuhelper/interfacecontainer.hxx>
+#include <cppuhelper/weak.hxx>
+#include <rtl/ref.hxx>
 #include <rtl/ustrbuf.hxx>
 #include <vcl/window.hxx>
 #include <vcl/wrkwin.hxx>
@@ -81,10 +86,380 @@
 #include <comphelper/processfactory.hxx>
 #include <unotools/moduleoptions.hxx>
 #include <tools/diagnose_ex.h>
-
 #include <vcl/menu.hxx>
+#include <unotools/cmdoptions.hxx>
+
+using namespace framework;
 
-namespace framework{
+namespace {
+
+// This enum can be used to set different active states of frames
+enum EActiveState
+{
+    E_INACTIVE      ,   // I'am not a member of active path in tree and i don't have the focus.
+    E_ACTIVE        ,   // I'am in the middle of an active path in tree and i don't have the focus.
+    E_FOCUS             // I have the focus now. I must a member of an active path!
+};
+
+/*-************************************************************************************************************//**
+    @short      implements a normal frame of hierarchy
+    @descr      An instance of these class can be a normal node in frame tree. A frame support influencing of his
+                subtree, find of subframes, activate- and deactivate-mechanism as well as
+                set/get of a frame window, component or controller.
+
+    @attention  This implementation supports three states: a)uninitialized, b)working, c)disposed
+                If you call wrong methods in modes a) or c) ... you will get some exceptions.
+                How you should work with this service:
+                    i)      create it by using "xServiceManager->createInstance(...)"
+                    ii)     call XInitialization::initialize() with a valid window reference or use createInstanceWithArguments() at i)
+                    iii)    works with object
+                    iv)     dispose object by calling XComponent::dispose()
+                After iv) all further requests are rejected by exceptions! (DisposedException)
+
+    @base       ThreadHelpBase
+                    help to guarantee correct initialized lock member at startup
+    @base       TransactionBase
+                    help to implement unbreakable interface calls
+    @base       OBroadcastHelper
+                OPropertySetHelper
+                    implements the property set
+    @base       OWeakObject
+                    provides the refcount and XInterface, XWeak
+
+    @devstatus  ready to use
+    @threadsafe yes
+*//*-*************************************************************************************************************/
+class Frame :   // interfaces
+                public  css::lang::XTypeProvider                    ,
+                public  css::lang::XServiceInfo                     ,
+                public  css::frame::XFrame2                         ,
+                public  css::awt::XWindowListener                   ,   // => XEventListener
+                public  css::awt::XTopWindowListener                ,
+                public  css::awt::XFocusListener                    ,
+                public  css::document::XActionLockable              ,
+                public  css::util::XCloseable                       ,   // => XCloseBroadcaster
+                public  css::frame::XComponentLoader                ,
+                public  css::frame::XTitle                          ,
+                public  css::frame::XTitleChangeBroadcaster         ,
+                // base classes
+                // Order is necessary for right initialization of this class!
+                public  ThreadHelpBase                              ,
+                public  TransactionBase                             ,
+                public  PropertySetHelper                           ,   // helper implements ThreadHelpbase, TransactionBase, XPropertySet, XPropertySetInfo
+                public  ::cppu::OWeakObject                             // helper implements XInterface, XWeak
+{
+public:
+
+             Frame( const css::uno::Reference< css::uno::XComponentContext >& xContext );
+    virtual ~Frame();
+
+    FWK_DECLARE_XINTERFACE
+    FWK_DECLARE_XTYPEPROVIDER
+    DECLARE_XSERVICEINFO
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XComponentLoader
+    //---------------------------------------------------------------------------------------------------------
+    virtual css::uno::Reference< css::lang::XComponent > SAL_CALL loadComponentFromURL(
+            const OUString& sURL,
+            const OUString& sTargetFrameName,
+            sal_Int32 nSearchFlags,
+            const css::uno::Sequence< css::beans::PropertyValue >& lArguments )
+        throw( css::io::IOException,
+               css::lang::IllegalArgumentException,
+               css::uno::RuntimeException );
+
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XFramesSupplier
+    //---------------------------------------------------------------------------------------------------------
+    virtual css::uno::Reference< css::frame::XFrames >          SAL_CALL getFrames                          (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual css::uno::Reference< css::frame::XFrame >           SAL_CALL getActiveFrame                     (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL setActiveFrame                     (   const   css::uno::Reference< css::frame::XFrame >&                          xFrame              ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XFrame
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL initialize                         (   const   css::uno::Reference< css::awt::XWindow >&                           xWindow             ) throw( css::uno::RuntimeException );
+    virtual css::uno::Reference< css::awt::XWindow >            SAL_CALL getContainerWindow                 (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL setCreator                         (   const   css::uno::Reference< css::frame::XFramesSupplier >&                 xCreator            ) throw( css::uno::RuntimeException );
+    virtual css::uno::Reference< css::frame::XFramesSupplier >  SAL_CALL getCreator                         (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual OUString                                     SAL_CALL getName                            (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL setName                            (   const   OUString&                                                    sName               ) throw( css::uno::RuntimeException );
+    virtual css::uno::Reference< css::frame::XFrame >           SAL_CALL findFrame                          (   const   OUString&                                                    sTargetFrameName    ,
+                                                                                                                        sal_Int32                                                           nSearchFlags        ) throw( css::uno::RuntimeException );
+    virtual sal_Bool                                            SAL_CALL isTop                              (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL activate                           (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL deactivate                         (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual sal_Bool                                            SAL_CALL isActive                           (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL contextChanged                     (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual sal_Bool                                            SAL_CALL setComponent                       (   const   css::uno::Reference< css::awt::XWindow >&                           xComponentWindow    ,
+                                                                                                                const   css::uno::Reference< css::frame::XController >&                     xController         ) throw( css::uno::RuntimeException );
+    virtual css::uno::Reference< css::awt::XWindow >            SAL_CALL getComponentWindow                 (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual css::uno::Reference< css::frame::XController >      SAL_CALL getController                      (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL addFrameActionListener             (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL removeFrameActionListener          (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XComponent
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL dispose                            (                                                                                                   ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL addEventListener                   (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL removeEventListener                (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XStatusIndicatorFactory
+    //---------------------------------------------------------------------------------------------------------
+    virtual css::uno::Reference< css::task::XStatusIndicator >  SAL_CALL createStatusIndicator              (                                                                                                   ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XDispatchProvider
+    //---------------------------------------------------------------------------------------------------------
+    virtual css::uno::Reference< css::frame::XDispatch >        SAL_CALL queryDispatch                      (   const   css::util::URL&                                                     aURL                ,
+                                                                                                                const   OUString&                                                    sTargetFrameName    ,
+                                                                                                                        sal_Int32                                                           nSearchFlags        ) throw( css::uno::RuntimeException );
+    virtual css::uno::Sequence<
+                css::uno::Reference< css::frame::XDispatch > >  SAL_CALL queryDispatches                    (   const   css::uno::Sequence< css::frame::DispatchDescriptor >&               lDescriptor         ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XDispatchProviderInterception
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL registerDispatchProviderInterceptor(   const   css::uno::Reference< css::frame::XDispatchProviderInterceptor >&    xInterceptor        ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL releaseDispatchProviderInterceptor (   const   css::uno::Reference< css::frame::XDispatchProviderInterceptor >&    xInterceptor        ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XDispatchInformationProvider
+    //---------------------------------------------------------------------------------------------------------
+    virtual css::uno::Sequence< sal_Int16 >                       SAL_CALL getSupportedCommandGroups         (                       ) throw (css::uno::RuntimeException);
+    virtual css::uno::Sequence< css::frame::DispatchInformation > SAL_CALL getConfigurableDispatchInformation(sal_Int16 nCommandGroup) throw (css::uno::RuntimeException);
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XWindowListener
+    //  Attention: windowResized() and windowShown() are implement only! All other are empty!
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL windowResized                      (   const   css::awt::WindowEvent&                                              aEvent              ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL windowMoved                        (   const   css::awt::WindowEvent&                                              /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
+    virtual void                                                SAL_CALL windowShown                        (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL windowHidden                       (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XFocusListener
+    //  Attention: focusLost() not implemented yet!
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL focusGained                        (   const   css::awt::FocusEvent&                                               aEvent              ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL focusLost                          (   const   css::awt::FocusEvent&                                               /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XTopWindowListener
+    //  Attention: windowActivated(), windowDeactivated() and windowClosing() are implement only! All other are empty!
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL windowActivated                    (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL windowDeactivated                  (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL windowOpened                       (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
+    virtual void                                                SAL_CALL windowClosing                      (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
+    virtual void                                                SAL_CALL windowClosed                       (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
+    virtual void                                                SAL_CALL windowMinimized                    (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
+    virtual void                                                SAL_CALL windowNormalized                   (   const   css::lang::EventObject&                                             /*aEvent*/          ) throw( css::uno::RuntimeException ) {};
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XEventListener
+    //---------------------------------------------------------------------------------------------------------
+    virtual void                                                SAL_CALL disposing                          (   const   css::lang::EventObject&                                             aEvent              ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XActionLockable
+    //---------------------------------------------------------------------------------------------------------
+    virtual sal_Bool    SAL_CALL isActionLocked  (                 ) throw( css::uno::RuntimeException );
+    virtual void        SAL_CALL addActionLock   (                 ) throw( css::uno::RuntimeException );
+    virtual void        SAL_CALL removeActionLock(                 ) throw( css::uno::RuntimeException );
+    virtual void        SAL_CALL setActionLocks  ( sal_Int16 nLock ) throw( css::uno::RuntimeException );
+    virtual sal_Int16   SAL_CALL resetActionLocks(                 ) throw( css::uno::RuntimeException );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XCloseable
+    //---------------------------------------------------------------------------------------------------------
+    virtual void SAL_CALL close( sal_Bool bDeliverOwnership ) throw( css::util::CloseVetoException,
+                                                                     css::uno::RuntimeException   );
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XCloseBroadcaster
+    //---------------------------------------------------------------------------------------------------------
+    virtual void SAL_CALL addCloseListener   ( const css::uno::Reference< css::util::XCloseListener >& xListener ) throw (css::uno::RuntimeException);
+    virtual void SAL_CALL removeCloseListener( const css::uno::Reference< css::util::XCloseListener >& xListener ) throw (css::uno::RuntimeException);
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XTitle
+    //---------------------------------------------------------------------------------------------------------
+    virtual OUString SAL_CALL getTitle(                               ) throw (css::uno::RuntimeException);
+    virtual void            SAL_CALL setTitle( const OUString& sTitle ) throw (css::uno::RuntimeException);
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XTitleChangeBroadcaster
+    //---------------------------------------------------------------------------------------------------------
+    virtual void SAL_CALL addTitleChangeListener   ( const css::uno::Reference< css::frame::XTitleChangeListener >& xListener) throw (css::uno::RuntimeException);
+    virtual void SAL_CALL removeTitleChangeListener( const css::uno::Reference< css::frame::XTitleChangeListener >& xListenr ) throw (css::uno::RuntimeException);
+
+
+    //---------------------------------------------------------------------------------------------------------
+    //  XFrame2 attributes
+    //---------------------------------------------------------------------------------------------------------
+    virtual css::uno::Reference<css::container::XNameContainer> SAL_CALL getUserDefinedAttributes() throw (css::uno::RuntimeException);
+
+    virtual css::uno::Reference<css::frame::XDispatchRecorderSupplier> SAL_CALL getDispatchRecorderSupplier() throw (css::uno::RuntimeException);
+    virtual void SAL_CALL setDispatchRecorderSupplier(const css::uno::Reference<css::frame::XDispatchRecorderSupplier>&) throw (css::uno::RuntimeException);
+
+    virtual css::uno::Reference<css::uno::XInterface> SAL_CALL getLayoutManager() throw (css::uno::RuntimeException);
+    virtual void SAL_CALL setLayoutManager(const css::uno::Reference<css::uno::XInterface>&) throw (css::uno::RuntimeException);
+
+
+    //---------------------------------------------------------------------------------------------------------
+    //  PropertySetHelper => XPropertySet, XPropertySetInfo
+    //---------------------------------------------------------------------------------------------------------
+private:
+
+    void impl_initializePropInfo();
+
+    virtual void SAL_CALL impl_setPropertyValue(const OUString& sProperty,
+                                                      sal_Int32        nHandle  ,
+                                                const css::uno::Any&   aValue   );
+
+    virtual css::uno::Any SAL_CALL impl_getPropertyValue(const OUString& sProperty,
+                                                               sal_Int32        nHandle  );
+
+//-------------------------------------------------------------------------------------------------------------
+//  private methods
+//-------------------------------------------------------------------------------------------------------------
+
+private:
+
+    /*-****************************************************************************************************//**
+        @short      helper methods
+        @descr      Follow methods are needed at different points of our code (more then ones!).
+
+        @attention  Threadsafe methods are signed by "implts_..."!
+    *//*-*****************************************************************************************************/
+
+    // threadsafe
+    void implts_sendFrameActionEvent     ( const css::frame::FrameAction&                        aAction          );
+    void implts_resizeComponentWindow    (                                                                        );
+    void implts_setIconOnWindow          (                                                                        );
+    void implts_startWindowListening     (                                                                        );
+    void implts_stopWindowListening      (                                                                        );
+    void implts_saveWindowAttributes     (                                                                        );
+    void implts_checkSuicide             (                                                                        );
+    void implts_forgetSubFrames          (                                                                        );
+    DECL_LINK( implts_windowClosing, void* );
+    css::uno::Reference< css::awt::XTopWindow >             impl_searchTopWindow            ( const css::uno::Reference< css::awt::XWindow >&       xWindow          );
+
+    // non threadsafe
+    void impl_checkMenuCloser            (                                                                        );
+    void impl_setCloser                  ( const css::uno::Reference< css::frame::XFrame2 >& xFrame , sal_Bool bState );
+    void impl_disposeContainerWindow     (       css::uno::Reference< css::awt::XWindow >&       xWindow          );
+
+//-------------------------------------------------------------------------------------------------------------
+//  debug methods
+//  (should be private everyway!)
+//-------------------------------------------------------------------------------------------------------------
+
+    /*-****************************************************************************************************//**
+        @short      debug-method to check incoming parameter of some other mehods of this class
+        @descr      The following methods are used to check parameters for other methods
+                    of this class. The return value is used directly for an ASSERT(...).
+
+        @attention  This methods are static and can't use our member directly! It's better for threadsafe code...
+                    because we call it with references or pointer to check variables ... and must make it safe
+                    by himself!
+
+        @seealso    ASSERTs in implementation!
+
+        @param      references to checking variables
+        @return     sal_True  ,on invalid parameter
+        @return     sal_False ,otherwise
+
+        @onerror    We return sal_True
+    *//*-*****************************************************************************************************/
+
+private:
+
+    static sal_Bool implcp_ctor                                (   const   css::uno::Reference< css::uno::XComponentContext >&                 xContext            );
+    static sal_Bool implcp_setActiveFrame                      (   const   css::uno::Reference< css::frame::XFrame >&                          xFrame              );
+    static sal_Bool implcp_addFrameActionListener              (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           );
+    static sal_Bool implcp_removeFrameActionListener           (   const   css::uno::Reference< css::frame::XFrameActionListener >&            xListener           );
+    static sal_Bool implcp_addEventListener                    (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           );
+    static sal_Bool implcp_removeEventListener                 (   const   css::uno::Reference< css::lang::XEventListener >&                   xListener           );
+    static sal_Bool implcp_windowResized                       (   const   css::awt::WindowEvent&                                              aEvent              );
+    static sal_Bool implcp_focusGained                         (   const   css::awt::FocusEvent&                                               aEvent              );
+    static sal_Bool implcp_windowActivated                     (   const   css::lang::EventObject&                                             aEvent              );
+    static sal_Bool implcp_windowDeactivated                   (   const   css::lang::EventObject&                                             aEvent              );
+    static sal_Bool implcp_disposing                           (   const   css::lang::EventObject&                                             aEvent              );
+
+//*************************************************************************************************************
+//  variables
+//  -threadsafe by own read/write lock "m_aLock"
+//*************************************************************************************************************
+private:
+
+    css::uno::Reference< css::uno::XComponentContext >                      m_xContext                          ;   /// reference to factory, which has create this instance
+    css::uno::Reference< css::task::XStatusIndicatorFactory >               m_xIndicatorFactoryHelper           ;   /// reference to factory helper to create status indicator objects
+    css::uno::WeakReference< css::task::XStatusIndicator >                  m_xIndicatorInterception            ;   /// points to an external set progress, which should be used instead of the internal one.
+    css::uno::Reference< css::frame::XDispatchProvider >                    m_xDispatchHelper                   ;   /// helper for XDispatch/Provider and interception interfaces
+    css::uno::Reference< css::frame::XFrames >                              m_xFramesHelper                     ;   /// helper for XFrames, XIndexAccess and XElementAccess interfaces
+    ::cppu::OMultiTypeInterfaceContainerHelper                              m_aListenerContainer                ;   /// container for ALL Listener
+    css::uno::Reference< css::frame::XFramesSupplier >                      m_xParent                           ;   /// parent of this frame
+    css::uno::Reference< css::awt::XWindow >                                m_xContainerWindow                  ;   /// containerwindow of this frame for embedded components
+    css::uno::Reference< css::awt::XWindow >                                m_xComponentWindow                  ;   /// window of the actual component
+    css::uno::Reference< css::frame::XController >                          m_xController                       ;   /// controller of the actual frame
+    css::uno::Reference< css::datatransfer::dnd::XDropTargetListener >      m_xDropTargetListener               ;   /// listen to drag & drop
+    EActiveState                                                            m_eActiveState                      ;   /// state, if i'am a member of active path in tree or i have the focus or ...
+    OUString                                                         m_sName                             ;   /// name of this frame
+    sal_Bool                                                                m_bIsFrameTop                       ;   /// frame has no parent or the parent is a taskor the desktop
+    sal_Bool                                                                m_bConnected                        ;   /// due to FrameActionEvent
+    sal_Int16                                                               m_nExternalLockCount                ;
+    css::uno::Reference< css::frame::XDispatchRecorderSupplier >            m_xDispatchRecorderSupplier         ;   /// is used for dispatch recording and will be set/get from outside. Frame provide it only!
+    SvtCommandOptions                                                       m_aCommandOptions                   ;   /// ref counted class to support disabling commands defined by configuration file
+    sal_Bool                                                                m_bSelfClose                        ;   /// in case of CloseVetoException on method close() wqs thrown by ourself - we must close ourself later if no internal processes are running
+    sal_Bool                                                                m_bIsHidden                         ;   /// indicates, if this frame is used in hidden mode or not
+    static css::uno::WeakReference< css::frame::XFrame2 >                   m_xCloserFrame                      ;   /// holds the only frame, which must show the special closer menu item (can be NULL!)
+    css::uno::Reference< ::css::frame::XLayoutManager2 >                    m_xLayoutManager                    ;   /// is used to layout the child windows of the frame.
+    css::uno::Reference< css::frame::XDispatchInformationProvider >         m_xDispatchInfoHelper               ;
+    css::uno::Reference< css::frame::XTitle >                               m_xTitleHelper                      ;
+
+    WindowCommandDispatch*                                                  m_pWindowCommandDispatch            ;
+
+protected:
+
+    FrameContainer                                                          m_aChildFrameContainer              ;   /// array of child frames
+
+    inline css::uno::Reference< css::uno::XComponentContext > impl_getComponentContext()
+    {
+        ReadGuard aReadLock( m_aLock );
+        return m_xContext;
+    }
+
+    inline OUString impl_getName()
+    {
+        ReadGuard aReadLock( m_aLock );
+        return m_sName;
+    }
+
+    inline css::uno::Reference< css::awt::XWindow > impl_getContainerWindow()
+    {
+        ReadGuard aReadLock( m_aLock );
+        return m_xContainerWindow;
+    }
+
+    inline css::uno::Reference< css::frame::XDispatchProvider > impl_getDispatchHelper()
+    {
+        ReadGuard aReadLock( m_aLock );
+        return m_xDispatchHelper;
+    }
+
+    inline css::uno::Reference< css::frame::XFramesSupplier > impl_getParent()
+    {
+        ReadGuard aReadLock( m_aLock );
+        return m_xParent;
+    }
+};
 
 css::uno::WeakReference< css::frame::XFrame2 > Frame::m_xCloserFrame = css::uno::WeakReference< css::frame::XFrame2 >();
 
@@ -3262,6 +3637,17 @@ sal_Bool Frame::implcp_disposing( const css::lang::EventObject& aEvent )
             );
 }
 
-}   // namespace framework
+}
+
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface * SAL_CALL
+com_sun_star_comp_framework_Frame_get_implementation(
+        css::uno::XComponentContext * context,
+        uno_Sequence * arguments)
+{
+    assert(arguments != 0 && arguments->nElements == 0); (void) arguments;
+    rtl::Reference<Frame> x(new Frame(context));
+    x->acquire();
+    return static_cast<cppu::OWeakObject *>(x.get());
+}
 
 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/framework/util/fwk.component b/framework/util/fwk.component
index df010a5..2680717 100644
--- a/framework/util/fwk.component
+++ b/framework/util/fwk.component
@@ -42,7 +42,8 @@
   <implementation name="org.apache.openoffice.comp.framework.ContextChangeEventMultiplexer">
     <singleton name="com.sun.star.ui.ContextChangeEventMultiplexer"/>
   </implementation>
-  <implementation name="com.sun.star.comp.framework.Frame">
+  <implementation name="com.sun.star.comp.framework.Frame"
+      constructor="com_sun_star_comp_framework_Frame_get_implementation">
     <service name="com.sun.star.frame.Frame"/>
   </implementation>
   <implementation name="com.sun.star.comp.framework.GlobalAcceleratorConfiguration"
commit cbb72e01be5e42ff0b6af0b7d9adcb981d5c469b
Author: Matúš Kukan <matus.kukan at collabora.com>
Date:   Thu Jan 9 20:48:08 2014 +0100

    fwk: Use constructor feature for GlobalAcceleratorConfiguration.
    
    Change-Id: Ic0268e9841c78e5de646074755e99706adac8d7d

diff --git a/framework/source/accelerators/globalacceleratorconfiguration.cxx b/framework/source/accelerators/globalacceleratorconfiguration.cxx
index 737d1bc..8ac6126 100644
--- a/framework/source/accelerators/globalacceleratorconfiguration.cxx
+++ b/framework/source/accelerators/globalacceleratorconfiguration.cxx
@@ -17,29 +17,65 @@
  *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
  */
 
-#include <accelerators/globalacceleratorconfiguration.hxx>
+#include <accelerators/acceleratorconfiguration.hxx>
+#include <accelerators/presethandler.hxx>
+#include <macros/xserviceinfo.hxx>
 
 #include <threadhelp/readguard.hxx>
 #include <threadhelp/writeguard.hxx>
-#include "helper/mischelper.hxx"
+#include <helper/mischelper.hxx>
 
 #include <acceleratorconst.h>
 #include <services.h>
 
-#include <com/sun/star/beans/XPropertySet.hpp>
-#include <com/sun/star/embed/ElementModes.hpp>
-#include <com/sun/star/lang/XSingleServiceFactory.hpp>
-#include <com/sun/star/container/XNameAccess.hpp>
 #include <com/sun/star/util/XChangesNotifier.hpp>
 
+#include <rtl/ref.hxx>
 #include <vcl/svapp.hxx>
 #include <i18nlangtag/languagetag.hxx>
 
-namespace framework
+using namespace framework;
+
+namespace {
+
+/**
+    implements a read/write access to the global
+    accelerator configuration.
+ */
+typedef ::cppu::ImplInheritanceHelper1<
+             XCUBasedAcceleratorConfiguration,
+             css::lang::XServiceInfo > GlobalAcceleratorConfiguration_BASE;
+class GlobalAcceleratorConfiguration : public GlobalAcceleratorConfiguration_BASE
 {
+public:
 
-//-----------------------------------------------
-// XInterface, XTypeProvider, XServiceInfo
+    /** initialize this instance and fill the internal cache.
+
+        @param  xSMGR
+                reference to an uno service manager, which is used internaly.
+     */

... etc. - the rest is truncated


More information about the Libreoffice-commits mailing list