6#include "validatormin_p.h"
14 const QString &defValKey)
15 :
ValidatorRule(*new ValidatorMinPrivate(field, type, min, messages, defValKey))
25 const QString v =
value(params);
35 case QMetaType::Short:
38 case QMetaType::LongLong:
40 const qlonglong val = c->
locale().toLongLong(v, &ok);
41 if (Q_UNLIKELY(!ok)) {
43 qCWarning(C_VALIDATOR).noquote().nospace()
44 <<
debugString(c) <<
" Failed to parse \"" << v <<
"\" into an integer number";
46 const qlonglong min = d->extractLongLong(c, params, d->min, &ok);
47 if (Q_UNLIKELY(!ok)) {
49 c,
static_cast<int>(ValidatorRulePrivate::ErrorType::InvalidMin));
50 qCWarning(C_VALIDATOR).noquote()
51 <<
debugString(c) <<
"Invalid minimum comparison value";
55 qCDebug(C_VALIDATOR).noquote()
56 <<
debugString(c) << val <<
"is not greater than" << min;
63 case QMetaType::UChar:
64 case QMetaType::UShort:
66 case QMetaType::ULong:
67 case QMetaType::ULongLong:
69 const qulonglong val = v.toULongLong(&ok);
70 if (Q_UNLIKELY(!ok)) {
72 qCWarning(C_VALIDATOR).noquote().nospace()
74 <<
"\" into an unsigned integer number";
76 const qulonglong min = d->extractULongLong(c, params, d->min, &ok);
77 if (Q_UNLIKELY(!ok)) {
79 c,
static_cast<int>(ValidatorRulePrivate::ErrorType::InvalidMin));
80 qCWarning(C_VALIDATOR).noquote()
81 <<
debugString(c) <<
"Invalid minimum comparison value";
85 qCDebug(C_VALIDATOR).noquote()
86 <<
debugString(c) << val <<
"is not greater than" << min;
93 case QMetaType::Float:
94 case QMetaType::Double:
96 const double val = v.toDouble(&ok);
97 if (Q_UNLIKELY(!ok)) {
99 qCWarning(C_VALIDATOR).noquote().nospace()
101 <<
"\" into a floating point number";
103 const double min = d->extractDouble(c, params, d->min, &ok);
104 if (Q_UNLIKELY(!ok)) {
106 c,
static_cast<int>(ValidatorRulePrivate::ErrorType::InvalidMin));
107 qCWarning(C_VALIDATOR).noquote()
108 <<
debugString(c) <<
"Invalid minimum comparison value";
112 qCDebug(C_VALIDATOR).noquote()
113 <<
debugString(c) << val <<
"is not greater than" << min;
120 case QMetaType::QString:
122 const auto val =
static_cast<qlonglong
>(v.length());
123 const qlonglong min = d->extractLongLong(c, params, d->min, &ok);
124 if (Q_UNLIKELY(!ok)) {
126 c,
static_cast<int>(ValidatorRulePrivate::ErrorType::InvalidMin));
127 qCWarning(C_VALIDATOR).noquote()
128 <<
debugString(c) <<
"Invalid minimum comparison value";
132 qCDebug(C_VALIDATOR).noquote()
133 <<
debugString(c) <<
"String length" << val <<
"is not longer than" << min;
140 qCWarning(C_VALIDATOR).noquote()
141 <<
debugString(c) <<
"The comparison type" << d->type <<
"is not supported";
143 c,
static_cast<int>(ValidatorRulePrivate::ErrorType::InvalidType));
148 if (d->type != QMetaType::QString) {
149 const QVariant _v = d->valueToNumber(c, v, d->type);
156 result.
value.setValue(v);
172 case QMetaType::Char:
173 case QMetaType::Short:
175 case QMetaType::Long:
176 case QMetaType::LongLong:
177 case QMetaType::QString:
178 min = c->
locale().toString(errorData.toLongLong());
180 case QMetaType::UChar:
181 case QMetaType::UShort:
182 case QMetaType::UInt:
183 case QMetaType::ULong:
184 case QMetaType::ULongLong:
185 min = c->
locale().toString(errorData.toULongLong());
187 case QMetaType::Float:
188 case QMetaType::Double:
189 min = c->
locale().toString(errorData.toDouble());
193 static_cast<int>(ValidatorRulePrivate::ErrorType::InvalidType));
196 const QString _label =
label(c);
198 if (_label.isEmpty()) {
199 if (d->type == QMetaType::QString) {
201 return c->
qtTrId(
"cutelyst-valmin-genvalerr-str").arg(min);
204 return c->
qtTrId(
"cutelyst-valmin-genvalerr-num").arg(min);
207 if (d->type == QMetaType::QString) {
209 return c->
qtTrId(
"cutelyst-valmin-genvalerr-str-label").arg(_label, min);
212 return c->
qtTrId(
"cutelyst-valmin-genvalerr-num-label").arg(_label, min);
219 const QString _label =
label(c);
220 const auto errorType =
static_cast<ValidatorRulePrivate::ErrorType
>(errorData.toInt());
224 if (_label.isEmpty()) {
226 case ValidatorRulePrivate::ErrorType::InvalidType:
229 const QMetaType _type(d->type);
230 return c->
qtTrId(
"cutelyst-validator-genvaldataerr-type")
231 .arg(QString::fromLatin1(_type.name()));
233 case ValidatorRulePrivate::ErrorType::InvalidMin:
234 return c->
qtTrId(
"cutelyst-validator-genvaldataerr-min");
235 case ValidatorRulePrivate::ErrorType::InvalidMax:
242 case ValidatorRulePrivate::ErrorType::InvalidType:
245 const QMetaType _type(d->type);
246 return c->
qtTrId(
"cutelyst-validator-genvaldataerr-type-label")
247 .arg(QString::fromLatin1(_type.name()), _label);
249 case ValidatorRulePrivate::ErrorType::InvalidMin:
250 return c->
qtTrId(
"cutelyst-validator-genvaldataerr-min-label").arg(_label);
251 case ValidatorRulePrivate::ErrorType::InvalidMax:
258#if QT_VERSION >= QT_VERSION_CHECK(6, 5, 0)
260 Q_UNREACHABLE_RETURN({});
273 const QString _label =
label(c);
274 if ((d->type == QMetaType::Float) || (d->type == QMetaType::Double)) {
275 if (_label.isEmpty()) {
276 return c->
qtTrId(
"cutelyst-validator-genparseerr-float");
278 return c->
qtTrId(
"cutelyst-validator-genparseerr-float-label").arg(_label);
281 if (_label.isEmpty()) {
282 return c->
qtTrId(
"cutelyst-validator-genparseerr-int");
284 return c->
qtTrId(
"cutelyst-validator-genparseerr-int-label").arg(_label);
QLocale locale() const noexcept
QString qtTrId(const char *id, int n=-1) const
Checks if a value is not smaller or shorter than a maximum value.
QString genericValidationDataError(Context *c, const QVariant &errorData) const override
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const override
QString genericParsingError(Context *c, const QVariant &errorData) const override
ValidatorMin(const QString &field, QMetaType::Type type, const QVariant &min, const ValidatorMessages &messages=ValidatorMessages(), const QString &defValKey=QString())
Base class for all validator rules.
QString validationError(Context *c, const QVariant &errorData={}) const
QString label(Context *c) const
QString validationDataError(Context *c, const QVariant &errorData={}) const
void defaultValue(Context *c, ValidatorReturnType *result) const
QString value(const ParamsMultiMap ¶ms) const
QString parsingError(Context *c, const QVariant &errorData={}) const
QString debugString(Context *c) const
QMultiMap< QString, QString > ParamsMultiMap
The Cutelyst namespace holds all public Cutelyst API.
Stores custom error messages and the input field label.
Contains the result of a single input parameter validation.