mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-13 08:19:50 -05:00
Various minor code improvements
This commit is contained in:
parent
125a81f2ed
commit
96438a45b4
@ -166,15 +166,16 @@ if("${CMAKE_SIZEOF_VOID_P}" EQUAL "4")
|
|||||||
set(IS_32BIT TRUE)
|
set(IS_32BIT TRUE)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(CLANG_COMPILER_ID_REGEX "^(Apple)?[Cc]lang$")
|
||||||
if("${CMAKE_C_COMPILER}" MATCHES "clang$"
|
if("${CMAKE_C_COMPILER}" MATCHES "clang$"
|
||||||
OR "${CMAKE_EXTRA_GENERATOR_C_SYSTEM_DEFINED_MACROS}" MATCHES "__clang__"
|
OR "${CMAKE_EXTRA_GENERATOR_C_SYSTEM_DEFINED_MACROS}" MATCHES "__clang__"
|
||||||
OR "${CMAKE_C_COMPILER_ID}" STREQUAL "Clang")
|
OR "${CMAKE_C_COMPILER_ID}" MATCHES ${CLANG_COMPILER_ID_REGEX})
|
||||||
set(CMAKE_COMPILER_IS_CLANG 1)
|
set(CMAKE_COMPILER_IS_CLANG 1)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if("${CMAKE_CXX_COMPILER}" MATCHES "clang(\\+\\+)?$"
|
if("${CMAKE_CXX_COMPILER}" MATCHES "clang(\\+\\+)?$"
|
||||||
OR "${CMAKE_EXTRA_GENERATOR_CXX_SYSTEM_DEFINED_MACROS}" MATCHES "__clang__"
|
OR "${CMAKE_EXTRA_GENERATOR_CXX_SYSTEM_DEFINED_MACROS}" MATCHES "__clang__"
|
||||||
OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
OR "${CMAKE_CXX_COMPILER_ID}" MATCHES ${CLANG_COMPILER_ID_REGEX})
|
||||||
set(CMAKE_COMPILER_IS_CLANGXX 1)
|
set(CMAKE_COMPILER_IS_CLANGXX 1)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -253,6 +254,15 @@ if(CMAKE_COMPILER_IS_GNUCXX)
|
|||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wcast-align")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wcast-align")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(WITH_COVERAGE AND CMAKE_COMPILER_IS_CLANGXX)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fprofile-instr-generate -fcoverage-mapping")
|
||||||
|
# then:
|
||||||
|
# $ llvm-profdata merge -sparse default.profraw -o default.profdata
|
||||||
|
# $ llvm-cov show ./tests/${the_test_binary} \
|
||||||
|
# -format=html -instr-profile=default.profdata -output-dir=./coverages \
|
||||||
|
# `find src -iname '*.h' -or -iname '*.cpp'`
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CMAKE_COMPILER_IS_GNUCC)
|
if(CMAKE_COMPILER_IS_GNUCC)
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wcast-align")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wcast-align")
|
||||||
endif()
|
endif()
|
||||||
@ -276,7 +286,7 @@ if((CMAKE_COMPILER_IS_GNUCXX AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 4.9.
|
|||||||
add_gcc_compiler_cxxflags("-fsized-deallocation")
|
add_gcc_compiler_cxxflags("-fsized-deallocation")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE AND CMAKE_COMPILER_IS_CLANGXX)
|
||||||
add_gcc_compiler_cxxflags("-stdlib=libc++")
|
add_gcc_compiler_cxxflags("-stdlib=libc++")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -619,9 +619,9 @@ bool AutoType::windowMatches(const QString& windowTitle, const QString& windowPa
|
|||||||
if (windowPattern.startsWith("//") && windowPattern.endsWith("//") && windowPattern.size() >= 4) {
|
if (windowPattern.startsWith("//") && windowPattern.endsWith("//") && windowPattern.size() >= 4) {
|
||||||
QRegExp regExp(windowPattern.mid(2, windowPattern.size() - 4), Qt::CaseInsensitive, QRegExp::RegExp2);
|
QRegExp regExp(windowPattern.mid(2, windowPattern.size() - 4), Qt::CaseInsensitive, QRegExp::RegExp2);
|
||||||
return (regExp.indexIn(windowTitle) != -1);
|
return (regExp.indexIn(windowTitle) != -1);
|
||||||
} else {
|
}
|
||||||
return WildcardMatcher(windowTitle).match(windowPattern);
|
return WildcardMatcher(windowTitle).match(windowPattern);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,10 +1,6 @@
|
|||||||
set(autotype_mac_SOURCES AutoTypeMac.cpp)
|
set(autotype_mac_SOURCES AutoTypeMac.cpp)
|
||||||
|
|
||||||
set(autotype_mac_mm_SOURCES
|
add_library(keepassx-autotype-cocoa MODULE ${autotype_mac_SOURCES})
|
||||||
${CMAKE_SOURCE_DIR}/src/gui/macutils/AppKitImpl.mm
|
|
||||||
${CMAKE_SOURCE_DIR}/src/gui/macutils/MacUtils.cpp)
|
|
||||||
|
|
||||||
add_library(keepassx-autotype-cocoa MODULE ${autotype_mac_SOURCES} ${autotype_mac_mm_SOURCES})
|
|
||||||
set_target_properties(keepassx-autotype-cocoa PROPERTIES LINK_FLAGS "-framework Foundation -framework AppKit -framework Carbon")
|
set_target_properties(keepassx-autotype-cocoa PROPERTIES LINK_FLAGS "-framework Foundation -framework AppKit -framework Carbon")
|
||||||
target_link_libraries(keepassx-autotype-cocoa ${PROGNAME} Qt5::Core Qt5::Widgets)
|
target_link_libraries(keepassx-autotype-cocoa ${PROGNAME} Qt5::Core Qt5::Widgets)
|
||||||
|
|
||||||
|
@ -340,7 +340,7 @@ QJsonObject BrowserAction::handleSetLogin(const QJsonObject& json, const QString
|
|||||||
QJsonObject message = buildMessage(newNonce);
|
QJsonObject message = buildMessage(newNonce);
|
||||||
message["count"] = QJsonValue::Null;
|
message["count"] = QJsonValue::Null;
|
||||||
message["entries"] = QJsonValue::Null;
|
message["entries"] = QJsonValue::Null;
|
||||||
message["error"] = "";
|
message["error"] = QString("");
|
||||||
message["hash"] = hash;
|
message["hash"] = hash;
|
||||||
|
|
||||||
return buildResponse(action, message, newNonce);
|
return buildResponse(action, message, newNonce);
|
||||||
|
@ -417,7 +417,7 @@ QJsonArray BrowserService::findMatchingEntries(const QString& id,
|
|||||||
|
|
||||||
// Fill the list
|
// Fill the list
|
||||||
for (Entry* entry : pwEntries) {
|
for (Entry* entry : pwEntries) {
|
||||||
result << prepareEntry(entry);
|
result.append(prepareEntry(entry));
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
@ -739,7 +739,7 @@ QList<Entry*> BrowserService::sortEntries(QList<Entry*>& pwEntries, const QStrin
|
|||||||
|| ((QString::localeAwareCompare(left->attributes()->value(field),
|
|| ((QString::localeAwareCompare(left->attributes()->value(field),
|
||||||
right->attributes()->value(field))
|
right->attributes()->value(field))
|
||||||
== 0)
|
== 0)
|
||||||
&& (QString::localeAwareCompare(left->attributes()->value("UserName"),
|
&& (QString::localeAwareCompare(left->attributes()->value("UserName"),
|
||||||
right->attributes()->value("UserName"))
|
right->attributes()->value("UserName"))
|
||||||
< 0));
|
< 0));
|
||||||
});
|
});
|
||||||
@ -825,7 +825,7 @@ QJsonObject BrowserService::prepareEntry(const Entry* entry)
|
|||||||
if (key.startsWith(QLatin1String("KPH: "))) {
|
if (key.startsWith(QLatin1String("KPH: "))) {
|
||||||
QJsonObject sField;
|
QJsonObject sField;
|
||||||
sField[key] = entry->resolveMultiplePlaceholders(attr->value(key));
|
sField[key] = entry->resolveMultiplePlaceholders(attr->value(key));
|
||||||
stringFields << sField;
|
stringFields.append(sField);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
res["stringFields"] = stringFields;
|
res["stringFields"] = stringFields;
|
||||||
|
@ -299,9 +299,9 @@ QJsonObject HostInstaller::constructFile(SupportedBrowsers browser, const bool&
|
|||||||
|
|
||||||
QJsonObject script;
|
QJsonObject script;
|
||||||
script["name"] = HOST_NAME;
|
script["name"] = HOST_NAME;
|
||||||
script["description"] = "KeePassXC integration with native messaging support";
|
script["description"] = QString("KeePassXC integration with native messaging support");
|
||||||
script["path"] = path;
|
script["path"] = path;
|
||||||
script["type"] = "stdio";
|
script["type"] = QString("stdio");
|
||||||
|
|
||||||
QJsonArray arr;
|
QJsonArray arr;
|
||||||
if (browser == SupportedBrowsers::FIREFOX || browser == SupportedBrowsers::TOR_BROWSER) {
|
if (browser == SupportedBrowsers::FIREFOX || browser == SupportedBrowsers::TOR_BROWSER) {
|
||||||
|
@ -102,7 +102,7 @@ void NativeMessagingBase::readNativeMessages()
|
|||||||
{
|
{
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
quint32 length = 0;
|
quint32 length = 0;
|
||||||
while (m_running.load() && !std::cin.eof()) {
|
while (m_running.load() != 0 && !std::cin.eof()) {
|
||||||
length = 0;
|
length = 0;
|
||||||
std::cin.read(reinterpret_cast<char*>(&length), 4);
|
std::cin.read(reinterpret_cast<char*>(&length), 4);
|
||||||
readStdIn(length);
|
readStdIn(length);
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
#ifndef NATIVEMESSAGINGBASE_H
|
#ifndef NATIVEMESSAGINGBASE_H
|
||||||
#define NATIVEMESSAGINGBASE_H
|
#define NATIVEMESSAGINGBASE_H
|
||||||
|
|
||||||
#include <QAtomicInteger>
|
#include <QAtomicInt>
|
||||||
#include <QFuture>
|
#include <QFuture>
|
||||||
#include <QJsonDocument>
|
#include <QJsonDocument>
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
@ -60,7 +60,7 @@ protected:
|
|||||||
QString getLocalServerPath() const;
|
QString getLocalServerPath() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
QAtomicInteger<quint8> m_running;
|
QAtomicInt m_running;
|
||||||
QSharedPointer<QSocketNotifier> m_notifier;
|
QSharedPointer<QSocketNotifier> m_notifier;
|
||||||
QFuture<void> m_future;
|
QFuture<void> m_future;
|
||||||
};
|
};
|
||||||
|
@ -35,9 +35,9 @@ NativeMessagingHost::NativeMessagingHost(DatabaseTabWidget* parent, const bool e
|
|||||||
{
|
{
|
||||||
m_localServer.reset(new QLocalServer(this));
|
m_localServer.reset(new QLocalServer(this));
|
||||||
m_localServer->setSocketOptions(QLocalServer::UserAccessOption);
|
m_localServer->setSocketOptions(QLocalServer::UserAccessOption);
|
||||||
m_running.store(false);
|
m_running.store(0);
|
||||||
|
|
||||||
if (browserSettings()->isEnabled() && !m_running) {
|
if (browserSettings()->isEnabled() && m_running.load() == 0) {
|
||||||
run();
|
run();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,7 +59,7 @@ int NativeMessagingHost::init()
|
|||||||
void NativeMessagingHost::run()
|
void NativeMessagingHost::run()
|
||||||
{
|
{
|
||||||
QMutexLocker locker(&m_mutex);
|
QMutexLocker locker(&m_mutex);
|
||||||
if (!m_running.load() && init() == -1) {
|
if (m_running.load() == 0 && init() == -1) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,7 +69,7 @@ void NativeMessagingHost::run()
|
|||||||
browserSettings()->useCustomProxy() ? browserSettings()->customProxyLocation() : "");
|
browserSettings()->useCustomProxy() ? browserSettings()->customProxyLocation() : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
m_running.store(true);
|
m_running.store(1);
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
m_future =
|
m_future =
|
||||||
QtConcurrent::run(this, static_cast<void (NativeMessagingHost::*)()>(&NativeMessagingHost::readNativeMessages));
|
QtConcurrent::run(this, static_cast<void (NativeMessagingHost::*)()>(&NativeMessagingHost::readNativeMessages));
|
||||||
@ -100,7 +100,7 @@ void NativeMessagingHost::stop()
|
|||||||
databaseLocked();
|
databaseLocked();
|
||||||
QMutexLocker locker(&m_mutex);
|
QMutexLocker locker(&m_mutex);
|
||||||
m_socketList.clear();
|
m_socketList.clear();
|
||||||
m_running.testAndSetOrdered(true, false);
|
m_running.testAndSetOrdered(1, 0);
|
||||||
m_future.waitForFinished();
|
m_future.waitForFinished();
|
||||||
m_localServer->close();
|
m_localServer->close();
|
||||||
}
|
}
|
||||||
@ -210,13 +210,13 @@ void NativeMessagingHost::disconnectSocket()
|
|||||||
void NativeMessagingHost::databaseLocked()
|
void NativeMessagingHost::databaseLocked()
|
||||||
{
|
{
|
||||||
QJsonObject response;
|
QJsonObject response;
|
||||||
response["action"] = "database-locked";
|
response["action"] = QString("database-locked");
|
||||||
sendReplyToAllClients(response);
|
sendReplyToAllClients(response);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeMessagingHost::databaseUnlocked()
|
void NativeMessagingHost::databaseUnlocked()
|
||||||
{
|
{
|
||||||
QJsonObject response;
|
QJsonObject response;
|
||||||
response["action"] = "database-unlocked";
|
response["action"] = QString("database-unlocked");
|
||||||
sendReplyToAllClients(response);
|
sendReplyToAllClients(response);
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,7 @@ NativeMessagingHost::NativeMessagingHost()
|
|||||||
setsockopt(socketDesc, SOL_SOCKET, SO_SNDBUF, reinterpret_cast<char*>(&max), sizeof(max));
|
setsockopt(socketDesc, SOL_SOCKET, SO_SNDBUF, reinterpret_cast<char*>(&max), sizeof(max));
|
||||||
}
|
}
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
m_running.store(true);
|
m_running.store(1);
|
||||||
m_future = QtConcurrent::run(this, &NativeMessagingHost::readNativeMessages);
|
m_future = QtConcurrent::run(this, &NativeMessagingHost::readNativeMessages);
|
||||||
#endif
|
#endif
|
||||||
connect(m_localSocket, SIGNAL(readyRead()), this, SLOT(newLocalMessage()));
|
connect(m_localSocket, SIGNAL(readyRead()), this, SLOT(newLocalMessage()));
|
||||||
@ -56,7 +56,7 @@ void NativeMessagingHost::readNativeMessages()
|
|||||||
{
|
{
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
quint32 length = 0;
|
quint32 length = 0;
|
||||||
while (m_running.load() && !std::cin.eof()) {
|
while (m_running.load() == 1 && !std::cin.eof()) {
|
||||||
length = 0;
|
length = 0;
|
||||||
std::cin.read(reinterpret_cast<char*>(&length), 4);
|
std::cin.read(reinterpret_cast<char*>(&length), 4);
|
||||||
if (!readStdIn(length)) {
|
if (!readStdIn(length)) {
|
||||||
@ -128,6 +128,6 @@ void NativeMessagingHost::deleteSocket()
|
|||||||
void NativeMessagingHost::socketStateChanged(QLocalSocket::LocalSocketState socketState)
|
void NativeMessagingHost::socketStateChanged(QLocalSocket::LocalSocketState socketState)
|
||||||
{
|
{
|
||||||
if (socketState == QLocalSocket::UnconnectedState || socketState == QLocalSocket::ClosingState) {
|
if (socketState == QLocalSocket::UnconnectedState || socketState == QLocalSocket::ClosingState) {
|
||||||
m_running.testAndSetOrdered(true, false);
|
m_running.testAndSetOrdered(1, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user