QxFactoryX.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /****************************************************************************
  2. **
  3. ** https://www.qxorm.com/
  4. ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com)
  5. **
  6. ** This file is part of the QxOrm library
  7. **
  8. ** This software is provided 'as-is', without any express or implied
  9. ** warranty. In no event will the authors be held liable for any
  10. ** damages arising from the use of this software
  11. **
  12. ** Commercial Usage
  13. ** Licensees holding valid commercial QxOrm licenses may use this file in
  14. ** accordance with the commercial license agreement provided with the
  15. ** Software or, alternatively, in accordance with the terms contained in
  16. ** a written agreement between you and Lionel Marty
  17. **
  18. ** GNU General Public License Usage
  19. ** Alternatively, this file may be used under the terms of the GNU
  20. ** General Public License version 3.0 as published by the Free Software
  21. ** Foundation and appearing in the file 'license.gpl3.txt' included in the
  22. ** packaging of this file. Please review the following information to
  23. ** ensure the GNU General Public License version 3.0 requirements will be
  24. ** met : http://www.gnu.org/copyleft/gpl.html
  25. **
  26. ** If you are unsure which license is appropriate for your use, or
  27. ** if you have questions regarding the use of this file, please contact :
  28. ** contact@qxorm.com
  29. **
  30. ****************************************************************************/
  31. #ifndef _QX_FACTORY_X_H_
  32. #define _QX_FACTORY_X_H_
  33. #ifdef _MSC_VER
  34. #pragma once
  35. #endif
  36. /*!
  37. * \file QxFactoryX.h
  38. * \author Lionel Marty
  39. * \ingroup QxFactory
  40. * \brief List of all classes registered with QxOrm library factory pattern to create object instance dynamically using the class name
  41. */
  42. #include <QtCore/qhash.h>
  43. #include <QtCore/qmutex.h>
  44. #include <QxFactory/IxFactory.h>
  45. #include <QxSingleton/QxSingleton.h>
  46. namespace qx {
  47. inline qx::any create(const QString & sKey, bool bRawPointer = false);
  48. template <typename T> inline T * create_nude_ptr(const QString & sKey);
  49. inline void * create_void_ptr(const QString & sKey);
  50. class QxClassX;
  51. /*!
  52. * \ingroup QxFactory
  53. * \brief qx::QxFactoryX : list of all classes registered with QxOrm library factory pattern to create object instance dynamically using the class name
  54. */
  55. class QX_DLL_EXPORT QxFactoryX : public QxSingleton<QxFactoryX>
  56. {
  57. friend class QxClassX;
  58. friend class IxFactory;
  59. friend class QxSingleton<QxFactoryX>;
  60. friend inline qx::any create(const QString & sKey, bool bRawPointer);
  61. template <typename T> friend inline T * create_nude_ptr(const QString & sKey);
  62. friend inline void * create_void_ptr(const QString & sKey);
  63. protected:
  64. QHash<QString, IxFactory *> m_mapFactoryX; //!< Collection of all 'IxFactory' pointer
  65. QMutex m_oMutexFactoryX; //!< Mutex -> 'QxFactoryX' is thread-safe
  66. private:
  67. QxFactoryX() : QxSingleton<QxFactoryX>("qx::QxFactoryX") { ; }
  68. virtual ~QxFactoryX() { ; }
  69. QHash<QString, IxFactory *> * getAllFactory() { return (& m_mapFactoryX); }
  70. void registerFactory(const QString & sKey, IxFactory * pFactory);
  71. void unregisterFactory(const QString & sKey);
  72. qx::any createObject(const QString & sKey, bool bRawPointer = false) const;
  73. void * createObjectNudePtr(const QString & sKey) const;
  74. #ifndef _QX_NO_RTTI
  75. const std::type_info & typeInfo(const QString & sKey) const;
  76. #endif // _QX_NO_RTTI
  77. static inline qx::any createInstance(const QString & sKey, bool bRawPointer = false) { return QxFactoryX::getSingleton()->createObject(sKey, bRawPointer); }
  78. static inline void * createInstanceNudePtr(const QString & sKey) { return QxFactoryX::getSingleton()->createObjectNudePtr(sKey); }
  79. #ifndef _QX_NO_RTTI
  80. static inline const std::type_info & getTypeInfo(const QString & sKey) { return QxFactoryX::getSingleton()->typeInfo(sKey); }
  81. #endif // _QX_NO_RTTI
  82. };
  83. /*!
  84. * \ingroup QxFactory
  85. * \brief Return a smart-pointer new instance of object (std::shared_ptr<T>) associated by key sKey using qx::any type (for example : qx::create("drug") return a new instance of smart-pointer drug class into qx::any type)
  86. */
  87. inline qx::any create(const QString & sKey, bool bRawPointer /* = false */)
  88. { return qx::QxFactoryX::createInstance(sKey, bRawPointer); }
  89. /*!
  90. * \ingroup QxFactory
  91. * \brief Return a nude pointer (be careful with memory leak) of type T associated by key sKey, or return NULL if sKey is not registered into factory engine
  92. */
  93. template <typename T>
  94. inline T * create_nude_ptr(const QString & sKey)
  95. #ifdef _QX_NO_RTTI
  96. { return static_cast<T *>(qx::QxFactoryX::createInstanceNudePtr(sKey)); }
  97. #else // _QX_NO_RTTI
  98. { return dynamic_cast<T *>(static_cast<T *>(qx::QxFactoryX::createInstanceNudePtr(sKey))); }
  99. #endif // _QX_NO_RTTI
  100. /*!
  101. * \ingroup QxFactory
  102. * \brief Return a void * pointer (be careful with memory leak) associated by key sKey, or return NULL if sKey is not registered into factory engine
  103. */
  104. inline void * create_void_ptr(const QString & sKey)
  105. { return qx::QxFactoryX::createInstanceNudePtr(sKey); }
  106. } // namespace qx
  107. QX_DLL_EXPORT_QX_SINGLETON_HPP(qx::QxFactoryX)
  108. #endif // _QX_FACTORY_X_H_