construct_ptr.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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_CONSTRUCT_PTR_H_
  32. #define _QX_CONSTRUCT_PTR_H_
  33. #ifdef _MSC_VER
  34. #pragma once
  35. #endif
  36. /*!
  37. * \file construct_ptr.h
  38. * \author Lionel Marty
  39. * \ingroup QxTraits
  40. * \brief qx::trait::construct_ptr<T>::get(T & t, bool bReset = false) : instantiate (or reset) a new pointer, support both nude-pointer and smart-pointer of boost, Qt and QxOrm libraries
  41. */
  42. #include <QtCore/qsharedpointer.h>
  43. #if (QT_VERSION >= 0x040600)
  44. #include <QtCore/qscopedpointer.h>
  45. #endif // (QT_VERSION >= 0x040600)
  46. #include <QxDao/QxDaoPointer.h>
  47. namespace qx {
  48. namespace trait {
  49. /*!
  50. * \ingroup QxTraits
  51. * \brief qx::trait::construct_ptr<T>::get(T & t, bool bReset = false) : instantiate (or reset) a new pointer, support both nude-pointer and smart-pointer of boost, Qt and QxOrm libraries
  52. */
  53. template <typename T>
  54. struct construct_ptr
  55. {
  56. private:
  57. typedef typename std::remove_pointer<T>::type type_ptr;
  58. public:
  59. static inline void get(T & t, bool bReset = false)
  60. { new_ptr<std::is_abstract<type_ptr>::value, 0>::get(t, bReset); }
  61. private:
  62. template <bool isAbstract /* = false */, int dummy>
  63. struct new_ptr
  64. { static inline void get(T & t, bool bReset) { if (bReset) { t = NULL; } else { t = new type_ptr(); } } };
  65. template <int dummy>
  66. struct new_ptr<true, dummy>
  67. { static inline void get(T & t, bool bReset) { Q_UNUSED(t); Q_UNUSED(bReset); qDebug("[QxOrm] qx::trait::construct_ptr<T> : %s", "cannot instantiate abstract class"); } };
  68. };
  69. #ifdef _QX_ENABLE_BOOST
  70. template <typename T>
  71. struct construct_ptr< boost::scoped_ptr<T> >
  72. { static inline void get(boost::scoped_ptr<T> & t, bool bReset = false) { if (bReset) { t.reset(); } else { t.reset(new T()); } } };
  73. template <typename T>
  74. struct construct_ptr< boost::shared_ptr<T> >
  75. { static inline void get(boost::shared_ptr<T> & t, bool bReset = false) { if (bReset) { t.reset(); } else { t.reset(new T()); } } };
  76. template <typename T>
  77. struct construct_ptr< boost::intrusive_ptr<T> >
  78. { static inline void get(boost::intrusive_ptr<T> & t, bool bReset = false) { if (bReset) { t.reset(); } else { t.reset(new T()); } } };
  79. #endif // _QX_ENABLE_BOOST
  80. template <typename T>
  81. struct construct_ptr< QSharedPointer<T> >
  82. { static inline void get(QSharedPointer<T> & t, bool bReset = false) { if (bReset) { t = QSharedPointer<T>(); } else { t = QSharedPointer<T>(new T()); } } };
  83. #if (QT_VERSION >= 0x040600)
  84. template <typename T>
  85. struct construct_ptr< QScopedPointer<T> >
  86. { static inline void get(QScopedPointer<T> & t, bool bReset = false) { if (bReset) { t = QScopedPointer<T>(); } else { t = QScopedPointer<T>(new T()); } } };
  87. #endif // (QT_VERSION >= 0x040600)
  88. template <typename T>
  89. struct construct_ptr< qx::dao::ptr<T> >
  90. { static inline void get(qx::dao::ptr<T> & t, bool bReset = false) { if (bReset) { t = qx::dao::ptr<T>(); } else { t = qx::dao::ptr<T>(new T()); } } };
  91. template <typename T>
  92. struct construct_ptr< std::unique_ptr<T> >
  93. { static inline void get(std::unique_ptr<T> & t, bool bReset = false) { if (bReset) { t.reset(); } else { t.reset(new T()); } } };
  94. template <typename T>
  95. struct construct_ptr< std::shared_ptr<T> >
  96. { static inline void get(std::shared_ptr<T> & t, bool bReset = false) { if (bReset) { t.reset(); } else { t = std::make_shared<T>(); } } };
  97. } // namespace trait
  98. } // namespace qx
  99. #endif // _QX_CONSTRUCT_PTR_H_