| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 | 
							- /*=============================================================================
 
-   Library: CTK
 
-   Copyright (c) German Cancer Research Center,
 
-     Division of Medical and Biological Informatics
 
-   Licensed 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
 
-   Unless required by applicable law or agreed to in writing, software
 
-   distributed under the License is distributed on an "AS IS" BASIS,
 
-   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
-   See the License for the specific language governing permissions and
 
-   limitations under the License.
 
- =============================================================================*/
 
- #ifndef CTKEVENTCONSTANTS_H
 
- #define CTKEVENTCONSTANTS_H
 
- #include <QString>
 
- #include "ctkPluginFrameworkExport.h"
 
- /**
 
-  * Defines standard names for <code>ctkEventHandler</code> and Qt event slot properties.
 
-  *
 
-  * \see ctkEventHandler
 
-  * \see ctkEventAdmin::subscribeSlot()
 
-  */
 
- struct CTK_PLUGINFW_EXPORT ctkEventConstants {
 
-   /**
 
-    * Qt slot property (named <code>event.topics</code>)
 
-    * specifying the <code>ctkEvent</code> topics of interest to a
 
-    * subscribed slot.
 
-    * <p>
 
-    * Subscribed slots SHOULD be registered with this property. The value of the
 
-    * property is a QString or a QStringList that describes the topics in
 
-    * which the handler is interested. An asterisk ('*') may be used as a
 
-    * trailing wildcard. Subscribed slots which do not have a value for this
 
-    * property must not receive events. More precisely, the value of each
 
-    * string must conform to the following grammar:
 
-    *
 
-    * <pre>
 
-    *  topic-description := '*' | topic ( '/*' )?
 
-    *  topic := token ( '/' token )*
 
-    * </pre>
 
-    *
 
-    * @see ctkEvent
 
-    */
 
-   static const QString EVENT_TOPIC; // = "event.topics"
 
-   /**
 
-    * Qt slot property (named <code>event.filter</code>)
 
-    * specifying a filter to further select <code>ctkEvent</code> s of interest to
 
-    * a subscribed slot.
 
-    * <p>
 
-    * Subscribed slots MAY be registered with this property. The value of this
 
-    * property is a QString containing an LDAP-style filter specification. Any
 
-    * of the event's properties may be used in the filter expression. Each
 
-    * subscribed slot is notified for any event which belongs to the topics in
 
-    * which the slot has expressed an interest. If the slot is also
 
-    * registered with this property, then the properties of the event
 
-    * must also match the filter for the event to be delivered to the slot.
 
-    * <p>
 
-    * If the filter syntax is invalid, then the slot must be ignored
 
-    * and a warning should be logged.
 
-    *
 
-    * @see ctkEvent
 
-    * @see ctkLDAPSearchFilter
 
-    */
 
-   static const QString EVENT_FILTER; // = "event.filter"
 
-   /**
 
-    * Service Registration property specifying the delivery qualities requested
 
-    * by an Event Handler service.
 
-    * <p>
 
-    * Event handlers MAY be registered with this property. Each value of this
 
-    * property is a string specifying a delivery quality for the Event handler.
 
-    *
 
-    * <p>
 
-    * The value of this property must be of type <code>QString</code> or
 
-    * <code>QStringList</code>.
 
-    *
 
-    * @see #DELIVERY_ASYNC_ORDERED
 
-    * @see #DELIVERY_ASYNC_UNORDERED
 
-    */
 
-   static const QString EVENT_DELIVERY; // = "event.delivery"
 
-   /**
 
-    * Event Handler delivery quality value specifying the Event Handler
 
-    * requires asynchronously delivered events be delivered in order. Ordered
 
-    * delivery is the default for asynchronously delivered events.
 
-    *
 
-    * <p>
 
-    * This delivery quality value is mutually exclusive with
 
-    * {@link #DELIVERY_ASYNC_UNORDERED}. However, if both this value and
 
-    * {@link #DELIVERY_ASYNC_UNORDERED} are specified for an event handler,
 
-    * this value takes precedence.
 
-    *
 
-    * @see #EVENT_DELIVERY
 
-    */
 
-   static const QString DELIVERY_ASYNC_ORDERED; // = "async.ordered"
 
-   /**
 
-    * Event Handler delivery quality value specifying the Event Handler does
 
-    * not require asynchronously delivered events be delivered in order. This
 
-    * may allow an Event Admin implementation to optimize asynchronous event
 
-    * delivery by relaxing ordering requirements.
 
-    *
 
-    * <p>
 
-    * This delivery quality value is mutually exclusive with
 
-    * {@link #DELIVERY_ASYNC_ORDERED}. However, if both this value and
 
-    * {@link #DELIVERY_ASYNC_ORDERED} are specified for an event handler,
 
-    * {@link #DELIVERY_ASYNC_ORDERED} takes precedence.
 
-    *
 
-    * @see #EVENT_DELIVERY
 
-    */
 
-   static const QString DELIVERY_ASYNC_UNORDERED; // = "async.unordered"
 
-   /**
 
-    * The Plugin Symbolic Name of the plugin relevant to the event. The type of
 
-    * the value for this event property is <code>QString</code>.
 
-    */
 
-   static const QString PLUGIN_SYMBOLICNAME; // = "plugin.symbolicName"
 
-   /**
 
-    * The Plugin id of the plugin relevant to the event. The type of the value
 
-    * for this event property is <code>long</code>.
 
-    */
 
-   static const QString PLUGIN_ID; // = "plugin.id"
 
-   /**
 
-    * The ctkPlugin object of the plugin relevant to the event. The type of the
 
-    * value for this event property is <code>QSharedPointer<ctkPlugin></code>.
 
-    */
 
-   static const QString PLUGIN; // = "plugin"
 
-   /**
 
-    * The version of the plugin relevant to the event. The type of the value
 
-    * for this event property is {@link ctkVersion}.
 
-    */
 
-   static const QString PLUGIN_VERSION; // = "plugin.version"
 
-   /**
 
-    * The forwarded event object. Used when rebroadcasting an event that was
 
-    * sent via some other event mechanism. The type of the value for this event
 
-    * property depends on the event topic (for org/commontk/PluginEvent/&0x42; the
 
-    * the type will be ctkPluginEvent).
 
-    */
 
-   static const QString EVENT; // = "event"
 
-   /**
 
-    * An exception or error. The type of the value for this event property is
 
-    * <code>ctkRuntimeException</code>.
 
-    */
 
-   static const QString EXCEPTION; // = "exception"
 
-   /**
 
-    * The name of the exception type. Must be equal to the name of the class of
 
-    * the exception in the event property {@link #EXCEPTION}. The type of the
 
-    * value for this event property is <code>QString</code>.
 
-    */
 
-   static const QString EXCEPTION_CLASS; // = "exception.class"
 
-   /**
 
-    * The exception message. Must be equal to the result of calling
 
-    * <code>what()</code> on the exception in the event property
 
-    * {@link #EXCEPTION}. The type of the value for this event property is
 
-    * <code>QString</code>.
 
-    */
 
-   static const QString EXCEPTION_MESSAGE; // = "exception.message"
 
-   /**
 
-    * A human-readable message that is usually not localized. The type of the
 
-    * value for this event property is <code>QString</code>.
 
-    */
 
-   static const QString MESSAGE; // = "message"
 
-   /**
 
-    * A service reference. The type of the value for this event property is
 
-    * {@link ctkServiceReference}.
 
-    */
 
-   static const QString SERVICE; // = "service"
 
-   /**
 
-    * A service's id. The type of the value for this event property is
 
-    * <code>long</code>.
 
-    */
 
-   static const QString SERVICE_ID; // = ctkPluginConstants::SERVICE_ID
 
-   /**
 
-    * A service's objectClass. The type of the value for this event property is
 
-    * <code>QStringList</code>.
 
-    */
 
-   static const QString SERVICE_OBJECTCLASS; // = "service.objectClass"
 
-   /**
 
-    * A service's persistent identity. The type of the value for this event
 
-    * property is <code>QString</code>.
 
-    */
 
-   static const QString SERVICE_PID; // = ctkPluginConstants::SERVICE_PID
 
-   /**
 
-    * The time when the event occurred, as reported by
 
-    * <code>QDateTime::currentDateTime()</code>. The type of the value for this
 
-    * event property is <code>QDateTime</code>.
 
-    */
 
-   static const QString TIMESTAMP; // = "timestamp"
 
- };
 
- #endif // CTKEVENTCONSTANTS_H
 
 
  |