mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-25 14:04:23 +00:00
- Improved date handling in RSS
This commit is contained in:
parent
8ed0e58d63
commit
2ce375d8eb
@ -37,7 +37,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~FeedList() {
|
~FeedList() {
|
||||||
delete unread_item;
|
//delete unread_item;
|
||||||
}
|
}
|
||||||
|
|
||||||
void itemAdded(QTreeWidgetItem *item, RssFile* file) {
|
void itemAdded(QTreeWidgetItem *item, RssFile* file) {
|
||||||
|
16
src/rss.h
16
src/rss.h
@ -137,7 +137,7 @@ protected:
|
|||||||
QDateTime parseDate(const QString &string) {
|
QDateTime parseDate(const QString &string) {
|
||||||
QString str = string.trimmed();
|
QString str = string.trimmed();
|
||||||
if (str.isEmpty())
|
if (str.isEmpty())
|
||||||
return QDateTime();
|
return QDateTime::currentDateTime();
|
||||||
|
|
||||||
int nyear = 6; // indexes within string to values
|
int nyear = 6; // indexes within string to values
|
||||||
int nmonth = 4;
|
int nmonth = 4;
|
||||||
@ -155,12 +155,12 @@ protected:
|
|||||||
bool h1 = (parts[3] == QLatin1String("-"));
|
bool h1 = (parts[3] == QLatin1String("-"));
|
||||||
bool h2 = (parts[5] == QLatin1String("-"));
|
bool h2 = (parts[5] == QLatin1String("-"));
|
||||||
if (h1 != h2)
|
if (h1 != h2)
|
||||||
return QDateTime();
|
return QDateTime::currentDateTime();
|
||||||
} else {
|
} else {
|
||||||
// Check for the obsolete form "Wdy Mon DD HH:MM:SS YYYY"
|
// Check for the obsolete form "Wdy Mon DD HH:MM:SS YYYY"
|
||||||
rx = QRegExp("^([A-Z][a-z]+)\\s+(\\S+)\\s+(\\d\\d)\\s+(\\d\\d):(\\d\\d):(\\d\\d)\\s+(\\d\\d\\d\\d)$");
|
rx = QRegExp("^([A-Z][a-z]+)\\s+(\\S+)\\s+(\\d\\d)\\s+(\\d\\d):(\\d\\d):(\\d\\d)\\s+(\\d\\d\\d\\d)$");
|
||||||
if (str.indexOf(rx))
|
if (str.indexOf(rx))
|
||||||
return QDateTime();
|
return QDateTime::currentDateTime();
|
||||||
nyear = 7;
|
nyear = 7;
|
||||||
nmonth = 2;
|
nmonth = 2;
|
||||||
nday = 3;
|
nday = 3;
|
||||||
@ -176,12 +176,12 @@ protected:
|
|||||||
int hour = parts[nhour].toInt(&ok[2]);
|
int hour = parts[nhour].toInt(&ok[2]);
|
||||||
int minute = parts[nmin].toInt(&ok[3]);
|
int minute = parts[nmin].toInt(&ok[3]);
|
||||||
if (!ok[0] || !ok[1] || !ok[2] || !ok[3])
|
if (!ok[0] || !ok[1] || !ok[2] || !ok[3])
|
||||||
return QDateTime();
|
return QDateTime::currentDateTime();
|
||||||
int second = 0;
|
int second = 0;
|
||||||
if (!parts[nsec].isEmpty()) {
|
if (!parts[nsec].isEmpty()) {
|
||||||
second = parts[nsec].toInt(&ok[0]);
|
second = parts[nsec].toInt(&ok[0]);
|
||||||
if (!ok[0])
|
if (!ok[0])
|
||||||
return QDateTime();
|
return QDateTime::currentDateTime();
|
||||||
}
|
}
|
||||||
bool leapSecond = (second == 60);
|
bool leapSecond = (second == 60);
|
||||||
if (leapSecond)
|
if (leapSecond)
|
||||||
@ -247,11 +247,11 @@ protected:
|
|||||||
}
|
}
|
||||||
QDate qdate(year, month+1, day); // convert date, and check for out-of-range
|
QDate qdate(year, month+1, day); // convert date, and check for out-of-range
|
||||||
if (!qdate.isValid())
|
if (!qdate.isValid())
|
||||||
return QDateTime();
|
return QDateTime::currentDateTime();
|
||||||
QDateTime result(qdate, QTime(hour, minute, second));
|
QDateTime result(qdate, QTime(hour, minute, second));
|
||||||
if (!result.isValid()
|
if (!result.isValid()
|
||||||
|| (dayOfWeek >= 0 && result.date().dayOfWeek() != dayOfWeek+1))
|
|| (dayOfWeek >= 0 && result.date().dayOfWeek() != dayOfWeek+1))
|
||||||
return QDateTime(); // invalid date/time, or weekday doesn't correspond with date
|
return QDateTime::currentDateTime(); // invalid date/time, or weekday doesn't correspond with date
|
||||||
if (!offset) {
|
if (!offset) {
|
||||||
result.setTimeSpec(Qt::UTC);
|
result.setTimeSpec(Qt::UTC);
|
||||||
}
|
}
|
||||||
@ -259,7 +259,7 @@ protected:
|
|||||||
// Validate a leap second time. Leap seconds are inserted after 23:59:59 UTC.
|
// Validate a leap second time. Leap seconds are inserted after 23:59:59 UTC.
|
||||||
// Convert the time to UTC and check that it is 00:00:00.
|
// Convert the time to UTC and check that it is 00:00:00.
|
||||||
if ((hour*3600 + minute*60 + 60 - offset + 86400*5) % 86400) // (max abs(offset) is 100 hours)
|
if ((hour*3600 + minute*60 + 60 - offset + 86400*5) % 86400) // (max abs(offset) is 100 hours)
|
||||||
return QDateTime(); // the time isn't the last second of the day
|
return QDateTime::currentDateTime(); // the time isn't the last second of the day
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -475,7 +475,7 @@ void RSSImp::refreshTextBrowser() {
|
|||||||
html += "<div style='border: 2px solid red; margin-left: 5px; margin-right: 5px; margin-bottom: 5px;'>";
|
html += "<div style='border: 2px solid red; margin-left: 5px; margin-right: 5px; margin-bottom: 5px;'>";
|
||||||
html += "<div style='background-color: #678db2; font-weight: bold; color: #fff;'>"+article->getTitle() + "</div>";
|
html += "<div style='background-color: #678db2; font-weight: bold; color: #fff;'>"+article->getTitle() + "</div>";
|
||||||
if(article->getDate().isValid()) {
|
if(article->getDate().isValid()) {
|
||||||
html += "<div style='background-color: #efefef;'><b>"+tr("Date: ")+"</b>"+article->getDate().toString()+"</div>";
|
html += "<div style='background-color: #efefef;'><b>"+tr("Date: ")+"</b>"+article->getDate().toLocalTime().toString(Qt::SystemLocaleLongDate)+"</div>";
|
||||||
}
|
}
|
||||||
if(!article->getAuthor().isEmpty()) {
|
if(!article->getAuthor().isEmpty()) {
|
||||||
html += "<div style='background-color: #efefef;'><b>"+tr("Author: ")+"</b>"+article->getAuthor()+"</div>";
|
html += "<div style='background-color: #efefef;'><b>"+tr("Author: ")+"</b>"+article->getAuthor()+"</div>";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user