ctkCmdLineModuleFrontendFactory.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*=============================================================================
  2. Library: CTK
  3. Copyright (c) German Cancer Research Center,
  4. Division of Medical and Biological Informatics
  5. Licensed under the Apache License, Version 2.0 (the "License");
  6. you may not use this file except in compliance with the License.
  7. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. =============================================================================*/
  15. #ifndef CTKCMDLINEMODULEFRONTENDFACTORY_H
  16. #define CTKCMDLINEMODULEFRONTENDFACTORY_H
  17. #include "ctkCommandLineModulesCoreExport.h"
  18. class ctkCmdLineModuleFrontend;
  19. class ctkCmdLineModuleReference;
  20. /**
  21. * \class ctkCmdLineModuleFrontendFactory
  22. * \brief Factory class to create new front-ends.
  23. * \ingroup CommandLineModulesCore_API
  24. *
  25. * Front-end implementors are advised to create and export a sub-class of
  26. * this class to unify the creation process of front-ends.
  27. *
  28. * \see ctkCmdLineModuleFrontend
  29. */
  30. struct CTK_CMDLINEMODULECORE_EXPORT ctkCmdLineModuleFrontendFactory
  31. {
  32. virtual ~ctkCmdLineModuleFrontendFactory();
  33. /**
  34. * @brief Get the name of this factory.
  35. * @return The factory name.
  36. */
  37. virtual QString name() const = 0;
  38. /**
  39. * @brief Get the description for this factory.
  40. * @return A factory description.
  41. */
  42. virtual QString description() const = 0;
  43. /**
  44. * @brief Creates front-end instances.
  45. * @param moduleRef The module reference for which to create a front-end.
  46. * @return The created front-end or NULL if creation failed.
  47. */
  48. virtual ctkCmdLineModuleFrontend* create(const ctkCmdLineModuleReference& moduleRef) = 0;
  49. };
  50. #endif // CTKCMDLINEMODULEFRONTENDFACTORY_H