1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: unoevent.hxx,v $
10 * $Revision: 1.5.136.1 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
30 #ifndef _SVTOOLS_UNOEVENT_HXX_
31 #define _SVTOOLS_UNOEVENT_HXX_
33 #include "svtools/svtdllapi.h"
34 #include <com/sun/star/container/XNameReplace.hpp>
35 #include <com/sun/star/lang/XServiceInfo.hpp>
36 #include <com/sun/star/uno/XInterface.hpp>
37 #include <cppuhelper/implbase2.hxx>
39 class SvxMacroTableDtor
;
43 /** SvEventDescription: Description of a single event.
44 mnEvent is the id used by SvxMacroItem
45 mpEventName is the api name for this event
47 the last event in an array is indicated by mnEvent && mpEventName == 0
49 struct SvEventDescription
52 const sal_Char
* mpEventName
;
56 * SvBaseEventDescriptor: Abstract class that implements the basics
57 * of an XNameReplace that is delivered by the
58 * XEventsSupplier::getEvents() method.
60 * The functionality this class provides is:
61 * 1) Which elements are in the XNameReplace?
62 * 2) Mapping from Api names to item IDs.
63 * 3) conversion from SvxMacroItem to Any and vice versa.
65 * All details of how to actually get and set SvxMacroItem(s) have to
66 * be supplied by the base class.
68 class SVT_DLLPUBLIC SvBaseEventDescriptor
: public cppu::WeakImplHelper2
70 ::com::sun::star::container::XNameReplace
,
71 ::com::sun::star::lang::XServiceInfo
74 const ::rtl::OUString sEventType
;
75 const ::rtl::OUString sMacroName
;
76 const ::rtl::OUString sLibrary
;
77 const ::rtl::OUString sStarBasic
;
78 const ::rtl::OUString sJavaScript
;
79 const ::rtl::OUString sScript
;
80 const ::rtl::OUString sNone
;
83 /// name of own service
84 const ::rtl::OUString sServiceName
;
87 const ::rtl::OUString sEmpty
;
89 /// last element is 0, 0
90 const SvEventDescription
* mpSupportedMacroItems
;
91 sal_Int16 mnMacroItems
;
95 SvBaseEventDescriptor(const SvEventDescription
* pSupportedMacroItems
);
97 virtual ~SvBaseEventDescriptor();
101 /// calls replaceByName(const sal_uInt16, const SvxMacro&)
102 virtual void SAL_CALL
replaceByName(
103 const ::rtl::OUString
& rName
, /// API name of event
104 const ::com::sun::star::uno::Any
& rElement
) /// event (PropertyValues)
106 ::com::sun::star::lang::IllegalArgumentException
,
107 ::com::sun::star::container::NoSuchElementException
,
108 ::com::sun::star::lang::WrappedTargetException
,
109 ::com::sun::star::uno::RuntimeException
);
111 // XNameAccess (via XNameReplace)
112 /// calls getByName(sal_uInt16)
113 virtual ::com::sun::star::uno::Any SAL_CALL
getByName(
114 const ::rtl::OUString
& rName
) /// API name of event
116 ::com::sun::star::container::NoSuchElementException
,
117 ::com::sun::star::lang::WrappedTargetException
,
118 ::com::sun::star::uno::RuntimeException
);
120 // XNameAxcess (via XNameReplace)
121 virtual ::com::sun::star::uno::Sequence
< ::rtl::OUString
> SAL_CALL
123 throw(::com::sun::star::uno::RuntimeException
);
125 // XNameAccess (via XNameReplace)
126 virtual sal_Bool SAL_CALL
hasByName(
127 const ::rtl::OUString
& rName
)
128 throw(::com::sun::star::uno::RuntimeException
);
130 // XElementAccess (via XNameReplace)
131 virtual ::com::sun::star::uno::Type SAL_CALL
getElementType()
132 throw(::com::sun::star::uno::RuntimeException
);
134 // XElementAccess (via XNameReplace)
135 virtual sal_Bool SAL_CALL
hasElements()
136 throw(::com::sun::star::uno::RuntimeException
);
139 /// must be implemented in subclass
140 virtual rtl::OUString SAL_CALL
getImplementationName(void)
141 throw( ::com::sun::star::uno::RuntimeException
) = 0;
144 virtual sal_Bool SAL_CALL
supportsService(const rtl::OUString
& ServiceName
)
145 throw( ::com::sun::star::uno::RuntimeException
);
148 virtual ::com::sun::star::uno::Sequence
< rtl::OUString
> SAL_CALL
149 getSupportedServiceNames(void)
150 throw( ::com::sun::star::uno::RuntimeException
);
154 /// Must be implemented in subclass.
155 virtual void replaceByName(
156 const sal_uInt16 nEvent
, /// item ID of event
157 const SvxMacro
& rMacro
) /// event (will be copied)
159 ::com::sun::star::lang::IllegalArgumentException
,
160 ::com::sun::star::container::NoSuchElementException
,
161 ::com::sun::star::lang::WrappedTargetException
,
162 ::com::sun::star::uno::RuntimeException
) = 0;
164 /// Must be implemented in subclass.
165 virtual void getByName(
167 const sal_uInt16 nEvent
)
169 ::com::sun::star::container::NoSuchElementException
,
170 ::com::sun::star::lang::WrappedTargetException
,
171 ::com::sun::star::uno::RuntimeException
) = 0;
173 /// convert an API event name to the event ID as used by SvxMacroItem
174 sal_uInt16
mapNameToEventID(const ::rtl::OUString
& rName
) const;
176 /// convert an event ID to an API event name
177 ::rtl::OUString
mapEventIDToName(sal_uInt16 nPoolID
) const;
179 /// get the event ID for the name; return 0 if not supported
180 sal_uInt16
getMacroID(const ::rtl::OUString
& rName
) const;
182 /// create PropertyValues and Any from macro
183 void getAnyFromMacro(
184 ::com::sun::star::uno::Any
& aAny
, // Any to be filled by Macro values
185 const SvxMacro
& rMacro
);
187 /// create macro from PropertyValues (in an Any)
188 void getMacroFromAny(
189 SvxMacro
& aMacro
, // reference to be filled by Any
190 const ::com::sun::star::uno::Any
& rAny
)
192 ::com::sun::star::lang::IllegalArgumentException
);
200 * SvEventDescriptor: Implement the XNameReplace that is delivered by
201 * the XEventsSupplier::getEvents() method. The SvEventDescriptor has
202 * to be subclassed to implement the events for a specific
203 * objects. The subclass has to
204 * 1) supply the super class constructor with a list of known events (item IDs)
205 * 2) supply the super class constructor with a reference of it's parent object
206 * (to prevent destruction)
207 * 3) implement getItem() and setItem(...) methods.
209 * If no object is available to which the SvEventDescriptor can attach itself,
210 * the class SvDetachedEventDescriptor should be used.
212 class SVT_DLLPUBLIC SvEventDescriptor
: public SvBaseEventDescriptor
214 /// keep reference to parent to prevent it from being destroyed
215 ::com::sun::star::uno::Reference
<
216 ::com::sun::star::uno::XInterface
> xParentRef
;
220 SvEventDescriptor(::com::sun::star::uno::XInterface
& rParent
,
221 const SvEventDescription
* pSupportedMacroItems
);
223 virtual ~SvEventDescriptor();
229 using SvBaseEventDescriptor::replaceByName
;
230 virtual void replaceByName(
231 const sal_uInt16 nEvent
, /// item ID of event
232 const SvxMacro
& rMacro
) /// event (will be copied)
234 ::com::sun::star::lang::IllegalArgumentException
,
235 ::com::sun::star::container::NoSuchElementException
,
236 ::com::sun::star::lang::WrappedTargetException
,
237 ::com::sun::star::uno::RuntimeException
);
239 using SvBaseEventDescriptor::getByName
;
240 virtual void getByName(
241 SvxMacro
& rMacros
, /// macro to be filled with values
242 const sal_uInt16 nEvent
) /// item ID of event
244 ::com::sun::star::container::NoSuchElementException
,
245 ::com::sun::star::lang::WrappedTargetException
,
246 ::com::sun::star::uno::RuntimeException
);
249 /// Get the SvxMacroItem from the parent.
250 /// must be implemented by subclass
251 virtual const SvxMacroItem
& getMacroItem() = 0;
253 /// Set the SvxMacroItem at the parent.
254 /// must be implemented by subclass
255 virtual void setMacroItem(const SvxMacroItem
& rItem
) = 0;
257 /// Get the SvxMacroItem Which Id needed for the current application
258 /// must be implemented by subclass
259 virtual sal_uInt16
getMacroItemWhich() const = 0;
264 * SvDetachedEventDescriptor:
266 class SVT_DLLPUBLIC SvDetachedEventDescriptor
: public SvBaseEventDescriptor
268 // the macros; aMacros[i] is the value for aSupportedMacroItemIDs[i]
271 const ::rtl::OUString sImplName
;
275 SvDetachedEventDescriptor(const SvEventDescription
* pSupportedMacroItems
);
277 virtual ~SvDetachedEventDescriptor();
280 virtual rtl::OUString SAL_CALL
getImplementationName(void)
281 throw( ::com::sun::star::uno::RuntimeException
);
285 sal_Int16
getIndex(const sal_uInt16 nID
) const;
287 using SvBaseEventDescriptor::replaceByName
;
288 virtual void replaceByName(
289 const sal_uInt16 nEvent
, /// item ID of event
290 const SvxMacro
& rMacro
) /// event (will be copied)
292 ::com::sun::star::lang::IllegalArgumentException
,
293 ::com::sun::star::container::NoSuchElementException
,
294 ::com::sun::star::lang::WrappedTargetException
,
295 ::com::sun::star::uno::RuntimeException
);
297 using SvBaseEventDescriptor::getByName
;
298 virtual void getByName(
299 SvxMacro
& rMacro
, /// macro to be filled
300 const sal_uInt16 nEvent
) /// item ID of event
302 ::com::sun::star::container::NoSuchElementException
,
303 ::com::sun::star::lang::WrappedTargetException
,
304 ::com::sun::star::uno::RuntimeException
);
306 /// do we have an event?
307 /// return sal_True: we have a macro for the event
308 /// return sal_False: no macro; getByName() will return an empty macro
309 /// IllegalArgumentException: the event is not supported
310 using SvBaseEventDescriptor::hasByName
;
311 virtual sal_Bool
hasByName(
312 const sal_uInt16 nEvent
) const /// item ID of event
314 ::com::sun::star::lang::IllegalArgumentException
);
318 class SVT_DLLPUBLIC SvMacroTableEventDescriptor
: public SvDetachedEventDescriptor
322 SvMacroTableEventDescriptor(const SvEventDescription
* pSupportedMacroItems
);
323 SvMacroTableEventDescriptor(const SvxMacroTableDtor
& aFmt
,
324 const SvEventDescription
* pSupportedMacroItems
);
326 virtual ~SvMacroTableEventDescriptor();
328 void copyMacrosFromTable(const SvxMacroTableDtor
& aFmt
);
329 void copyMacrosIntoTable(SvxMacroTableDtor
& aFmt
);