- 
    Bug 
- 
    Resolution: Fixed
- 
    P3: Somewhat important 
- 
    6.8
- 
    None
- 
        
- 
        1
- 
        0fb3661f1 (dev), 453d8797f (dev)
- 
        Foundation Sprint 123
The original report is from the forum: https://forum.qt.io/topic/160278
QChronoTimer::remainingTime() can not return a duration > ~24days due to an integer overflow inside int QEventDispatcherWin32::remainingTime() because this function can only return integers in Qt6.
I wonder why this should work on linux with gcc13 though (at least someone else from the forum checked it with this combination)
Reproducer:
int main(int argc, char **argv) { QCoreApplication app(argc, argv); ChronoTimer timer; qint64 interval = 24; timer.setInterval(days(interval)); timer.start(); qDebug() << "days:" << duration_cast<days>(timer.remainingTime()).count(); QChronoTimer timer2; interval = 25; timer2.setInterval(days(interval)); timer2.start(); qDebug() << "days:" << duration_cast<days>(timer2.remainingTime()).count(); }
- relates to
- 
                    QTBUG-129170 QEventDispatcherWin needs porting to QAbstractEventDispatcherV2 -         
- Closed
 
-         
| For Gerrit Dashboard: QTBUG-132388 | ||||||
|---|---|---|---|---|---|---|
| # | Subject | Branch | Project | Status | CR | V | 
| 616912,4 | QChronoTimer: add test for interval (u)int overflow | dev | qt/qtbase | Status: MERGED | +2 | 0 | 
| 616934,5 | QEventDispatcherWin32: consistently use ms precision in calculations | dev | qt/qtbase | Status: MERGED | +2 | 0 |