summaryrefslogtreecommitdiff
path: root/framework/source/application/framework.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'framework/source/application/framework.cxx')
-rw-r--r--framework/source/application/framework.cxx286
1 files changed, 286 insertions, 0 deletions
diff --git a/framework/source/application/framework.cxx b/framework/source/application/framework.cxx
new file mode 100644
index 000000000000..76044ae6bb51
--- /dev/null
+++ b/framework/source/application/framework.cxx
@@ -0,0 +1,286 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_framework.hxx"
+
+//_________________________________________________________________________________________________________________
+// my own includes
+//_________________________________________________________________________________________________________________
+
+#ifndef __FRAMEWORK_HELPER_OINSTANCEPROVIDER_HXX_
+#include <helper/oinstanceprovider.hxx>
+#endif
+#include <classes/servicemanager.hxx>
+#include <macros/debug.hxx>
+
+#ifndef __FRAMEWORK_DEFINES_HXX_
+#include <defines.hxx>
+#endif
+
+//_________________________________________________________________________________________________________________
+// interface includes
+//_________________________________________________________________________________________________________________
+#include <com/sun/star/frame/XDesktop.hpp>
+#include <com/sun/star/frame/XFrame.hpp>
+#include <com/sun/star/awt/XWindow.hpp>
+#include <com/sun/star/frame/XFrameLoader.hpp>
+#include <com/sun/star/beans/PropertyValue.hpp>
+#include <com/sun/star/frame/XLoadEventListener.hpp>
+#include <com/sun/star/frame/XDispatchProvider.hpp>
+#include <com/sun/star/util/URL.hpp>
+#include <com/sun/star/frame/FrameSearchFlag.hpp>
+#include <com/sun/star/frame/XFrames.hpp>
+
+#ifndef _COM_SUN_STAR_CONNECTION_XConnection_HPP_
+#include <com/sun/star/connection/XConnection.hpp>
+#endif
+
+#ifndef _COM_SUN_STAR_BRIDGE_XBridgeFactory_HPP_
+#include <com/sun/star/bridge/XBridgeFactory.hpp>
+#endif
+
+//_________________________________________________________________________________________________________________
+// other includes
+//_________________________________________________________________________________________________________________
+#include <comphelper/processfactory.hxx>
+#include <com/sun/star/uno/Reference.hxx>
+#include <rtl/ustring.hxx>
+#include <rtl/ustrbuf.hxx>
+#include <toolkit/helper/vclunohelper.hxx>
+#include <svtools/unoiface.hxx>
+#include <vcl/svapp.hxx>
+#include <vcl/wrkwin.hxx>
+#include <vos/process.hxx>
+
+//_________________________________________________________________________________________________________________
+// namespace
+//_________________________________________________________________________________________________________________
+
+using namespace ::rtl ;
+using namespace ::vos ;
+using namespace ::comphelper ;
+using namespace ::framework ;
+using namespace ::com::sun::star::uno ;
+using namespace ::com::sun::star::lang ;
+using namespace ::com::sun::star::frame ;
+using namespace ::com::sun::star::awt ;
+using namespace ::com::sun::star::beans ;
+using namespace ::com::sun::star::util ;
+using namespace ::com::sun::star::connection ;
+using namespace ::com::sun::star::bridge ;
+
+//_________________________________________________________________________________________________________________
+// const
+//_________________________________________________________________________________________________________________
+
+#define APPLICATIONNAME "FrameWork"
+#define COMMANDARGUMENT_PLUGIN DECLARE_ASCII("-plugin" )
+#define NAME_PLUGINBRIDGE DECLARE_ASCII("mozilla plugin bridge" )
+#define PROTOCOL_PLUGINBRIDGE DECLARE_ASCII("urp" )
+
+//_________________________________________________________________________________________________________________
+// declarations
+//_________________________________________________________________________________________________________________
+
+/*-************************************************************************************************************//**
+ @short normal application
+ @descr An instance of these class can be a normal node in frame tree only. The highest level to be allowed is 3!
+ On 1 stand the desktop himself as the only one, on 2 are all tasks present ... and then comes frames only.
+ 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.
+
+ @implements XInterface
+ XTypeProvider
+ XServiceInfo
+ XFramesSupplier
+ XFrame
+ XComponent
+ XStatusIndicatorSupplier
+ XDispatchProvider
+ XDispatchProviderInterception
+ XBrowseHistoryRegistry
+ XLoadEventListener
+ XEventListener
+ XWindowListener
+ XTopWindowListener
+ [ XDebugging, if TEST_TREE is defined! ]
+ @base OMutexMember
+ OWeakObject
+
+ @devstatus deprecated
+*//*-*************************************************************************************************************/
+class FrameWork : public Application
+{
+ //-------------------------------------------------------------------------------------------------------------
+ // public methods
+ //-------------------------------------------------------------------------------------------------------------
+
+ public:
+ void Main();
+
+ private:
+ void impl_analyzeCommandArguments();
+
+ private:
+ sal_Bool m_bUsePlugIn ;
+
+}; // class FrameWork
+
+//_________________________________________________________________________________________________________________
+// definitions
+//_________________________________________________________________________________________________________________
+
+//_________________________________________________________________________________________________________________
+// global variables
+//_________________________________________________________________________________________________________________
+
+FrameWork aFrameWork ;
+
+//_________________________________________________________________________________________________________________
+// definitions
+//_________________________________________________________________________________________________________________
+
+//*****************************************************************************************************************
+// private methods
+//*****************************************************************************************************************
+void FrameWork::impl_analyzeCommandArguments()
+{
+ // First reset all member variables which present states of incoming arguments!
+ m_bUsePlugIn = sal_False; // depends from "/plugin"
+
+ // Then step over all given arguments and search for supported one.
+ OStartupInfo aInfo ;
+ OUString sArgument ;
+ sal_uInt32 nCount = aInfo.getCommandArgCount();
+ for ( sal_uInt32 nArgument=0; nArgument<nCount; ++nArgument )
+ {
+ // If extraction of current argument successfull ...
+ if ( aInfo.getCommandArg( nArgument, sArgument ) == osl_Process_E_None )
+ {
+ // ... search for matching with supported values.
+ if ( sArgument == COMMANDARGUMENT_PLUGIN )
+ {
+ // We found "/plugin" => set internal equivalent.
+ m_bUsePlugIn = sal_True;
+ }
+ }
+ }
+}
+
+//_________________________________________________________________________________________________________________
+// main
+//_________________________________________________________________________________________________________________
+
+void FrameWork::Main()
+{
+ //-------------------------------------------------------------------------------------------------------------
+ // a) Initialize ouer application
+
+ // Analyze command arguments.
+ impl_analyzeCommandArguments();
+
+ // Create new global servicemanager.
+ ServiceManager aManager;
+ Reference< XMultiServiceFactory > xGlobalServiceManager = aManager.getGlobalUNOServiceManager();
+
+ if ( xGlobalServiceManager.is() == sal_True )
+ {
+ // If it was successful - set in as static value in UNOTOOLS!
+ setProcessServiceFactory( xGlobalServiceManager );
+
+ //---------------------------------------------------------------------------------------------------------
+ // b) Create root of ouer frame tree
+
+ // Create top of frame hierarchy - the desktop.
+ Reference< XDesktop > xDesktop( xGlobalServiceManager->createInstance( SERVICENAME_DESKTOP ), UNO_QUERY );
+ // Safe impossible cases
+ // We need the desktop for working.
+ LOG_ASSERT( !(xDesktop.is()==sal_False), "FrameWork::Main()\nCan't instanciate desktop!Servicename unknown?\n" )
+
+ //---------------------------------------------------------------------------------------------------------
+ // c) Initialize connection to possible PlugIn dll.
+
+// OPipeConnection removed, connection to plugin now uses acceptor service
+#if 0
+ if ( m_bUsePlugIn == sal_True )
+ {
+ Reference< XConnection > xConnection = new OPipeConnection( xGlobalServiceManager );
+ Reference< XBridgeFactory > xBridgeFactory ( xGlobalServiceManager->createInstance( SERVICENAME_BRIDGEFACTORY ), UNO_QUERY );
+ if (
+ ( xConnection.is() == sal_True ) &&
+ ( xBridgeFactory.is() == sal_True )
+ )
+ {
+ Reference< XBridge > xBridge = xBridgeFactory->createBridge( NAME_PLUGINBRIDGE ,
+ PROTOCOL_PLUGINBRIDGE ,
+ xConnection ,
+ new OInstanceProvider( xGlobalServiceManager ) );
+ }
+ else
+ {
+ // Error handling ... !?
+ LOG_ASSERT( sal_False, "FrameWork::Main()\nNo connection to plugin. Initialization of bridge failed.\n" )
+ }
+ }
+#endif
+ //---------------------------------------------------------------------------------------------------------
+ // d) Initialize new task with a HTML-URL in it.
+
+ // Cast desktop to right interface to do this.
+ Reference< XDispatchProvider > xDispatchProvider( xDesktop, UNO_QUERY );
+ // Safe impossible cases.
+ // Desktop MUST support these interface!
+ LOG_ASSERT( !(xDispatchProvider.is()==sal_False), "FrameWork::Main()\nDesktop don't support XDispatchProvider interface.\n" )
+ if ( xDispatchProvider.is() == sal_True )
+ {
+ // Build URL ...
+ OUString sURL( RTL_CONSTASCII_USTRINGPARAM( "file://e|/dokumentation/Documentation/projekte/services/inimanager/inimanager/index.html" ));
+ URL aURL;
+ aURL.Complete = sURL;
+ // ... and dispatch it.
+ Reference< XDispatch > xDispatch = xDispatchProvider->queryDispatch( aURL, FRAMETYPE_BLANK, 0 );
+ xDispatch->dispatch( aURL, Sequence< PropertyValue >() );
+
+ // Use special feature of desktop service and log current tree state in file.
+// LOG_TREE( xDesktop )
+
+ // Build URL ...
+ sURL = OUString( RTL_CONSTASCII_USTRINGPARAM( "file://d|/menu.htm" ));
+ aURL.Complete = sURL;
+ // ... and dispatch it.
+ xDispatch = xDispatchProvider->queryDispatch( aURL, FRAMETYPE_BLANK, 0 );
+ xDispatch->dispatch( aURL, Sequence< PropertyValue >() );
+
+ // Use special feature of desktop service and log current tree state in file.
+// LOG_TREE( xDesktop )
+ }
+
+ // Set running-mode for application.
+ Execute();
+ }
+}