This commit is contained in:
blackdal 2017-07-26 20:31:35 +04:30
parent eae5d8c185
commit 7860f7a0d5
2 changed files with 237 additions and 134 deletions

View File

@ -200,4 +200,34 @@ WherePhrase WherePhrase::operator&(const WherePhrase &other)
return WherePhrase(this, PhraseData::Append, (WherePhrase *)&other); return WherePhrase(this, PhraseData::Append, (WherePhrase *)&other);
} }
WherePhrase WherePhrase::operator==(const QVariant &other)
{
return WherePhrase(this, PhraseData::Equal, other);
}
WherePhrase WherePhrase::operator!=(const QVariant &other)
{
return WherePhrase(this, PhraseData::NotEqual, other);
}
WherePhrase WherePhrase::operator<(const QVariant &other)
{
return WherePhrase(this, PhraseData::Less, other);
}
WherePhrase WherePhrase::operator>(const QVariant &other)
{
return WherePhrase(this, PhraseData::Greater, other);
}
WherePhrase WherePhrase::operator<=(const QVariant &other)
{
return WherePhrase(this, PhraseData::LessEqual, other);
}
WherePhrase WherePhrase::operator>=(const QVariant &other)
{
return WherePhrase(this, PhraseData::GreaterEqual, other);
}
NUT_END_NAMESPACE NUT_END_NAMESPACE

View File

