is_valid_primary_key.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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_IS_VALID_PRIMARY_KEY_H_
  32. #define _QX_IS_VALID_PRIMARY_KEY_H_
  33. #ifdef _MSC_VER
  34. #pragma once
  35. #endif
  36. /*!
  37. * \file is_valid_primary_key.h
  38. * \author Lionel Marty
  39. * \ingroup QxTraits
  40. * \brief qx::trait::is_valid_primary_key<T>(const T & t) : return true if t can be a valid primary key to be inserted into a database, otherwise return false
  41. */
  42. namespace qx {
  43. namespace trait {
  44. namespace detail {
  45. /*!
  46. * \ingroup QxTraits
  47. * \brief qx::trait::is_valid_primary_key<T>(const T & t) : return true if t can be a valid primary key to be inserted into a database, otherwise return false
  48. */
  49. template <typename T>
  50. struct is_valid_primary_key
  51. { static inline bool get(const T & t) { Q_UNUSED(t); qAssert(false); return false; } };
  52. template <>
  53. struct is_valid_primary_key<short>
  54. { static inline bool get(const short & t) { return (t != 0); } };
  55. template <>
  56. struct is_valid_primary_key<int>
  57. { static inline bool get(const int & t) { return (t != 0); } };
  58. template <>
  59. struct is_valid_primary_key<long>
  60. { static inline bool get(const long & t) { return (t != 0); } };
  61. template <>
  62. struct is_valid_primary_key<long long>
  63. { static inline bool get(const long long & t) { return (t != 0); } };
  64. template <>
  65. struct is_valid_primary_key<QString>
  66. { static inline bool get(const QString & t) { return (! t.isEmpty()); } };
  67. template <>
  68. struct is_valid_primary_key<QByteArray>
  69. { static inline bool get(const QByteArray & t) { return (! t.isEmpty()); } };
  70. template <>
  71. struct is_valid_primary_key<std::string>
  72. { static inline bool get(const std::string & t) { return (! t.empty()); } };
  73. template <>
  74. struct is_valid_primary_key<std::wstring>
  75. { static inline bool get(const std::wstring & t) { return (! t.empty()); } };
  76. template <>
  77. struct is_valid_primary_key<QVariant>
  78. {
  79. static inline bool get(const QVariant & t)
  80. {
  81. if (t.type() == QVariant::ByteArray) { return qx::trait::detail::is_valid_primary_key<QByteArray>::get(t.toByteArray()); }
  82. if (t.type() == QVariant::String) { return qx::trait::detail::is_valid_primary_key<QString>::get(t.toString()); }
  83. return (! t.isNull() && (t.toLongLong() != 0));
  84. }
  85. };
  86. } // namespace detail
  87. template <typename T>
  88. inline bool is_valid_primary_key(const T & t)
  89. { return qx::trait::detail::is_valid_primary_key<T>::get(t); }
  90. } // namespace trait
  91. } // namespace qx
  92. #endif // _QX_IS_VALID_PRIMARY_KEY_H_