mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-23 05:01:19 -05:00
Separate GUI sources from core sources.
This PR splits the GUI source files from the core source files. The immediate goal is to allow the CLI to require only a minimum number of dynamic libraries. The long term goal is to create an architectural boundary around the core module, in preparation of libkdbx.
This commit is contained in:
parent
3e3e87d3c5
commit
a7ffd28e26
@ -89,6 +89,19 @@ set(keepassx_SOURCES
|
|||||||
format/OpVaultReaderAttachments.cpp
|
format/OpVaultReaderAttachments.cpp
|
||||||
format/OpVaultReaderBandEntry.cpp
|
format/OpVaultReaderBandEntry.cpp
|
||||||
format/OpVaultReaderSections.cpp
|
format/OpVaultReaderSections.cpp
|
||||||
|
keys/CompositeKey.cpp
|
||||||
|
keys/FileKey.cpp
|
||||||
|
keys/PasswordKey.cpp
|
||||||
|
keys/ChallengeResponseKey.cpp
|
||||||
|
streams/HashedBlockStream.cpp
|
||||||
|
streams/HmacBlockStream.cpp
|
||||||
|
streams/LayeredStream.cpp
|
||||||
|
streams/qtiocompressor.cpp
|
||||||
|
streams/StoreDataStream.cpp
|
||||||
|
streams/SymmetricCipherStream.cpp
|
||||||
|
totp/totp.cpp)
|
||||||
|
|
||||||
|
set(gui_SOURCES
|
||||||
gui/styles/styles.qrc
|
gui/styles/styles.qrc
|
||||||
gui/styles/StateColorPalette.cpp
|
gui/styles/StateColorPalette.cpp
|
||||||
gui/styles/base/phantomcolor.cpp
|
gui/styles/base/phantomcolor.cpp
|
||||||
@ -182,52 +195,41 @@ set(keepassx_SOURCES
|
|||||||
gui/wizard/NewDatabaseWizardPage.cpp
|
gui/wizard/NewDatabaseWizardPage.cpp
|
||||||
gui/wizard/NewDatabaseWizardPageMetaData.cpp
|
gui/wizard/NewDatabaseWizardPageMetaData.cpp
|
||||||
gui/wizard/NewDatabaseWizardPageEncryption.cpp
|
gui/wizard/NewDatabaseWizardPageEncryption.cpp
|
||||||
gui/wizard/NewDatabaseWizardPageDatabaseKey.cpp
|
gui/wizard/NewDatabaseWizardPageDatabaseKey.cpp)
|
||||||
keys/CompositeKey.cpp
|
|
||||||
keys/FileKey.cpp
|
|
||||||
keys/PasswordKey.cpp
|
|
||||||
keys/ChallengeResponseKey.cpp
|
|
||||||
streams/HashedBlockStream.cpp
|
|
||||||
streams/HmacBlockStream.cpp
|
|
||||||
streams/LayeredStream.cpp
|
|
||||||
streams/qtiocompressor.cpp
|
|
||||||
streams/StoreDataStream.cpp
|
|
||||||
streams/SymmetricCipherStream.cpp
|
|
||||||
totp/totp.cpp)
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set(keepassx_SOURCES
|
set(gui_SOURCES
|
||||||
${keepassx_SOURCES}
|
${gui_SOURCES}
|
||||||
core/MacPasteboard.cpp
|
|
||||||
gui/osutils/macutils/MacUtils.cpp
|
gui/osutils/macutils/MacUtils.cpp
|
||||||
gui/osutils/macutils/ScreenLockListenerMac.cpp
|
gui/osutils/macutils/ScreenLockListenerMac.cpp
|
||||||
gui/osutils/macutils/AppKitImpl.mm
|
gui/osutils/macutils/AppKitImpl.mm
|
||||||
gui/osutils/macutils/AppKit.h)
|
gui/osutils/macutils/AppKit.h)
|
||||||
endif()
|
endif()
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
set(keepassx_SOURCES
|
set(gui_SOURCES
|
||||||
${keepassx_SOURCES}
|
${gui_SOURCES}
|
||||||
gui/osutils/nixutils/ScreenLockListenerDBus.cpp
|
gui/osutils/nixutils/ScreenLockListenerDBus.cpp
|
||||||
gui/osutils/nixutils/NixUtils.cpp)
|
gui/osutils/nixutils/NixUtils.cpp)
|
||||||
if(WITH_XC_X11)
|
if(WITH_XC_X11)
|
||||||
list(APPEND keepassx_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
gui/osutils/nixutils/X11Funcs.cpp)
|
gui/osutils/nixutils/X11Funcs.cpp)
|
||||||
endif()
|
endif()
|
||||||
qt5_add_dbus_adaptor(keepassx_SOURCES
|
qt5_add_dbus_adaptor(gui_SOURCES
|
||||||
gui/org.keepassxc.KeePassXC.MainWindow.xml
|
gui/org.keepassxc.KeePassXC.MainWindow.xml
|
||||||
gui/MainWindow.h
|
gui/MainWindow.h
|
||||||
MainWindow)
|
MainWindow)
|
||||||
endif()
|
endif()
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(keepassx_SOURCES
|
set(gui_SOURCES
|
||||||
${keepassx_SOURCES}
|
${gui_SOURCES}
|
||||||
gui/osutils/winutils/ScreenLockListenerWin.cpp
|
gui/osutils/winutils/ScreenLockListenerWin.cpp
|
||||||
gui/osutils/winutils/WinUtils.cpp)
|
gui/osutils/winutils/WinUtils.cpp)
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
list(APPEND keepassx_SOURCES winhello/WindowsHello.cpp)
|
list(APPEND gui_SOURCES winhello/WindowsHello.cpp)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(keepassx_SOURCES ${keepassx_SOURCES}
|
set(gui_SOURCES ${gui_SOURCES}
|
||||||
../share/icons/icons.qrc
|
../share/icons/icons.qrc
|
||||||
../share/wizard/wizard.qrc)
|
../share/wizard/wizard.qrc)
|
||||||
|
|
||||||
@ -248,10 +250,10 @@ add_subdirectory(browser)
|
|||||||
add_subdirectory(proxy)
|
add_subdirectory(proxy)
|
||||||
if(WITH_XC_BROWSER)
|
if(WITH_XC_BROWSER)
|
||||||
set(keepassxcbrowser_LIB keepassxcbrowser)
|
set(keepassxcbrowser_LIB keepassxcbrowser)
|
||||||
set(keepassx_SOURCES ${keepassx_SOURCES} gui/dbsettings/DatabaseSettingsWidgetBrowser.cpp)
|
set(gui_SOURCES ${gui_SOURCES} gui/dbsettings/DatabaseSettingsWidgetBrowser.cpp)
|
||||||
set(keepassx_SOURCES ${keepassx_SOURCES} gui/entry/EntryURLModel.cpp)
|
set(gui_SOURCES ${gui_SOURCES} gui/entry/EntryURLModel.cpp)
|
||||||
set(keepassx_SOURCES ${keepassx_SOURCES} gui/reports/ReportsWidgetBrowserStatistics.cpp)
|
set(gui_SOURCES ${gui_SOURCES} gui/reports/ReportsWidgetBrowserStatistics.cpp)
|
||||||
set(keepassx_SOURCES ${keepassx_SOURCES} gui/reports/ReportsPageBrowserStatistics.cpp)
|
set(gui_SOURCES ${gui_SOURCES} gui/reports/ReportsPageBrowserStatistics.cpp)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_subdirectory(autotype)
|
add_subdirectory(autotype)
|
||||||
@ -277,7 +279,6 @@ endif()
|
|||||||
add_subdirectory(thirdparty)
|
add_subdirectory(thirdparty)
|
||||||
|
|
||||||
set(autotype_SOURCES
|
set(autotype_SOURCES
|
||||||
core/Tools.cpp
|
|
||||||
autotype/AutoType.cpp
|
autotype/AutoType.cpp
|
||||||
autotype/AutoTypeAction.cpp
|
autotype/AutoTypeAction.cpp
|
||||||
autotype/AutoTypeMatchModel.cpp
|
autotype/AutoTypeMatchModel.cpp
|
||||||
@ -305,13 +306,13 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WITH_XC_NETWORKING)
|
if(WITH_XC_NETWORKING)
|
||||||
list(APPEND keepassx_SOURCES
|
list(APPEND gui_SOURCES
|
||||||
core/HibpDownloader.cpp
|
networking/HibpDownloader.cpp
|
||||||
core/NetworkManager.cpp
|
networking/NetworkManager.cpp
|
||||||
|
networking/UpdateChecker.cpp
|
||||||
gui/UpdateCheckDialog.cpp
|
gui/UpdateCheckDialog.cpp
|
||||||
gui/IconDownloader.cpp
|
gui/IconDownloader.cpp
|
||||||
gui/IconDownloaderDialog.cpp
|
gui/IconDownloaderDialog.cpp)
|
||||||
updatecheck/UpdateChecker.cpp)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
@ -328,51 +329,61 @@ target_link_libraries(autotype Qt5::Core Qt5::Widgets)
|
|||||||
|
|
||||||
add_library(keepassx_core STATIC ${keepassx_SOURCES})
|
add_library(keepassx_core STATIC ${keepassx_SOURCES})
|
||||||
|
|
||||||
set_target_properties(keepassx_core PROPERTIES COMPILE_DEFINITIONS KEEPASSX_BUILDING_CORE)
|
set(gui_SOURCES
|
||||||
target_link_libraries(keepassx_core
|
${gui_SOURCES}
|
||||||
autotype
|
${keepassx_SOURCES})
|
||||||
${keepassxcbrowser_LIB}
|
|
||||||
|
set(keepassx_core_LIBRARIES
|
||||||
${qrcode_LIB}
|
${qrcode_LIB}
|
||||||
${fdosecrets_LIB}
|
|
||||||
Qt5::Core
|
Qt5::Core
|
||||||
Qt5::Concurrent
|
Qt5::Concurrent
|
||||||
Qt5::Network
|
|
||||||
Qt5::Widgets
|
|
||||||
${BOTAN2_LIBRARIES}
|
${BOTAN2_LIBRARIES}
|
||||||
${PCSC_LIBRARIES}
|
${PCSC_LIBRARIES}
|
||||||
${ZXCVBN_LIBRARIES}
|
${ZXCVBN_LIBRARIES}
|
||||||
${ZLIB_LIBRARIES}
|
${ZLIB_LIBRARIES}
|
||||||
${ARGON2_LIBRARIES}
|
${ARGON2_LIBRARIES}
|
||||||
${thirdparty_LIBRARIES}
|
${thirdparty_LIBRARIES})
|
||||||
)
|
|
||||||
|
add_library(keepassx_gui STATIC ${gui_SOURCES})
|
||||||
|
target_link_libraries(keepassx_gui
|
||||||
|
${keepassx_core_LIBRARIES}
|
||||||
|
Qt5::Network
|
||||||
|
Qt5::Widgets
|
||||||
|
autotype
|
||||||
|
${keepassxcbrowser_LIB}
|
||||||
|
${fdosecrets_LIB}
|
||||||
|
)
|
||||||
|
|
||||||
|
set_target_properties(keepassx_core PROPERTIES COMPILE_DEFINITIONS KEEPASSX_BUILDING_CORE)
|
||||||
|
target_link_libraries(keepassx_core ${keepassx_core_LIBRARIES})
|
||||||
|
|
||||||
if(WITH_XC_SSHAGENT)
|
if(WITH_XC_SSHAGENT)
|
||||||
target_link_libraries(keepassx_core sshagent)
|
target_link_libraries(keepassx_gui sshagent)
|
||||||
endif()
|
endif()
|
||||||
if(WITH_XC_KEESHARE)
|
if(WITH_XC_KEESHARE)
|
||||||
target_link_libraries(keepassx_core keeshare)
|
target_link_libraries(keepassx_gui keeshare)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
target_link_libraries(keepassx_core "-framework Foundation -framework AppKit -framework Carbon -framework Security -framework LocalAuthentication")
|
target_link_libraries(keepassx_gui "-framework Foundation -framework AppKit -framework Carbon -framework Security -framework LocalAuthentication")
|
||||||
if(Qt5MacExtras_FOUND)
|
if(Qt5MacExtras_FOUND)
|
||||||
target_link_libraries(keepassx_core Qt5::MacExtras)
|
target_link_libraries(keepassx_gui Qt5::MacExtras)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
if(HAIKU)
|
if(HAIKU)
|
||||||
target_link_libraries(keepassx_core network)
|
target_link_libraries(keepassx_gui network)
|
||||||
endif()
|
endif()
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
target_link_libraries(keepassx_core Qt5::DBus)
|
target_link_libraries(keepassx_gui Qt5::DBus)
|
||||||
if(WITH_XC_X11)
|
if(WITH_XC_X11)
|
||||||
target_link_libraries(keepassx_core Qt5::X11Extras X11)
|
target_link_libraries(keepassx_gui Qt5::X11Extras X11)
|
||||||
endif()
|
endif()
|
||||||
include_directories(${Qt5Gui_PRIVATE_INCLUDE_DIRS})
|
include_directories(${Qt5Gui_PRIVATE_INCLUDE_DIRS})
|
||||||
endif()
|
endif()
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
target_link_libraries(keepassx_core Wtsapi32.lib Ws2_32.lib)
|
target_link_libraries(keepassx_gui Wtsapi32.lib Ws2_32.lib)
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
target_link_libraries(keepassx_core WindowsApp.lib)
|
target_link_libraries(keepassx_gui WindowsApp.lib)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -389,7 +400,7 @@ if(WIN32)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_executable(${PROGNAME} WIN32 ${keepassx_SOURCES_MAINEXE} ${WIN32_ProductVersionFiles})
|
add_executable(${PROGNAME} WIN32 ${keepassx_SOURCES_MAINEXE} ${WIN32_ProductVersionFiles})
|
||||||
target_link_libraries(${PROGNAME} keepassx_core)
|
target_link_libraries(${PROGNAME} keepassx_gui)
|
||||||
|
|
||||||
set_target_properties(${PROGNAME} PROPERTIES ENABLE_EXPORTS ON)
|
set_target_properties(${PROGNAME} PROPERTIES ENABLE_EXPORTS ON)
|
||||||
|
|
||||||
@ -532,5 +543,5 @@ if(WIN32)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# The install commands in this subdirectory will be executed after all the install commands in the
|
# The install commands in this subdirectory will be executed after all the install commands in the
|
||||||
# current scope are ran. It is required for correct functtioning of macdeployqt.
|
# current scope are ran. It is required for correct functioning of macdeployqt.
|
||||||
add_subdirectory(post_install)
|
add_subdirectory(post_install)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
set(autotype_test_SOURCES AutoTypeTest.cpp)
|
set(autotype_test_SOURCES AutoTypeTest.cpp)
|
||||||
|
|
||||||
add_library(keepassxc-autotype-test MODULE ${autotype_test_SOURCES})
|
add_library(keepassxc-autotype-test MODULE ${autotype_test_SOURCES})
|
||||||
target_link_libraries(keepassxc-autotype-test keepassx_core ${autotype_LIB} Qt5::Core Qt5::Widgets)
|
target_link_libraries(keepassxc-autotype-test keepassx_gui ${autotype_LIB} Qt5::Core Qt5::Widgets)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
set(autotype_win_SOURCES AutoTypeWindows.cpp)
|
set(autotype_win_SOURCES AutoTypeWindows.cpp)
|
||||||
|
|
||||||
add_library(keepassxc-autotype-windows MODULE ${autotype_win_SOURCES})
|
add_library(keepassxc-autotype-windows MODULE ${autotype_win_SOURCES})
|
||||||
target_link_libraries(keepassxc-autotype-windows keepassx_core ${autotype_LIB} Qt5::Core Qt5::Widgets)
|
target_link_libraries(keepassxc-autotype-windows keepassx_gui ${autotype_LIB} Qt5::Core Qt5::Widgets)
|
||||||
install(TARGETS keepassxc-autotype-windows
|
install(TARGETS keepassxc-autotype-windows
|
||||||
BUNDLE DESTINATION . COMPONENT Runtime
|
BUNDLE DESTINATION . COMPONENT Runtime
|
||||||
LIBRARY DESTINATION ${PLUGIN_INSTALL_DIR} COMPONENT Runtime)
|
LIBRARY DESTINATION ${PLUGIN_INSTALL_DIR} COMPONENT Runtime)
|
||||||
|
@ -3,7 +3,7 @@ include_directories(SYSTEM ${X11_X11_INCLUDE_PATH})
|
|||||||
set(autotype_XCB_SOURCES AutoTypeXCB.cpp)
|
set(autotype_XCB_SOURCES AutoTypeXCB.cpp)
|
||||||
|
|
||||||
add_library(keepassxc-autotype-xcb MODULE ${autotype_XCB_SOURCES})
|
add_library(keepassxc-autotype-xcb MODULE ${autotype_XCB_SOURCES})
|
||||||
target_link_libraries(keepassxc-autotype-xcb keepassx_core Qt5::Core Qt5::Widgets Qt5::X11Extras ${X11_X11_LIB} ${X11_Xi_LIB} ${X11_XTest_LIB})
|
target_link_libraries(keepassxc-autotype-xcb keepassx_gui Qt5::Core Qt5::Widgets Qt5::X11Extras ${X11_X11_LIB} ${X11_Xi_LIB} ${X11_XTest_LIB})
|
||||||
install(TARGETS keepassxc-autotype-xcb
|
install(TARGETS keepassxc-autotype-xcb
|
||||||
BUNDLE DESTINATION . COMPONENT Runtime
|
BUNDLE DESTINATION . COMPONENT Runtime
|
||||||
LIBRARY DESTINATION ${PLUGIN_INSTALL_DIR} COMPONENT Runtime)
|
LIBRARY DESTINATION ${PLUGIN_INSTALL_DIR} COMPONENT Runtime)
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
#include "IconDownloader.h"
|
#include "IconDownloader.h"
|
||||||
#include "core/Config.h"
|
#include "core/Config.h"
|
||||||
#include "core/NetworkManager.h"
|
#include "networking/NetworkManager.h"
|
||||||
|
|
||||||
#include <QBuffer>
|
#include <QBuffer>
|
||||||
#include <QHostInfo>
|
#include <QHostInfo>
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
|
|
||||||
#ifdef WITH_XC_UPDATECHECK
|
#ifdef WITH_XC_UPDATECHECK
|
||||||
#include "gui/UpdateCheckDialog.h"
|
#include "gui/UpdateCheckDialog.h"
|
||||||
#include "updatecheck/UpdateChecker.h"
|
#include "networking/UpdateChecker.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WITH_XC_SSHAGENT
|
#ifdef WITH_XC_SSHAGENT
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
#include "config-keepassx.h"
|
#include "config-keepassx.h"
|
||||||
#include "gui/Icons.h"
|
#include "gui/Icons.h"
|
||||||
#include "updatecheck/UpdateChecker.h"
|
#include "networking/UpdateChecker.h"
|
||||||
|
|
||||||
UpdateCheckDialog::UpdateCheckDialog(QWidget* parent)
|
UpdateCheckDialog::UpdateCheckDialog(QWidget* parent)
|
||||||
: QDialog(parent)
|
: QDialog(parent)
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
|
|
||||||
#ifdef WITH_XC_NETWORKING
|
#ifdef WITH_XC_NETWORKING
|
||||||
#include "core/HibpDownloader.h"
|
#include "networking/HibpDownloader.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
class Database;
|
class Database;
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "HibpDownloader.h"
|
#include "HibpDownloader.h"
|
||||||
#include "core/NetworkManager.h"
|
#include "NetworkManager.h"
|
||||||
|
|
||||||
#include <QCryptographicHash>
|
#include <QCryptographicHash>
|
||||||
#include <QNetworkReply>
|
#include <QNetworkReply>
|
@ -17,10 +17,10 @@
|
|||||||
|
|
||||||
#include "UpdateChecker.h"
|
#include "UpdateChecker.h"
|
||||||
|
|
||||||
|
#include "NetworkManager.h"
|
||||||
#include "config-keepassx.h"
|
#include "config-keepassx.h"
|
||||||
#include "core/Clock.h"
|
#include "core/Clock.h"
|
||||||
#include "core/Config.h"
|
#include "core/Config.h"
|
||||||
#include "core/NetworkManager.h"
|
|
||||||
|
|
||||||
#include <QJsonArray>
|
#include <QJsonArray>
|
||||||
#include <QJsonDocument>
|
#include <QJsonDocument>
|
@ -90,7 +90,7 @@ macro(add_unit_test)
|
|||||||
endif()
|
endif()
|
||||||
endmacro(add_unit_test)
|
endmacro(add_unit_test)
|
||||||
|
|
||||||
set(TEST_LIBRARIES keepassx_core Qt5::Test)
|
set(TEST_LIBRARIES keepassx_gui Qt5::Test)
|
||||||
|
|
||||||
set(testsupport_SOURCES
|
set(testsupport_SOURCES
|
||||||
modeltest.cpp
|
modeltest.cpp
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
#include "TestUpdateCheck.h"
|
#include "TestUpdateCheck.h"
|
||||||
#include "crypto/Crypto.h"
|
#include "crypto/Crypto.h"
|
||||||
#include "updatecheck/UpdateChecker.h"
|
#include "networking/UpdateChecker.h"
|
||||||
|
|
||||||
#include <QTest>
|
#include <QTest>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user