QDateTime: replace a bool parameter with an enum
Change-Id: Ie72b1d482c67c83cb0e2e0bfd1e00f1be2fa4899 Reviewed-by: Thiago Macieira <thiago.macieira@intel.com> Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
This commit is contained in:
parent
b490bd0265
commit
b9786f21b8
@ -831,7 +831,9 @@ static QTimeZone asTimeZone(Qt::TimeSpec spec, int offset, const char *warner)
|
|||||||
}
|
}
|
||||||
#endif // Helper for 6.9 deprecation
|
#endif // Helper for 6.9 deprecation
|
||||||
|
|
||||||
static bool inDateTimeRange(qint64 jd, bool start)
|
enum class DaySide { Start, End };
|
||||||
|
|
||||||
|
static bool inDateTimeRange(qint64 jd, DaySide side)
|
||||||
{
|
{
|
||||||
using Bounds = std::numeric_limits<qint64>;
|
using Bounds = std::numeric_limits<qint64>;
|
||||||
if (jd < Bounds::min() + JULIAN_DAY_FOR_EPOCH)
|
if (jd < Bounds::min() + JULIAN_DAY_FOR_EPOCH)
|
||||||
@ -842,9 +844,13 @@ static bool inDateTimeRange(qint64 jd, bool start)
|
|||||||
// (Divisions rounded towards zero, as MSECS_PER_DAY is even - so doesn't
|
// (Divisions rounded towards zero, as MSECS_PER_DAY is even - so doesn't
|
||||||
// divide max() - and has factors other than two, so doesn't divide min().)
|
// divide max() - and has factors other than two, so doesn't divide min().)
|
||||||
// Range includes start of last day and end of first:
|
// Range includes start of last day and end of first:
|
||||||
if (start)
|
switch (side) {
|
||||||
|
case DaySide::Start:
|
||||||
return jd > minDay && jd <= maxDay;
|
return jd > minDay && jd <= maxDay;
|
||||||
return jd >= minDay && jd < maxDay;
|
case DaySide::End:
|
||||||
|
return jd >= minDay && jd < maxDay;
|
||||||
|
}
|
||||||
|
Q_UNREACHABLE_RETURN(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
static QDateTime toEarliest(QDate day, const QTimeZone &zone)
|
static QDateTime toEarliest(QDate day, const QTimeZone &zone)
|
||||||
@ -927,7 +933,7 @@ static QDateTime toEarliest(QDate day, const QTimeZone &zone)
|
|||||||
*/
|
*/
|
||||||
QDateTime QDate::startOfDay(const QTimeZone &zone) const
|
QDateTime QDate::startOfDay(const QTimeZone &zone) const
|
||||||
{
|
{
|
||||||
if (!inDateTimeRange(jd, true) || !zone.isValid())
|
if (!inDateTimeRange(jd, DaySide::Start) || !zone.isValid())
|
||||||
return QDateTime();
|
return QDateTime();
|
||||||
|
|
||||||
QDateTime when(*this, QTime(0, 0), zone);
|
QDateTime when(*this, QTime(0, 0), zone);
|
||||||
@ -1077,7 +1083,7 @@ static QDateTime toLatest(QDate day, const QTimeZone &zone)
|
|||||||
*/
|
*/
|
||||||
QDateTime QDate::endOfDay(const QTimeZone &zone) const
|
QDateTime QDate::endOfDay(const QTimeZone &zone) const
|
||||||
{
|
{
|
||||||
if (!inDateTimeRange(jd, false) || !zone.isValid())
|
if (!inDateTimeRange(jd, DaySide::End) || !zone.isValid())
|
||||||
return QDateTime();
|
return QDateTime();
|
||||||
|
|
||||||
QDateTime when(*this, QTime(23, 59, 59, 999), zone);
|
QDateTime when(*this, QTime(23, 59, 59, 999), zone);
|
||||||
|
Loading…
Reference in New Issue
Block a user