mirror of
https://github.com/Nheko-Reborn/nheko.git
synced 2024-11-22 19:08:58 +03:00
lint and avoid copy
This commit is contained in:
parent
a320fc6f7a
commit
0ab566dc4b
3 changed files with 44 additions and 43 deletions
|
@ -1652,7 +1652,7 @@ ChatPage::isRoomActive(const QString &room_id)
|
||||||
void
|
void
|
||||||
ChatPage::removeAllNotifications()
|
ChatPage::removeAllNotifications()
|
||||||
{
|
{
|
||||||
#if defined (Q_OS_LINUX)
|
#if defined(Q_OS_LINUX)
|
||||||
notificationsManager->closeAllNotifications();
|
notificationsManager->closeAllNotifications();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
82
src/Config.h
82
src/Config.h
|
@ -25,23 +25,22 @@ constexpr auto LABEL_MEDIUM_SIZE_RATIO = 1.3;
|
||||||
|
|
||||||
namespace strings {
|
namespace strings {
|
||||||
const QString url_html = QStringLiteral("<a href=\"\\1\">\\1</a>");
|
const QString url_html = QStringLiteral("<a href=\"\\1\">\\1</a>");
|
||||||
const QRegularExpression
|
const QRegularExpression url_regex(
|
||||||
url_regex(
|
// match an unquoted URL
|
||||||
// match an unquoted URL
|
[]() {
|
||||||
[]() {
|
const auto general_unicode = QStringLiteral(
|
||||||
const auto general_unicode = QStringLiteral(
|
R"((?:[^\x{0}-\x{7f}\p{Cc}\s\p{P}]|[\x{2010}\x{2011}\x{2012}\x{2013}\x{2014}\x{2015}]))");
|
||||||
R"((?:[^\x{0}-\x{7f}\p{Cc}\s\p{P}]|[\x{2010}\x{2011}\x{2012}\x{2013}\x{2014}\x{2015}]))");
|
const auto protocol = QStringLiteral(R"((?:[Hh][Tt][Tt][Pp][Ss]?))");
|
||||||
const auto protocol = QStringLiteral(R"((?:[Hh][Tt][Tt][Pp][Ss]?))");
|
const auto unreserved_subdelims_colon = QStringLiteral(R"([a-zA-Z0-9\-._~!$&'()*+,;=:])");
|
||||||
const auto unreserved_subdelims_colon = QStringLiteral(R"([a-zA-Z0-9\-._~!$&'()*+,;=:])");
|
const auto pct_enc = QStringLiteral(R"((?:%[[:xdigit:]]{2}))");
|
||||||
const auto pct_enc = QStringLiteral(R"((?:%[[:xdigit:]]{2}))");
|
const auto userinfo =
|
||||||
const auto userinfo = "(?:" + unreserved_subdelims_colon + "*(?:" + pct_enc +
|
"(?:" + unreserved_subdelims_colon + "*(?:" + pct_enc + unreserved_subdelims_colon + "*)*)";
|
||||||
unreserved_subdelims_colon + "*)*)";
|
const auto dec_octet =
|
||||||
const auto dec_octet =
|
QStringLiteral(R"((?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9]))");
|
||||||
QStringLiteral(R"((?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9]))");
|
const auto ipv4_addr = "(?:" + dec_octet + R"((?:\.)" + dec_octet + "){3})";
|
||||||
const auto ipv4_addr = "(?:" + dec_octet + R"((?:\.)" + dec_octet + "){3})";
|
const auto h16 = QStringLiteral(R"((?:[[:xdigit:]]{1,4}))");
|
||||||
const auto h16 = QStringLiteral(R"((?:[[:xdigit:]]{1,4}))");
|
const auto ls32 = "(?:" + h16 + ":" + h16 + "|" + ipv4_addr + ")";
|
||||||
const auto ls32 = "(?:" + h16 + ":" + h16 + "|" + ipv4_addr + ")";
|
// clang-format off
|
||||||
// clang-format off
|
|
||||||
const auto ipv6_addr = "(?:"
|
const auto ipv6_addr = "(?:"
|
||||||
"(?:" + h16 + ":){6}" + ls32
|
"(?:" + h16 + ":){6}" + ls32
|
||||||
+ "|" "::(?:" + h16 + ":){5}" + ls32
|
+ "|" "::(?:" + h16 + ":){5}" + ls32
|
||||||
|
@ -53,30 +52,31 @@ const QRegularExpression
|
||||||
+ "|" "(?:" + h16 + "(?::" + h16 + "){0,5})?::" + h16
|
+ "|" "(?:" + h16 + "(?::" + h16 + "){0,5})?::" + h16
|
||||||
+ "|" "(?:" + h16 + "(?::" + h16 + "){0,6})?::"
|
+ "|" "(?:" + h16 + "(?::" + h16 + "){0,6})?::"
|
||||||
")";
|
")";
|
||||||
// clang-format on
|
// clang-format on
|
||||||
const auto ipvfuture = R"((?:v[[:xdigit:]]+\.)" + unreserved_subdelims_colon + "+)";
|
const auto ipvfuture = R"((?:v[[:xdigit:]]+\.)" + unreserved_subdelims_colon + "+)";
|
||||||
const auto ip_literal = R"((?:\[(?:)" + ipv6_addr + "|" + ipvfuture + R"()\]))";
|
const auto ip_literal = R"((?:\[(?:)" + ipv6_addr + "|" + ipvfuture + R"()\]))";
|
||||||
const auto host_alnum = "(?:[a-zA-Z0-9]|" + general_unicode + ")";
|
const auto host_alnum = "(?:[a-zA-Z0-9]|" + general_unicode + ")";
|
||||||
const auto host_label = "(?:" + host_alnum + "+(?:-+" + host_alnum + "+)*)";
|
const auto host_label = "(?:" + host_alnum + "+(?:-+" + host_alnum + "+)*)";
|
||||||
const auto hostname = "(?:" + host_label + R"((?:\.)" + host_label + R"()*\.?))";
|
const auto hostname = "(?:" + host_label + R"((?:\.)" + host_label + R"()*\.?))";
|
||||||
const auto host = "(?:" + hostname + "|" + ip_literal + ")";
|
const auto host = "(?:" + hostname + "|" + ip_literal + ")";
|
||||||
const auto path = R"((?:/((?:[a-zA-Z0-9\-._~!$&'*+,;=:@/]|)" + pct_enc + R"(|\((?-1)\)|)" +
|
const auto path = R"((?:/((?:[a-zA-Z0-9\-._~!$&'*+,;=:@/]|)" + pct_enc + R"(|\((?-1)\)|)" +
|
||||||
general_unicode + ")*))";
|
general_unicode + ")*))";
|
||||||
const auto query = R"(((?:[a-zA-Z0-9\-._~!$&'*+,;=:@/?\\{}]|)" + pct_enc +
|
const auto query = R"(((?:[a-zA-Z0-9\-._~!$&'*+,;=:@/?\\{}]|)" + pct_enc +
|
||||||
R"(|\((?-1)\)|\[(?-1)\]|)" + general_unicode + ")*)";
|
R"(|\((?-1)\)|\[(?-1)\]|)" + general_unicode + ")*)";
|
||||||
const auto &fragment = query;
|
const auto &fragment = query;
|
||||||
return
|
return R"((?<!["'\w])(?>()" + protocol + "://" + "(?:" + userinfo + "@)?" + host +
|
||||||
R"((?<!["'\w])(?>()"
|
"(?::[0-9]+)?" + path +
|
||||||
+ protocol + "://"
|
"?"
|
||||||
+ "(?:" + userinfo + "@)?"
|
R"((?:\?)" +
|
||||||
+ host + "(?::[0-9]+)?"
|
query +
|
||||||
+ path + "?"
|
")?"
|
||||||
R"((?:\?)" + query + ")?"
|
R"((?:#)" +
|
||||||
R"((?:#)" + fragment + ")?"
|
fragment +
|
||||||
"(?<![.!?,;:'])"
|
")?"
|
||||||
R"())(?!["']))";
|
"(?<![.!?,;:'])"
|
||||||
}(),
|
R"())(?!["']))";
|
||||||
QRegularExpression::UseUnicodePropertiesOption);
|
}(),
|
||||||
|
QRegularExpression::UseUnicodePropertiesOption);
|
||||||
// A matrix link to be converted back to markdown
|
// A matrix link to be converted back to markdown
|
||||||
static const QRegularExpression
|
static const QRegularExpression
|
||||||
matrixToLink(QStringLiteral(R"(<a href=\"(https://matrix.to/#/.*?)\">(.*?)</a>)"));
|
matrixToLink(QStringLiteral(R"(<a href=\"(https://matrix.to/#/.*?)\">(.*?)</a>)"));
|
||||||
|
|
|
@ -275,7 +275,8 @@ NotificationsManager::notificationClosed(uint id, uint reason)
|
||||||
void
|
void
|
||||||
NotificationsManager::closeAllNotifications()
|
NotificationsManager::closeAllNotifications()
|
||||||
{
|
{
|
||||||
for (auto id : notificationIds.keys()) {
|
const auto ids = notificationIds.keys();
|
||||||
|
for (const auto &id : ids) {
|
||||||
closeNotification(id);
|
closeNotification(id);
|
||||||
notificationIds.remove(id);
|
notificationIds.remove(id);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue