1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 #ifndef __FRAMEWORK_DISPATCH_DISPATCHPROVIDER_HXX_ 25 #define __FRAMEWORK_DISPATCH_DISPATCHPROVIDER_HXX_ 26 27 //_________________________________________________________________________________________________________________ 28 // my own includes 29 //_________________________________________________________________________________________________________________ 30 31 #include <services/frame.hxx> 32 33 #include <classes/protocolhandlercache.hxx> 34 #include <threadhelp/threadhelpbase.hxx> 35 36 #ifndef __FRAMEWORK_THREADHELP_TRANSACTIONBASE_HXX_ 37 #include <threadhelp/transactionbase.hxx> 38 #endif 39 #include <macros/xinterface.hxx> 40 #include <macros/xtypeprovider.hxx> 41 #include <macros/debug.hxx> 42 #include <macros/generic.hxx> 43 #include <stdtypes.h> 44 45 //_________________________________________________________________________________________________________________ 46 // interface includes 47 //_________________________________________________________________________________________________________________ 48 #include <com/sun/star/lang/XTypeProvider.hpp> 49 #include <com/sun/star/frame/XDispatchProvider.hpp> 50 #include <com/sun/star/util/URL.hpp> 51 #include <com/sun/star/frame/DispatchDescriptor.hpp> 52 #include <com/sun/star/beans/PropertyValue.hpp> 53 54 //_________________________________________________________________________________________________________________ 55 // other includes 56 //_________________________________________________________________________________________________________________ 57 #include <cppuhelper/weak.hxx> 58 #include <cppuhelper/weakref.hxx> 59 60 //_________________________________________________________________________________________________________________ 61 // namespace 62 //_________________________________________________________________________________________________________________ 63 64 namespace framework{ 65 66 //_________________________________________________________________________________________________________________ 67 68 /** 69 @descr We know some special dispatch objects with different functionality. 70 They can be created internally by the following DispatchProvider. 71 Here we define some identifier to force creation of the right one. 72 */ 73 enum EDispatchHelper 74 { 75 E_DEFAULTDISPATCHER , 76 E_MENUDISPATCHER , 77 E_HELPAGENTDISPATCHER , 78 E_CREATEDISPATCHER , 79 E_BLANKDISPATCHER , 80 E_SELFDISPATCHER , 81 E_CLOSEDISPATCHER , 82 E_STARTMODULEDISPATCHER 83 }; 84 85 //_________________________________________________________________________________________________________________ 86 87 /** 88 @short implement a helper for XDispatchProvider interface 89 @descr The result of a queryDispatch() call depends from the owner, which use an instance of this class. 90 (frame, desktop) All of them must provides different functionality. 91 E.g: - task can be created by the desktop only 92 - a task can have a beamer as direct child 93 - a normal frame never can create a new one by himself 94 95 @attention Use this class as member only! Never use it as baseclass. 96 XInterface will be ambiguous and we hold a weakreference to our OWNER - not to our SUPERCLASS! 97 98 @base ThreadHelpBase 99 supports threadsafe mechanism 100 @base OWeakObject 101 provides ref count and weak mechanism 102 103 @devstatus ready to use 104 @threadsafe yes 105 @modified 17.05.2002 07:56, as96863 106 */ 107 class DispatchProvider : // interfaces 108 public css::lang::XTypeProvider , 109 public css::frame::XDispatchProvider , 110 // baseclasses 111 // Order is necessary for right initialization! 112 private ThreadHelpBase , 113 private TransactionBase , 114 public ::cppu::OWeakObject 115 { 116 /* member */ 117 private: 118 /// reference to global service manager to create new services 119 css::uno::Reference< css::lang::XMultiServiceFactory > m_xFactory; 120 /// weakreference to owner frame (Don't use a hard reference. Owner can't delete us then!) 121 css::uno::WeakReference< css::frame::XFrame > m_xFrame; 122 /// different dispatcher to handle special dispatch calls, protocols or URLs (they will be created on demand.) 123 css::uno::Reference< css::frame::XDispatch > m_xMenuDispatcher ; 124 css::uno::Reference< css::frame::XDispatch > m_xHelpAgentDispatcher; 125 /* css::uno::Reference< css::frame::XDispatch > m_xBlankDispatcher ; 126 css::uno::Reference< css::frame::XDispatch > m_xSelfDispatcher ; 127 css::uno::Reference< css::frame::XDispatch > m_xDefaultDispatcher ;*/ 128 /// cache of some other dispatch provider which are registered inside configuration to handle special URL protocols 129 HandlerCache m_aProtocolHandlerCache; 130 131 /* interface */ 132 public: 133 FWK_DECLARE_XINTERFACE 134 FWK_DECLARE_XTYPEPROVIDER 135 136 DispatchProvider( const css::uno::Reference< css::lang::XMultiServiceFactory >& xFactory , 137 const css::uno::Reference< css::frame::XFrame >& xFrame ); 138 139 virtual css::uno::Reference< css::frame::XDispatch > SAL_CALL queryDispatch ( const css::util::URL& aURL , 140 const ::rtl::OUString& sTargetFrameName , 141 sal_Int32 nSearchFlags ) throw( css::uno::RuntimeException ); 142 virtual css::uno::Sequence< css::uno::Reference< css::frame::XDispatch > > SAL_CALL queryDispatches( const css::uno::Sequence< css::frame::DispatchDescriptor >& lDescriptions ) throw( css::uno::RuntimeException ); 143 144 /* helper */ 145 protected: 146 // Let him protected! So nobody can use us as base ... 147 virtual ~DispatchProvider(); 148 149 private: 150 css::uno::Reference< css::frame::XDispatch > implts_getOrCreateDispatchHelper ( EDispatchHelper eHelper , 151 const css::uno::Reference< css::frame::XFrame >& xOwner , 152 const ::rtl::OUString& sTarget = ::rtl::OUString() , 153 sal_Int32 nSearchFlags = 0 ); 154 sal_Bool implts_isLoadableContent ( const css::util::URL& aURL ); 155 css::uno::Reference< css::frame::XDispatch > implts_queryDesktopDispatch ( const css::uno::Reference< css::frame::XFrame > xDesktop , 156 const css::util::URL& aURL , 157 const ::rtl::OUString& sTargetFrameName , 158 sal_Int32 nSearchFlags ); 159 css::uno::Reference< css::frame::XDispatch > implts_queryFrameDispatch ( const css::uno::Reference< css::frame::XFrame > xFrame , 160 const css::util::URL& aURL , 161 const ::rtl::OUString& sTargetFrameName , 162 sal_Int32 nSearchFlags ); 163 css::uno::Reference< css::frame::XDispatch > implts_searchProtocolHandler ( const css::util::URL& aURL ); 164 165 }; // class DispatchProvider 166 167 } // namespace framework 168 169 #endif // #ifndef __FRAMEWORK_DISPATCH_DISPATCHPROVIDER_HXX_ 170