69 ,
mIncludeLower( limits ==
Qgis::RangeLimits::IncludeLowerExcludeUpper || limits ==
Qgis::RangeLimits::IncludeBoth )
70 ,
mIncludeUpper( limits ==
Qgis::RangeLimits::ExcludeLowerIncludeUpper || limits ==
Qgis::RangeLimits::IncludeBoth )
210 return ( !
operator==( other ) );
261 double upper = std::numeric_limits< double >::max(),
262 bool includeLower =
true,
bool includeUpper =
true )
263 :
QgsRange( lower, upper, includeLower, includeUpper )
273 bool includeLower =
true,
bool includeUpper =
true )
274 :
QgsRange( lower, upper, includeLower, includeUpper )
283 :
QgsRange( std::numeric_limits< double >::lowest(), std::numeric_limits< double >::max(), true, true )
293 return lower() == std::numeric_limits< double >::lowest() &&
upper() == std::numeric_limits< double >::max();
297 SIP_PYOBJECT __repr__();
299 QString str = QStringLiteral(
"<QgsDoubleRange: %1%2, %3%4>" ).arg( sipCpp->includeLower() ? QStringLiteral(
"[" ) : QStringLiteral(
"(" ) )
300 .arg( sipCpp->lower() )
301 .arg( sipCpp->upper() )
302 .arg( sipCpp->includeUpper() ? QStringLiteral(
"]" ) : QStringLiteral(
")" ) );
303 sipRes = PyUnicode_FromString( str.toUtf8().constData() );
317 return ( !
operator==( other ) );
357 int upper = std::numeric_limits< int >::max(),
358 bool includeLower =
true,
bool includeUpper =
true )
359 :
QgsRange( lower, upper, includeLower, includeUpper )
369 bool includeLower =
true,
bool includeUpper =
true )
370 :
QgsRange( lower, upper, includeLower, includeUpper )
379 :
QgsRange( std::numeric_limits< int >::lowest(), std::numeric_limits< int >::max(), true, true )
389 return lower() == std::numeric_limits< int >::lowest() && upper() == std::numeric_limits< int >::max();
393 SIP_PYOBJECT __repr__();
395 QString str = QStringLiteral(
"<QgsIntRange: %1%2, %3%4>" ).arg( sipCpp->includeLower() ? QStringLiteral(
"[" ) : QStringLiteral(
"(" ) )
396 .arg( sipCpp->lower() )
397 .arg( sipCpp->upper() )
398 .arg( sipCpp->includeUpper() ? QStringLiteral(
"]" ) : QStringLiteral(
")" ) );
399 sipRes = PyUnicode_FromString( str.toUtf8().constData() );
457 T
end()
const {
return mUpper; }
479 bool isInstant()
const {
return mLower.isValid() && mUpper.isValid() && mLower == mUpper && ( mIncludeLower || mIncludeUpper ); }
488 return !mLower.isValid() && !mUpper.isValid();
498 if ( !mLower.isValid() && !mUpper.isValid() )
501 if ( mLower.isValid() != mUpper.isValid() )
504 if ( mLower > mUpper )
507 if ( mLower == mUpper && !( mIncludeLower || mIncludeUpper ) )
518 if ( !other.mLower.isValid() && mLower.isValid() )
521 if ( mLower.isValid() )
523 const bool lowerOk = ( mIncludeLower && mLower <= other.mLower )
524 || ( !mIncludeLower && mLower < other.mLower )
525 || ( !mIncludeLower && !other.mIncludeLower && mLower <= other.mLower );
530 if ( !other.mUpper.isValid() && mUpper.isValid() )
533 if ( mUpper.isValid() )
535 const bool upperOk = ( mIncludeUpper && mUpper >= other.mUpper )
536 || ( !mIncludeUpper && mUpper > other.mUpper )
537 || ( !mIncludeUpper && !other.mIncludeUpper && mUpper >= other.mUpper );
550 if ( !element.isValid() )
553 if ( mLower.isValid() )
555 const bool lowerOk = ( mIncludeLower && mLower <= element )
556 || ( !mIncludeLower && mLower < element );
561 if ( mUpper.isValid() )
563 const bool upperOk = ( mIncludeUpper && mUpper >= element )
564 || ( !mIncludeUpper && mUpper > element );
577 if ( !mUpper.isValid() && ( ( mIncludeLower && mLower <= other.mUpper ) || ( !mIncludeLower && mLower < other.mUpper ) ) )
580 if ( ( ( mIncludeLower && mLower <= other.mLower ) || ( !mIncludeLower && mLower < other.mLower ) )
581 && ( ( mIncludeUpper && mUpper >= other.mUpper ) || ( !mIncludeUpper && mUpper > other.mUpper ) ) )
584 if ( ( ( mIncludeLower && mLower <= other.mLower ) || ( !mIncludeLower && mLower < other.mLower ) )
585 && ( ( mIncludeUpper && mUpper >= other.mLower ) || ( !mIncludeUpper && mUpper > other.mLower ) ) )
588 if ( ( ( mIncludeLower && mLower <= other.mUpper ) || ( !mIncludeLower && mLower < other.mUpper ) )
589 && ( ( mIncludeUpper && mUpper >= other.mUpper ) || ( !mIncludeUpper && mUpper > other.mUpper ) ) )
592 if ( ( ( mIncludeLower && mLower >= other.mLower ) || ( !mIncludeLower && mLower > other.mLower ) )
593 && ( ( mIncludeLower && mLower <= other.mUpper ) || ( !mIncludeLower && mLower < other.mUpper ) ) )
596 if ( mLower == other.mLower && mUpper == other.mUpper )
618 mLower = other.
begin();
619 mUpper = other.
end();
626 bool changed {
false };
629 if ( ! other.
begin().isValid()
630 || (
begin().isValid() && other.
begin() < mLower ) )
632 mLower = other.
begin();
638 mIncludeLower =
true;
643 if ( ! other.
end().isValid()
644 || (
end().isValid() && other.
end() > mUpper ) )
646 mUpper = other.
end();
650 else if ( other.
end() == mUpper && other.
includeEnd() && ! mIncludeUpper )
652 mIncludeUpper =
true;
675 if ( ranges.empty() )
678 QList< QgsTemporalRange<T > > sortedRanges = ranges;
681 QList< QgsTemporalRange<T>> res;
682 res.reserve( sortedRanges.size() );
685 auto it = sortedRanges.constBegin();
687 for ( ; it != sortedRanges.constEnd(); ++it )
706 return mLower == other.mLower &&
707 mUpper == other.mUpper &&
714 return ( !
operator==( other ) );
721 bool mIncludeLower =
true;
722 bool mIncludeUpper =
true;
The Qgis class provides global constants for use throughout the application.
RangeLimits
Describes how the limits of a range are handled.
@ ExcludeLowerIncludeUpper
Lower value is excluded from the range, upper value in inccluded.
@ IncludeBoth
Both lower and upper values are included in the range.
@ ExcludeBoth
Both lower and upper values are excluded from the range.
@ IncludeLowerExcludeUpper
Lower value is included in the range, upper value is excluded.
QgsRange which stores a range of double values.
QgsDoubleRange(double lower, double upper, Qgis::RangeLimits limits)
Constructor for QgsDoubleRange.
QgsDoubleRange(double lower=std::numeric_limits< double >::lowest(), double upper=std::numeric_limits< double >::max(), bool includeLower=true, bool includeUpper=true)
Constructor for QgsDoubleRange.
bool operator==(const QgsDoubleRange &other) const
bool isInfinite() const
Returns true if the range consists of all possible values.
bool operator!=(const QgsDoubleRange &other) const
QgsRange which stores a range of integer values.
bool isInfinite() const
Returns true if the range consists of all possible values.
QgsIntRange(int lower, int upper, Qgis::RangeLimits limits)
Constructor for QgsIntRange.
QgsIntRange(int lower=std::numeric_limits< int >::lowest(), int upper=std::numeric_limits< int >::max(), bool includeLower=true, bool includeUpper=true)
Constructor for QgsIntRange.
A template based class for storing ranges (lower to upper values).
QgsRange(T lower, T upper, Qgis::RangeLimits limits)
Constructor for QgsRange.
bool includeUpper() const
Returns true if the upper bound is inclusive, or false if the upper bound is exclusive.
bool overlaps(const QgsRange< T > &other) const
Returns true if this range overlaps another range.
Qgis::RangeLimits rangeLimits() const
Returns the limit handling of the range.
QgsRange(T lower, T upper, bool includeLower=true, bool includeUpper=true)
Constructor for QgsRange.
bool contains(const QgsRange< T > &other) const
Returns true if this range contains another range.
T lower() const
Returns the lower bound of the range.
bool includeLower() const
Returns true if the lower bound is inclusive, or false if the lower bound is exclusive.
T upper() const
Returns the upper bound of the range.
bool isSingleton() const
Returns true if the range consists only of a single value or instant.
bool operator!=(const QgsRange< T > &other) const
bool contains(T element) const
Returns true if this range contains a specified element.
bool operator==(const QgsRange< T > &other) const
bool isEmpty() const
Returns true if the range is empty, ie the lower bound equals (or exceeds) the upper bound and either...
A template based class for storing temporal ranges (beginning to end values).
bool contains(const T &element) const
Returns true if this range contains a specified element.
T begin() const
Returns the beginning of the range.
bool contains(const QgsTemporalRange< T > &other) const
Returns true if this range contains another range.
bool extend(const QgsTemporalRange< T > &other)
Extends the range in place by extending this range out to include an other range.
T end() const
Returns the upper bound of the range.
bool isInstant() const
Returns true if the range consists only of a single instant.
bool operator!=(const QgsTemporalRange< T > &other) const
QgsTemporalRange(const T &begin=T(), const T &end=T(), bool includeBeginning=true, bool includeEnd=true)
Constructor for QgsTemporalRange.
bool operator==(const QgsTemporalRange< T > &other) const
bool overlaps(const QgsTemporalRange< T > &other) const
Returns true if this range overlaps another range.
bool includeEnd() const
Returns true if the end is inclusive, or false if the end is exclusive.
bool includeBeginning() const
Returns true if the beginning is inclusive, or false if the beginning is exclusive.
bool isEmpty() const
Returns true if the range is empty, ie the beginning equals (or exceeds) the end and either of the bo...
static QList< QgsTemporalRange< T > > mergeRanges(const QList< QgsTemporalRange< T > > &ranges)
Merges a list of temporal ranges.
bool isInfinite() const
Returns true if the range consists of all possible values.
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference)
Q_DECLARE_METATYPE(QgsDatabaseQueryLogEntry)
QgsTemporalRange< QDate > QgsDateRange
QgsRange which stores a range of dates.
QgsRange< double > QgsRangedoubleBase
QgsRange< int > QgsRangeintBase