summaryrefslogtreecommitdiffstats
path: root/meta-boot2qt/classes
diff options
context:
space:
mode:
authorSamuli Piippo <samuli.piippo@qt.io>2018-09-06 16:25:44 +0300
committerSamuli Piippo <samuli.piippo@qt.io>2018-09-10 06:32:47 +0000
commit8f8722d36a1341c08c86c4357da8f398cc31e771 (patch)
treea272cc6ee5a4ba18b44961d768cfc09798555391 /meta-boot2qt/classes
parent0d81ebc4f4f6d1fe0b6103860a37eacf62ffa589 (diff)
downloadmeta-boot2qt-8f8722d36a1341c08c86c4357da8f398cc31e771.tar.gz
qt5: support feature files generated by Qt Configuration Tool
Qt Configuration Tool can be used to generate feature files for each Qt module, which contain enabled and disabled feature flags. This bbclass can be used to enable bitbake to use those files to configure Qt modules more thoroughly. These options will override any PACKAGECONFIG options that might conflict. Use by inheriting the qt5-features in a qt module recipe (using bbappend), which you want to configure. By default the bbclass expects the feature files to be named according to the Qt modules names (QtBase -> qtbase.opt) and placed in a 'features' subfolder next to the recipes. Task-number: QTBUG-68950 Change-Id: Ie580512346a5eb09cd65afc7474b5a88f1416a56 Reviewed-by: Kari Oikarinen <kari.oikarinen@qt.io>
Diffstat (limited to 'meta-boot2qt/classes')
-rw-r--r--meta-boot2qt/classes/qt5-features.bbclass40
1 files changed, 40 insertions, 0 deletions
diff --git a/meta-boot2qt/classes/qt5-features.bbclass b/meta-boot2qt/classes/qt5-features.bbclass
new file mode 100644
index 0000000..89b3ee6
--- /dev/null
+++ b/meta-boot2qt/classes/qt5-features.bbclass
@@ -0,0 +1,40 @@
1############################################################################
2##
3## Copyright (C) 2018 The Qt Company Ltd.
4## Contact: https://www.qt.io/licensing/
5##
6## This file is part of the Boot to Qt meta layer.
7##
8## $QT_BEGIN_LICENSE:GPL$
9## Commercial License Usage
10## Licensees holding valid commercial Qt licenses may use this file in
11## accordance with the commercial license agreement provided with the
12## Software or, alternatively, in accordance with the terms contained in
13## a written agreement between you and The Qt Company. For licensing terms
14## and conditions see https://www.qt.io/terms-conditions. For further
15## information use the contact form at https://www.qt.io/contact-us.
16##
17## GNU General Public License Usage
18## Alternatively, this file may be used under the terms of the GNU
19## General Public License version 3 or (at your option) any later version
20## approved by the KDE Free Qt Foundation. The licenses are as published by
21## the Free Software Foundation and appearing in the file LICENSE.GPL3
22## included in the packaging of this file. Please review the following
23## information to ensure the GNU General Public License requirements will
24## be met: https://www.gnu.org/licenses/gpl-3.0.html.
25##
26## $QT_END_LICENSE$
27##
28############################################################################
29
30FEATURES := "${THISDIR}/features/${QT_MODULE}.opt"
31do_configure[file-checksums] += "${FEATURES}:True"
32
33def qt_features(d):
34 featurefile = d.getVar('FEATURES', True)
35 with open(featurefile, 'r') as f:
36 features = f.read().replace('\n', ' ')
37 return features
38
39QT_CONFIG_FLAGS_append_class-target = " ${@qt_features(d)}"
40EXTRA_QMAKEVARS_CONFIGURE_append_class-target = " ${@qt_features(d)}"