-
Notifications
You must be signed in to change notification settings - Fork 7
/
CMakeLists.txt
215 lines (181 loc) · 8.8 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
# ################# CMake boilerplate ##############################################################
# Do not allow in-source builds.
if("${CMAKE_SOURCE_DIR}" STREQUAL "${CMAKE_BINARY_DIR}")
message(FATAL_ERROR "This application requires an out-of-source build. Please create a separate build directory and run 'cmake path_to_kirigami [options]' there.")
endif()
# ################# Project configuration #############################################################
# The CMake files of this project require only CMake ≥3.0. However, for the Android build, ECM ≥5.75.0
# is needed (see below), which in turn needs CMake ≥3.18. This dependency is not yet declared in ECM
# (see https://bugs.kde.org/show_bug.cgi?id=424392#c2 ). Until that is done, we record this
# transitive dependency here.
# The CMake version dependency is required up here, before any usage of affected language features.
if(CMAKE_SYSTEM_NAME STREQUAL "Android")
cmake_minimum_required(VERSION 3.18)
else()
cmake_minimum_required(VERSION 3.0)
endif()
# Project name and version. Also enables "C++" language.
project(foodrescue-app LANGUAGES CXX VERSION 0.3)
# TODO: What's this?
include(FeatureSummary)
feature_summary(
WHAT ALL
INCLUDE_QUIET_PACKAGES
FATAL_ON_MISSING_REQUIRED_PACKAGES
)
# Set the minimum required Qt version.
# Application depends on the Qt required by "the Kirigami found in Ubuntu 20.04 LTS", which is
# 5.12.0. Supplying a higher version is fine; Ubuntu 20.04 LTS comes with Qt 5.12.5 for example.
#
# See README.md for the reasoning and source.
set(REQUIRED_QT_VERSION 5.12.0)
# Application depends on KDE Framework version found in Ubuntu 20.04 LTS.
# See README.md for the reasoning and source.
set(KF5_DEP_VERSION 5.68.0)
# If building for Android and Breeze icons are installed under ./lib/breeze-icons/, set the path.
# If not installed, the build process will do a git clone to "breeze-icons" in the build
# directory.
#
# For documentation of the technique here and instructions to make a local change for your
# system only, see https://stackoverflow.com/a/62202304
#
# TODO: Later we want to use the breeze icons provided by the Ubuntu package under
# /usr/share/icons/breeze. However, the folder structure there is different than what
# _find_breeze_icon() expects. Once that is fixed, the code below should first look for the
# Ubuntu package and only afterwards for ./lib/breeze-icons. For the code to fix, see:
# https://invent.kde.org/frameworks/kirigami/-/blob/f47bf90/KF5Kirigami2Macros.cmake#L17
get_filename_component(
PROJECT_BREEZEICONS_DIR # Target variable to set.
"lib/breeze-icons" # Path relative to the project's source (!!) directory.
REALPATH # Convert to an absolute path and resolve any symlinks.
)
if(CMAKE_SYSTEM_NAME STREQUAL "Android" AND IS_DIRECTORY "${PROJECT_BREEZEICONS_DIR}")
list(APPEND BREEZEICONS_DIR "${PROJECT_BREEZEICONS_DIR}")
# To prevent adding duplicates at each run of CMake, remove the duplicates again.
list(REMOVE_DUPLICATES BREEZEICONS_DIR)
# The variable is cached in ${BUILD_DIR}/CMakeCache.txt. We need FORCE to change it there
# immediately. Also, add a comment to the cache file.
set(BREEZEICONS_DIR ${BREEZEICONS_DIR}
CACHE STRING "Path to the KDE Breeze icon set, for the Kirigami's Android packaging scripts"
FORCE
)
endif()
# Directories where Qt Creator can find QML files of Kirigami etc..
#
# Needed to make Qt Creator code completion happy. Not needed for builds to succeed.
# QML_IMPORT_PATH is ignored by the build process and only used by Qt Creator. See:
# https://bugreports.qt.io/browse/QTBUG-55259 . So there is no need to adapt it by target
# platform, just to give Qt Creator one set of directories to resolve QML imports.
#
# For documentation of the technique here and instructions to make a local change for your
# system only, see https://stackoverflow.com/a/62202304
#
# Kirigami QML path for Ubuntu systems.
list(APPEND QML_IMPORT_PATH "/usr/lib/x86_64-linux-gnu/qt5/qml")
# To prevent adding duplicates at each run of CMake, remove the duplicates again.
list(REMOVE_DUPLICATES QML_IMPORT_PATH)
# The variable is cached in ${BUILD_DIR}/CMakeCache.txt. We need FORCE to change it there
# immediately. Also, add a comment to the cache file.
set(QML_IMPORT_PATH ${QML_IMPORT_PATH}
CACHE STRING "Qt Creator 4.1 extra QML import paths"
FORCE
)
# Enable Qt MOC (Meta Object Compiler) pre-processor to run on C++ source files when needed.
set(CMAKE_AUTOMOC ON)
set(AUTOMOC_MOC_OPTIONS "-Muri=org.kde.kirigami")
# Set compilation flags.
add_definitions(
# Needed for linking with the ZXing library starting from a certain commit between
# 1.0.7 and 1.0.8. Because ZXing code throws exceptions.
-fexceptions
# Catches and prevents implicit conversions of filenames to URLs, making it easy to write own
# code for proper conversions (for example to file:// URLs). See documentation at:
# https://doc.qt.io/qt-5/qurl.html#QT_NO_URL_CAST_FROM_STRING
-DQT_NO_URL_CAST_FROM_STRING
)
# Enable C++11 features in clang and gcc.
# Note that ZXing-C++ uses C++14 internally resp. C++17 for versions newer than 1.1.1, but its
# linker interface is C++11. See: https://github.com/nu-book/zxing-cpp/blob/96b6a83/core/CMakeLists.txt#L465
set(CMAKE_CXX_STANDARD 11)
# ################# CMake module includes ##########################################################
# include()s have to be up here because the new CMake functionality can only be used afterwards.
# Make CPack available to easily generate binary packages.
include(CPack)
# Include KDE-related CMake modules (ECM = Extended CMake Modules).
# Under Android, we need a newer version due to a build issue in ZXing-C++. For details, see:
# https://github.com/fairdirect/foodrescue-app#52-linux-development-setup
if(CMAKE_SYSTEM_NAME STREQUAL "Android")
set(REQUIRED_ECM_VERSION 5.75.0)
else()
set(REQUIRED_ECM_VERSION 5.68.0)
endif()
find_package(ECM ${REQUIRED_ECM_VERSION} REQUIRED NO_MODULE)
set_package_properties(
ECM PROPERTIES
TYPE REQUIRED
DESCRIPTION "Extra CMake Modules."
URL "https://projects.kde.org/projects/kdesupport/extra-cmake-modules"
)
# Where to look for modules before ${CMAKE_ROOT}/Modules/.
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${ECM_MODULE_PATH})
# Include specific ECM modules.
include(KDEInstallDirs)
include(KDECMakeSettings)
include(KDECompilerSettings NO_POLICY_SCOPE)
include(ECMSetupVersion)
include(ECMGenerateHeaders)
include(ECMPoQmTools)
include(ECMQMLModules)
# ################# Application dependencies (CMake packages, QML modules) #########################
# Find the Qt installation.
find_package(
Qt5 ${REQUIRED_QT_VERSION}
REQUIRED
NO_MODULE
COMPONENTS # To know the available component names: https://stackoverflow.com/a/62676473
Concurrent # For Kirigami.
Core # Could also be omitted as it's a dependency of the other components.
Gui
Multimedia # For the barcode scanner.
Qml
Quick # For the barcode scanner.
QuickControls2
Sql
Svg
Xml # For XML debug output in formatXml(). TODO: Avoid in non-debug builds.
XmlPatterns # For XSLT conversion of database content for rendering.
)
# Require the package providing library Qt5::AndroidExtras, as needed in src/CMakeLists.txt.
if(CMAKE_SYSTEM_NAME STREQUAL "Android")
find_package(Qt5AndroidExtras ${REQUIRED_QT_VERSION} REQUIRED)
endif()
# Find Kirigami and other relevant KDE components.
find_package(KF5Kirigami2 REQUIRED)
# find_package(KF5I18n) # TODO: Add when starting to use i18n.
# Find ZXing C++ (a C++ reimplementation of popular barcode scanner library ZXing).
# Source repo: https://github.com/nu-book/zxing-cpp.
#
# Current ZXing version requirements: minimum version zxing-cpp commit 96b6a83 (which is 1.1.1
# plus some commits). Version 1.1.1 or even earlier may also work, but this is untested.
find_package(ZXing 1.1.1 REQUIRED)
# Include specific QML modules. (Example; enable when needed.)
# ecm_find_qmlmodule(QtGraphicalEffects 1.0)
# ################# Compilation and installation ###################################################
# Build and install the executable from the source tree, as instructed in src/CMakeLists.txt.
add_subdirectory(src)
# Install the FreeDesktop application metadata file.
install(
FILES metadata-freedesktop.desktop
DESTINATION ${KDE_INSTALL_APPDIR}
RENAME org.fairdirect.foodrescue.desktop
)
# Install the KDE AppStream application metadata file.
install(
FILES metadata-kde.xml
DESTINATION ${KDE_INSTALL_METAINFODIR}
RENAME org.fairdirect.foodrescue.appdata.xml
)
# TODO: What's this for? Something from KDE i18n?
if (IS_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/po")
ecm_install_po_files_as_qm(po)
endif()