| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 | /*=============================================================================  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 CTKTRACKEDPLUGIN_P_H#define CTKTRACKEDPLUGIN_P_H#include <QSharedPointer>#include "ctkTrackedPluginListener_p.h"#include "ctkPluginAbstractTracked_p.h"#include "ctkPluginEvent.h"#include "ctkPlugin.h"/** * \ingroup PluginFramework */template<class T>class ctkTrackedPlugin : public ctkTrackedPluginListener,    public ctkPluginAbstractTracked<QSharedPointer<ctkPlugin>, T, ctkPluginEvent>{public:  ctkTrackedPlugin(ctkPluginTracker<T>* pluginTracker,                   ctkPluginTrackerCustomizer<T>* customizer);  /**   * Slot for the <code>ctkPluginTracker</code>   * class. This method must NOT be synchronized to avoid deadlock   * potential.   *   * @param event <code>ctkPluginEvent</code> object from the framework.   */  void pluginChanged(const ctkPluginEvent& event);private:  typedef ctkPluginAbstractTracked<QSharedPointer<ctkPlugin>, T, ctkPluginEvent> Superclass;  ctkPluginTracker<T>* pluginTracker;  ctkPluginTrackerCustomizer<T>* customizer;  /**   * Call the specific customizer adding method. This method must not be   * called while synchronized on this object.   *   * @param item Item to be tracked.   * @param related Action related object.   * @return Customized object for the tracked item or <code>null</code>   *         if the item is not to be tracked.   */  T customizerAdding(QSharedPointer<ctkPlugin> item,                     const ctkPluginEvent& related);  /**   * Call the specific customizer modified method. This method must not be   * called while synchronized on this object.   *   * @param item Tracked item.   * @param related Action related object.   * @param object Customized object for the tracked item.   */  void customizerModified(QSharedPointer<ctkPlugin> item,                          const ctkPluginEvent& related, T object);  /**   * Call the specific customizer removed method. This method must not be   * called while synchronized on this object.   *   * @param item Tracked item.   * @param related Action related object.   * @param object Customized object for the tracked item.   */  void customizerRemoved(QSharedPointer<ctkPlugin> item,                         const ctkPluginEvent& related, T object);};#include "ctkTrackedPlugin.tpp"#endif // CTKTRACKEDPLUGIN_P_H
 |