| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 | 
							- /*=============================================================================
 
-   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 CTKDEFAULTAPPLICATIONLAUNCHER_H
 
- #define CTKDEFAULTAPPLICATIONLAUNCHER_H
 
- #include <service/application/ctkApplicationLauncher.h>
 
- #include <QSemaphore>
 
- #include <QVariant>
 
- class ctkPluginContext;
 
- /**
 
-  * A ctkApplicationLauncher is used to launch ctkApplicationRunnable objects using
 
-  * the main thread.
 
-  * <p>
 
-  * This class is for use by platform-related plug-ins which implement application containers.
 
-  * Clients outside of the base platform should not reference or subclass this class.
 
-  * </p>
 
-  */
 
- class ctkDefaultApplicationLauncher : public QObject, public ctkApplicationLauncher
 
- {
 
-   Q_OBJECT
 
-   Q_INTERFACES(ctkApplicationLauncher)
 
- private:
 
-   ctkApplicationRunnable* runnable;
 
-   QVariant appContext;
 
-   QSemaphore runningLock;
 
-   QSemaphore waitForAppLock;
 
-   ctkPluginContext* context;
 
-   bool relaunch;
 
-   bool failOnNoDefault;
 
-   // FrameworkLog log;
 
- public:
 
-   ctkDefaultApplicationLauncher(ctkPluginContext* context, bool relaunch, bool failOnNoDefault);
 
-   /**
 
-    * Starts this application launcher on the current thread.  This method
 
-    * should be called by the main thread to ensure that applications are
 
-    * launched in the main thread.
 
-    */
 
-   QVariant start(const QVariant& defaultContext);
 
-   /**
 
-      * Launches the specified runnable using the main thread.
 
-      * @param runnable a ParameterizedRunnalbe to run on the main thread.
 
-      * @param context the context to launch the runnable with
 
-      */
 
-   void launch(ctkApplicationRunnable* app, const QVariant& applicationContext);
 
-   /**
 
-    * Forces the current runnable which is running to be stopped.
 
-    * This method will return after the currently running ctkApplicationRunnable
 
-    * has completely stopped.
 
-    * <p>
 
-    * After this method returns this ctkApplicationLauncher will no longer allow
 
-    * applications to be launched.
 
-    */
 
-   void shutdown();
 
-   /**
 
-    * Similar to the start method this method will restart the default method on the current thread.
 
-    * This method assumes that the default application was launched at least once and that a ctkApplicationDescriptor
 
-    * exists that can be used to relaunch the default application.
 
-    * @param argument the new context to re-start the default application with
 
-    */
 
-   QVariant reStart(const QVariant& argument);
 
- private:
 
-   /*
 
-    * Waits for an application to be launched and the runs the application on the
 
-    * current thread (main).
 
-    */
 
-   QVariant runApplication(const QVariant& defaultContext);
 
-   friend struct FreeResources;
 
- };
 
- #endif // CTKDEFAULTAPPLICATIONLAUNCHER_H
 
 
  |