QxOrm  1.5.0
C++ Object Relational Mapping library
is_valid_primary_key.h
Go to the documentation of this file.
00001 /****************************************************************************
00002 **
00003 ** https://www.qxorm.com/
00004 ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com)
00005 **
00006 ** This file is part of the QxOrm library
00007 **
00008 ** This software is provided 'as-is', without any express or implied
00009 ** warranty. In no event will the authors be held liable for any
00010 ** damages arising from the use of this software
00011 **
00012 ** Commercial Usage
00013 ** Licensees holding valid commercial QxOrm licenses may use this file in
00014 ** accordance with the commercial license agreement provided with the
00015 ** Software or, alternatively, in accordance with the terms contained in
00016 ** a written agreement between you and Lionel Marty
00017 **
00018 ** GNU General Public License Usage
00019 ** Alternatively, this file may be used under the terms of the GNU
00020 ** General Public License version 3.0 as published by the Free Software
00021 ** Foundation and appearing in the file 'license.gpl3.txt' included in the
00022 ** packaging of this file. Please review the following information to
00023 ** ensure the GNU General Public License version 3.0 requirements will be
00024 ** met : http://www.gnu.org/copyleft/gpl.html
00025 **
00026 ** If you are unsure which license is appropriate for your use, or
00027 ** if you have questions regarding the use of this file, please contact :
00028 ** contact@qxorm.com
00029 **
00030 ****************************************************************************/
00031 
00032 #ifndef _QX_IS_VALID_PRIMARY_KEY_H_
00033 #define _QX_IS_VALID_PRIMARY_KEY_H_
00034 
00035 #ifdef _MSC_VER
00036 #pragma once
00037 #endif
00038 
00046 namespace qx {
00047 namespace trait {
00048 namespace detail {
00049 
00054 template <typename T>
00055 struct is_valid_primary_key
00056 { static inline bool get(const T & t) { Q_UNUSED(t); qAssert(false); return false; } };
00057 
00058 template <>
00059 struct is_valid_primary_key<short>
00060 { static inline bool get(const short & t) { return (t != 0); } };
00061 
00062 template <>
00063 struct is_valid_primary_key<int>
00064 { static inline bool get(const int & t) { return (t != 0); } };
00065 
00066 template <>
00067 struct is_valid_primary_key<long>
00068 { static inline bool get(const long & t) { return (t != 0); } };
00069 
00070 template <>
00071 struct is_valid_primary_key<long long>
00072 { static inline bool get(const long long & t) { return (t != 0); } };
00073 
00074 template <>
00075 struct is_valid_primary_key<QString>
00076 { static inline bool get(const QString & t) { return (! t.isEmpty()); } };
00077 
00078 template <>
00079 struct is_valid_primary_key<QByteArray>
00080 { static inline bool get(const QByteArray & t) { return (! t.isEmpty()); } };
00081 
00082 template <>
00083 struct is_valid_primary_key<std::string>
00084 { static inline bool get(const std::string & t) { return (! t.empty()); } };
00085 
00086 template <>
00087 struct is_valid_primary_key<std::wstring>
00088 { static inline bool get(const std::wstring & t) { return (! t.empty()); } };
00089 
00090 template <>
00091 struct is_valid_primary_key<QVariant>
00092 {
00093    static inline bool get(const QVariant & t)
00094    {
00095       if (t.type() == QVariant::ByteArray) { return qx::trait::detail::is_valid_primary_key<QByteArray>::get(t.toByteArray()); }
00096       if (t.type() == QVariant::String) { return qx::trait::detail::is_valid_primary_key<QString>::get(t.toString()); }
00097       return (! t.isNull() && (t.toLongLong() != 0));
00098    }
00099 };
00100 
00101 } // namespace detail
00102 
00103 template <typename T>
00104 inline bool is_valid_primary_key(const T & t)
00105 { return qx::trait::detail::is_valid_primary_key<T>::get(t); }
00106 
00107 } // namespace trait
00108 } // namespace qx
00109 
00110 #endif // _QX_IS_VALID_PRIMARY_KEY_H_