| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 | /*=============================================================================  Library: CTK  Copyright (c) 2010 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 CTKSERVICEREGISTRATION_H#define CTKSERVICEREGISTRATION_H#include "ctkPluginContext.h"#include "ctkServiceReference.h"#include "CTKPluginFrameworkExport.h"  class ctkServiceRegistrationPrivate;  /**   * A registered service.   *   * <p>   * The Framework returns a <code>ctkServiceRegistration</code> object when a   * <code>ctkPluginContext#registerService()</code> method invocation is successful.   * The <code>ctkServiceRegistration</code> object is for the private use of the   * registering plugin and should not be shared with other plugins.   * <p>   * The <code>ctkServiceRegistration</code> object may be used to update the   * properties of the service or to unregister the service.   *   * @see ctkPluginContext#registerService()   * @threadsafe   */  class CTK_PLUGINFW_EXPORT ctkServiceRegistration {    Q_DECLARE_PRIVATE(ctkServiceRegistration)  public:    /**     * Returns a <code>ctkServiceReference</code> object for a service being     * registered.     * <p>     * The <code>ctkServiceReference</code> object may be shared with other     * plugins.     *     * @throws std::logic_error If this     *         <code>ctkServiceRegistration</code> object has already been     *         unregistered.     * @return <code>ctkServiceReference</code> object.     */    ctkServiceReference* getReference();    /**     * Updates the properties associated with a service.     *     * <p>     * The {@link PluginConstants#OBJECTCLASS} and {@link PluginConstants#SERVICE_ID} keys     * cannot be modified by this method. These values are set by the Framework     * when the service is registered in the environment.     *     * <p>     * The following steps are required to modify service properties:     * <ol>     * <li>The service's properties are replaced with the provided properties.     * <li>A service event of type {@link ServiceEvent#MODIFIED} is fired.     * </ol>     *     * @param properties The properties for this service. See {@link PluginConstants}     *        for a list of standard service property keys. Changes should not     *        be made to this object after calling this method. To update the     *        service's properties this method should be called again.     *     * @throws std::logic_error If this <code>ctkServiceRegistration</code>     *         object has already been unregistered.     * @throws std::invalid_argument If <code>properties</code> contains     *         case variants of the same key name.     */    void setProperties(const ServiceProperties& properties);    /**     * Unregisters a service. Remove a <code>ctkServiceRegistration</code> object     * from the Framework service registry. All <code>ctkServiceReference</code>     * objects associated with this <code>ctkServiceRegistration</code> object     * can no longer be used to interact with the service once unregistration is     * complete.     *     * <p>     * The following steps are required to unregister a service:     * <ol>     * <li>The service is removed from the Framework service registry so that     * it can no longer be obtained.     * <li>A service event of type {@link ServiceEvent#UNREGISTERING} is fired     * so that plugins using this service can release their use of the service.     * Once delivery of the service event is complete, the     * <code>ctkServiceReference</code> objects for the service may no longer be     * used to get a service object for the service.     * <li>For each plugin whose use count for this service is greater than     * zero: <br>     * The plugin's use count for this service is set to zero. <br>     * If the service was registered with a {@link ctkServiceFactory} object, the     * <code>ctkServiceFactory#ungetService</code> method is called to release     * the service object for the plugin.     * </ol>     *     * @throws std::logic_error If this     *         <code>ctkServiceRegistration</code> object has already been     *         unregistered.     * @see BundleContext#ungetService     * @see ctkServiceFactory#ungetService     */    virtual void unregister();    bool operator<(const ctkServiceRegistration& o) const;  protected:    friend class ctkServices;    ctkServiceRegistration(ctkPluginPrivate* plugin, QObject* service,                        const ServiceProperties& props);    ctkServiceRegistration(ctkServiceRegistrationPrivate& dd);    ctkServiceRegistrationPrivate * const d_ptr;  };#endif // CTKSERVICEREGISTRATION_H
 |