| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 | /*=============================================================================  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"/** * \ingroup EventAdmin * * Defines standard names for <code>ctkEventHandler</code> and Qt event slot properties. * * \see ctkEventHandler * \see ctkEventAdmin::subscribeSlot() */struct CTK_PLUGINFW_EXPORT ctkEventConstants {  /**   * Registration property (named <code>event.topics</code>)   * specifying the <code>ctkEvent</code> topics of interest to an Event Handler   * (a service object or a subscribed slot).   * <p>   * Event handlers 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. Event handlers 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"  /**   * Registration property (named <code>event.filter</code>)   * specifying a filter to further select <code>ctkEvent</code> s of interest to   * an Event Handler (a service object or a subscribed slot).   * <p>   * Event handlers 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   * event handler is notified for any event which belongs to the topics in   * which the handler has expressed an interest. If the event handler 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 event handler.   * <p>   * If the filter syntax is invalid, then the Event Handler 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
 |