@ -32,13 +32,15 @@
#include "defines.h" #include "defines.h"
#include "dbgeography.h" #include "dbgeography.h"
#include <initializer_list>
NUT_BEGIN_NAMESPACE NUT_BEGIN_NAMESPACE
class SqlGeneratorBase; class SqlGeneratorBase;
class PhraseData{ class PhraseData
public:
enum Condition
{ {
public:
enum Condition {
NotAssign = 0, NotAssign = 0,
Equal, Equal,
Less, Less,
@ -58,7 +60,6 @@ public:
And = 20, And = 20,
Or, Or,
Append, Append,
Set, Set,
@ -71,12 +72,7 @@ public:
Distance Distance
}; };
enum Type{ enum Type { Field, WithVariant, WithOther, WithoutOperand };
Field,
WithVariant,
WithOther,
WithoutOperand
};
Type type; Type type;
Condition operatorCond; Condition operatorCond;
@ -94,7 +90,8 @@ public:
~PhraseData(); ~PhraseData();
}; };
class WherePhrase{ class WherePhrase
{
protected: protected:
PhraseData *_data; PhraseData *_data;
QSharedPointer<PhraseData> _dataPointer; QSharedPointer<PhraseData> _dataPointer;
@ -117,6 +114,13 @@ public:
WherePhrase operator<=(const WherePhrase &other); WherePhrase operator<=(const WherePhrase &other);
WherePhrase operator>=(const WherePhrase &other); WherePhrase operator>=(const WherePhrase &other);
WherePhrase operator==(const QVariant &other);
WherePhrase operator!=(const QVariant &other);
WherePhrase operator<(const QVariant &other);
WherePhrase operator>(const QVariant &other);
WherePhrase operator<=(const QVariant &other);
WherePhrase operator>=(const QVariant &other);
WherePhrase operator!(); WherePhrase operator!();
WherePhrase operator=(const WherePhrase &other); WherePhrase operator=(const WherePhrase &other);
@ -134,7 +138,8 @@ public:
}; };
template <typename T> template <typename T>
class FieldPhrase: public WherePhrase{ class FieldPhrase : public WherePhrase
{
public: public:
FieldPhrase(const char *className, const char *s); FieldPhrase(const char *className, const char *s);
@ -156,27 +161,32 @@ public:
WherePhrase like(QString pattern); WherePhrase like(QString pattern);
}; };
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE FieldPhrase<T>::FieldPhrase(const char *className, const char *s) : WherePhrase(className, s) Q_OUTOFLINE_TEMPLATE FieldPhrase<T>::FieldPhrase(const char *className,
const char *s)
: WherePhrase(className, s)
{ {
// qDebug() << "(" << this << ")" << "FieldPhrase ctor" << className << s; // qDebug() << "(" << this << ")" << "FieldPhrase ctor" << className <<
// s;
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator =(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator=(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::Set, other); return WherePhrase(this, PhraseData::Set, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator =(const WherePhrase &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator=(const WherePhrase &other)
{ {
return WherePhrase(this, PhraseData::Set, &other); return WherePhrase(this, PhraseData::Set, &other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator+(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator+(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::Add, other); return WherePhrase(this, PhraseData::Add, other);
} }
@ -185,7 +195,8 @@ template<typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator!() Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator!()
{ {
if (_data->operatorCond < 20) if (_data->operatorCond < 20)
_data->operatorCond = (PhraseData::Condition)((_data->operatorCond + 10) % 20); _data->operatorCond
= (PhraseData::Condition)((_data->operatorCond + 10) % 20);
else else
qFatal("Operator ! can not aplied to non condition statements"); qFatal("Operator ! can not aplied to non condition statements");
@ -193,43 +204,50 @@ Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator !()
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator==(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator==(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::Equal, other); return WherePhrase(this, PhraseData::Equal, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator!=(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator!=(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::NotEqual, other); return WherePhrase(this, PhraseData::NotEqual, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator<(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator<(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::Less, other); return WherePhrase(this, PhraseData::Less, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator>(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator>(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::Greater, other); return WherePhrase(this, PhraseData::Greater, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator<=(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator<=(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::LessEqual, other); return WherePhrase(this, PhraseData::LessEqual, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::operator>=(const QVariant &other) Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::
operator>=(const QVariant &other)
{ {
return WherePhrase(this, PhraseData::GreaterEqual, other); return WherePhrase(this, PhraseData::GreaterEqual, other);
} }
template <typename T> template <typename T>
Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::isNull(){ Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::isNull()
{
return WherePhrase(this, PhraseData::Null); return WherePhrase(this, PhraseData::Null);
} }
@ -255,57 +273,70 @@ Q_OUTOFLINE_TEMPLATE WherePhrase FieldPhrase<T>::like(QString pattern)
return WherePhrase(this, PhraseData::Like, pattern); return WherePhrase(this, PhraseData::Like, pattern);
} }
// Custom types // Custom types
template <> template <>
class FieldPhrase<DbGeography>: public WherePhrase { class FieldPhrase<DbGeography> : public WherePhrase
{
public: public:
FieldPhrase(const char *className, const char* s) : WherePhrase(className, s){ FieldPhrase(const char *className, const char *s)
: WherePhrase(className, s)
{
} }
WherePhrase distance(const DbGeography &geo) { WherePhrase distance(const DbGeography &geo)
return WherePhrase(this, PhraseData::Distance, QVariant::fromValue(geo)); {
return WherePhrase(this, PhraseData::Distance,
QVariant::fromValue(geo));
} }
}; };
// Custom types // Custom types
template <> template <>
class FieldPhrase<QPoint>: public WherePhrase { class FieldPhrase<QPoint> : public WherePhrase
{
public: public:
FieldPhrase(const char *className, const char* s) : WherePhrase(className, s){ FieldPhrase(const char *className, const char *s)
: WherePhrase(className, s)
{
} }
WherePhrase distance(const QPoint &geo) { WherePhrase distance(const QPoint &geo)
return WherePhrase(this, PhraseData::Distance, QVariant::fromValue(geo)); {
return WherePhrase(this, PhraseData::Distance,
QVariant::fromValue(geo));
} }
WherePhrase operator =(const QPoint &other) { WherePhrase operator=(const QPoint &other)
{
return WherePhrase(this, PhraseData::Set, other); return WherePhrase(this, PhraseData::Set, other);
} }
}; };
// Custom types // Custom types
template <> template <>
class FieldPhrase<QPointF>: public WherePhrase { class FieldPhrase<QPointF> : public WherePhrase
{
public: public:
FieldPhrase(const char *className, const char* s) : WherePhrase(className, s){ FieldPhrase(const char *className, const char *s)
: WherePhrase(className, s)
{
} }
WherePhrase distance(const QPointF &geo) { WherePhrase distance(const QPointF &geo)
return WherePhrase(this, PhraseData::Distance, QVariant::fromValue(geo)); {
return WherePhrase(this, PhraseData::Distance,
QVariant::fromValue(geo));
} }
WherePhrase operator =(const QPointF &other) { WherePhrase operator=(const QPointF &other)
{
return WherePhrase(this, PhraseData::Set, other); return WherePhrase(this, PhraseData::Set, other);
} }
}; };
// template<> // template<>
// class FieldPhrase<QString>: public WherePhrase { // class FieldPhrase<QString>: public WherePhrase {
// public: // public:
// FieldPhrase(const char *className, const char* s) : WherePhrase(className, s){ // FieldPhrase(const char *className, const char* s) : WherePhrase(className,
// s){
// } // }
@ -315,30 +346,38 @@ public:
// } // }
//}; //};
template <> template <>
class FieldPhrase<bool>: public WherePhrase{ class FieldPhrase<bool> : public WherePhrase
{
public: public:
FieldPhrase(const char *className, const char* s) : WherePhrase(className, s){ FieldPhrase(const char *className, const char *s)
: WherePhrase(className, s)
{
} }
WherePhrase operator ==(const bool &other) { WherePhrase operator==(const bool &other)
{
return WherePhrase(this, PhraseData::Equal, other ? 1 : 0); return WherePhrase(this, PhraseData::Equal, other ? 1 : 0);
} }
WherePhrase operator =(const bool &other) { WherePhrase operator=(const bool &other)
{
return WherePhrase(this, PhraseData::Set, other ? 1 : 0); return WherePhrase(this, PhraseData::Set, other ? 1 : 0);
} }
WherePhrase operator !() { WherePhrase operator!()
{
return WherePhrase(this, PhraseData::Equal, 0); return WherePhrase(this, PhraseData::Equal, 0);
} }
}; };
class NumericFieldPhrase: public WherePhrase{ class NumericFieldPhrase : public WherePhrase
{
public: public:
NumericFieldPhrase(const char *className, const char* s) : WherePhrase(className, s) { } NumericFieldPhrase(const char *className, const char *s)
: WherePhrase(className, s)
{
}
WherePhrase operator=(const QVariant &other) WherePhrase operator=(const QVariant &other)
{ {
@ -355,6 +394,15 @@ public:
return WherePhrase(this, PhraseData::Minus, other); return WherePhrase(this, PhraseData::Minus, other);
} }
WherePhrase operator++()
{
return WherePhrase(this, PhraseData::Add, 1);
}
WherePhrase operator--()
{
return WherePhrase(this, PhraseData::Minus, 1);
}
WherePhrase operator==(const QVariant &other) WherePhrase operator==(const QVariant &other)
{ {
@ -390,25 +438,51 @@ public:
{ {
return WherePhrase(this, PhraseData::Null); return WherePhrase(this, PhraseData::Null);
} }
template<typename T>
WherePhrase in(QList<T> list)
{
QVariantList vlist;
foreach (T t, list)
vlist.append(QVariant::fromValue(t));
return WherePhrase(this, PhraseData::In, vlist);
}
template<typename T>
WherePhrase in(std::initializer_list<T> list)
{
return in(QList<T>(list));
}
WherePhrase in(int count, ...)
{
QVariantList vlist;
va_list ap;
va_start(ap, count);
for (int i = 0; i < count; ++i)
vlist.append(QVariant::fromValue(va_arg(ap, int)));
va_end(ap);
return WherePhrase(this, PhraseData::In, vlist);
}
}; };
#define SPECIALIZATION_NUMERIC(type) \ #define SPECIALIZATION_NUMERIC(type) \
template <> \ template <> \
class FieldPhrase<type>: public NumericFieldPhrase{ \ class FieldPhrase<type> : public NumericFieldPhrase \
{ \
public: \ public: \
FieldPhrase(const char *className, const char *s) \ FieldPhrase(const char *className, const char *s) \
: NumericFieldPhrase(className, s) { } \ : NumericFieldPhrase(className, s) \
{ \
} \
WherePhrase operator=(const WherePhrase &other) \ WherePhrase operator=(const WherePhrase &other) \
{ \ { \
return WherePhrase(this, PhraseData::Set, (WherePhrase *)&other); \ return WherePhrase(this, PhraseData::Set, (WherePhrase *)&other); \
} \ } \
WherePhrase in(QList<type> list) \
{ \
QVariantList vlist; \
foreach (type t, list) \
vlist.append(QVariant::fromValue(t)); \
return WherePhrase(this, PhraseData::In, vlist); \
} \
}; };
SPECIALIZATION_NUMERIC(qint8) SPECIALIZATION_NUMERIC(qint8)
@ -423,7 +497,6 @@ SPECIALIZATION_NUMERIC(quint64)
SPECIALIZATION_NUMERIC(qreal) SPECIALIZATION_NUMERIC(qreal)
NUT_END_NAMESPACE NUT_END_NAMESPACE
#endif // PHRASE_H #endif // PHRASE_H