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 INCLUDED_SVTOOLS_ACCELERATOREXECUTE_HXX 25 #define INCLUDED_SVTOOLS_ACCELERATOREXECUTE_HXX 26 27 //=============================================== 28 // includes 29 30 #include "svtools/svtdllapi.h" 31 32 #ifndef INCLUDED_VECTOR 33 #include <vector> 34 #define INCLUDED_VECTOR 35 #endif 36 37 #ifndef __COM_SUN_STAR_LANG_XMULTISERVICEFACTORY_HPP_ 38 #include <com/sun/star/lang/XMultiServiceFactory.hpp> 39 #endif 40 41 #ifndef __COM_SUN_STAR_FRAME_XFRAME_HPP_ 42 #include <com/sun/star/frame/XFrame.hpp> 43 #endif 44 45 #ifndef __COM_SUN_STAR_FRAME_XDISPATCHPROVIDER_HPP_ 46 #include <com/sun/star/frame/XDispatchProvider.hpp> 47 #endif 48 49 #ifndef __com_SUN_STAR_UI_XACCELERATORCONFIGURATION_HPP_ 50 #include <com/sun/star/ui/XAcceleratorConfiguration.hpp> 51 #endif 52 53 #ifndef __COM_SUN_STAR_UTIL_XURLTRANSFORMER_HPP_ 54 #include <com/sun/star/util/XURLTransformer.hpp> 55 #endif 56 #include <com/sun/star/util/URL.hpp> 57 58 #ifndef __COM_SUN_STAR_AWT_KEYEVENT_HPP_ 59 #include <com/sun/star/awt/KeyEvent.hpp> 60 #endif 61 #include <vcl/keycod.hxx> 62 #include <vcl/evntpost.hxx> 63 #include <osl/mutex.h> 64 65 //=============================================== 66 // namespace 67 68 #ifdef css 69 #error "Conflict on using css as namespace alias!" 70 #else 71 #define css ::com::sun::star 72 #endif 73 74 namespace svt 75 { 76 77 //=============================================== 78 // definitions 79 80 struct TMutexInit 81 { 82 ::osl::Mutex m_aLock; 83 }; 84 85 //=============================================== 86 /** 87 @descr implements a helper, which can be used to 88 convert vcl key codes into awt key codes ... 89 and reverse. 90 91 Further such key code can be triggered. 92 Doing so different accelerator 93 configurations are merged together; a suitable 94 command registered for the given key code is searched 95 and will be dispatched. 96 97 @attention 98 99 Because exceution of an accelerator command can be dangerous 100 (in case it force an office shutdown for key "ALT+F4"!) 101 all internal dispatches are done asynchronous. 102 Menas that the trigger call doesnt wait till the dispatch 103 is finished. You can call very often. All requests will be 104 queued internal and dispatched ASAP. 105 106 Of course this queue will be stopped if the environment 107 will be destructed ... 108 */ 109 class SVT_DLLPUBLIC AcceleratorExecute : private TMutexInit 110 { 111 //------------------------------------------- 112 // const, types 113 private: 114 115 /** @deprecated 116 replaced by internal class AsyncAccelExec ... 117 remove this resource here if we go forwards to next major */ 118 typedef ::std::vector< ::std::pair< css::util::URL, css::uno::Reference< css::frame::XDispatch > > > TCommandQueue; 119 120 //------------------------------------------- 121 // member 122 private: 123 124 /** TODO document me */ 125 css::uno::Reference< css::lang::XMultiServiceFactory > m_xSMGR; 126 127 /** TODO document me */ 128 css::uno::Reference< css::util::XURLTransformer > m_xURLParser; 129 130 /** TODO document me */ 131 css::uno::Reference< css::frame::XDispatchProvider > m_xDispatcher; 132 133 /** TODO document me */ 134 css::uno::Reference< css::ui::XAcceleratorConfiguration > m_xGlobalCfg; 135 css::uno::Reference< css::ui::XAcceleratorConfiguration > m_xModuleCfg; 136 css::uno::Reference< css::ui::XAcceleratorConfiguration > m_xDocCfg; 137 138 /** @deprecated 139 replaced by internal class AsyncAccelExec ... 140 remove this resource here if we go forwards to next major */ 141 TCommandQueue m_lCommandQueue; 142 143 /** @deprecated 144 replaced by internal class AsyncAccelExec ... 145 remove this resource here if we go forwards to next major */ 146 ::vcl::EventPoster m_aAsyncCallback; 147 148 //------------------------------------------- 149 // interface 150 public: 151 152 //--------------------------------------- 153 /** @short factory method to create new accelerator 154 helper instance. 155 156 @descr Such helper instance must be initialized at first. 157 So it can know its environment (global/module or 158 document specific). 159 160 Afterwards it can be used to execute incoming 161 accelerator requests. 162 163 The "end of life" of such helper can be reached as follow: 164 165 - delete the object 166 => If it stands currently in its execute method, they will 167 be finished. All further queued requests will be removed 168 and further not executed! 169 170 - "let it stay alone" 171 => All currently queued events will be finished. The 172 helper kills itself afterwards. A shutdown of the 173 environment will be recognized ... The helper stop its 174 work immediatly then! 175 */ 176 static AcceleratorExecute* createAcceleratorHelper(); 177 178 //--------------------------------------- 179 /** @short fight against inlining ... */ 180 virtual ~AcceleratorExecute(); 181 182 //--------------------------------------- 183 /** @short init this instance. 184 185 @descr It must be called as first method after creation. 186 And further it can be called more then once ... 187 but at least its should be used one times only. 188 Otherwhise nobody can say, which asynchronous 189 executions will be used inside the old and which one 190 will be used inside the new environment. 191 192 @param xSMGR 193 reference to an uno service manager. 194 195 @param xEnv 196 if it points to a valid frame it will be used 197 to execute the dispatch there. Further the frame 198 is used to locate the right module configuration 199 and use it merged together with the document and 200 the global configuration. 201 202 If this parameter is set to NULL, the global configuration 203 is used only. Further the global Desktop instance is 204 used for dispatch. 205 */ 206 virtual void init(const css::uno::Reference< css::lang::XMultiServiceFactory >& xSMGR, 207 const css::uno::Reference< css::frame::XFrame >& xEnv ); 208 209 //--------------------------------------- 210 /** @short trigger this accelerator. 211 212 @descr The internal configuartions are used to find 213 as suitable command for this key code. 214 This command will be queued and executed later 215 asynchronous. 216 217 @param aKey 218 specify the accelerator for execute. 219 220 @return [sal_Bool] 221 sal_True if this key is configured and match to a command. 222 Attention: This state does not mean the success state 223 of the corresponding execute. Because its done asynchronous! 224 */ 225 virtual sal_Bool execute(const KeyCode& aKey); 226 virtual sal_Bool execute(const css::awt::KeyEvent& aKey); 227 228 /** search the command for the given key event. 229 * 230 * @param aKey The key event 231 * @return The command or an empty string if the key event could not be found. 232 */ 233 ::rtl::OUString findCommand(const ::com::sun::star::awt::KeyEvent& aKey); 234 //--------------------------------------- 235 /** TODO document me */ 236 static css::awt::KeyEvent st_VCLKey2AWTKey(const KeyCode& aKey); 237 static KeyCode st_AWTKey2VCLKey(const css::awt::KeyEvent& aKey); 238 239 //--------------------------------------- 240 /** TODO document me */ 241 static css::uno::Reference< css::ui::XAcceleratorConfiguration > st_openGlobalConfig(const css::uno::Reference< css::lang::XMultiServiceFactory >& xSMGR); 242 243 //--------------------------------------- 244 /** TODO document me */ 245 static css::uno::Reference< css::ui::XAcceleratorConfiguration > st_openModuleConfig(const css::uno::Reference< css::lang::XMultiServiceFactory >& xSMGR , 246 const css::uno::Reference< css::frame::XFrame >& xFrame); 247 248 //--------------------------------------- 249 /** TODO document me */ 250 static css::uno::Reference< css::ui::XAcceleratorConfiguration > st_openDocConfig(const css::uno::Reference< css::frame::XModel >& xModel); 251 252 //------------------------------------------- 253 // internal 254 private: 255 256 //--------------------------------------- 257 /** @short allow creation of instances of this class 258 by using our factory only! 259 */ 260 SVT_DLLPRIVATE AcceleratorExecute(); 261 262 AcceleratorExecute(const AcceleratorExecute& rCopy); 263 void operator=(const AcceleratorExecute&) {}; 264 //--------------------------------------- 265 /** TODO document me */ 266 SVT_DLLPRIVATE ::rtl::OUString impl_ts_findCommand(const css::awt::KeyEvent& aKey); 267 268 //--------------------------------------- 269 /** TODO document me */ 270 SVT_DLLPRIVATE css::uno::Reference< css::util::XURLTransformer > impl_ts_getURLParser(); 271 272 //--------------------------------------- 273 /** @deprecated 274 replaced by internal class AsyncAccelExec ... 275 remove this resource here if we go forwards to next major */ 276 DECL_DLLPRIVATE_LINK(impl_ts_asyncCallback, void*); 277 }; 278 279 } // namespace svt 280 281 #undef css 282 283 #endif // INCLUDED_SVTOOLS_ACCELERATOREXECUTE_HXX 284