summaryrefslogtreecommitdiff
path: root/doc/src/projects/creator-projects-qbs.qdoc
blob: b67f9f2bf43ee02b7fbe790d8e564a5d8af23873 (plain)
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
/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the Qt Creator documentation.
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU Free Documentation License Usage
** Alternatively, this file may be used under the terms of the GNU Free
** Documentation License version 1.3 as published by the Free Software
** Foundation and appearing in the file included in the packaging of
** this file. Please review the following information to ensure
** the GNU Free Documentation License version 1.3 requirements
** will be met: https://www.gnu.org/licenses/fdl-1.3.html.
**
****************************************************************************/

/*!
    \contentspage {Qt Creator Manual}
    \previouspage creator-project-cmake.html
    \page creator-project-qbs.html
    \nextpage creator-projects-autotools.html

    \title Setting Up a Qbs Project

    To use Qbs to build a project, you must create a .qbs file for the project.
    You can use \QC to create a C or C++ project that is built with Qbs.
    For more information about Qbs, see
    the \l{http://doc.qt.io/qbs/index.html}{Qbs Manual}.

    The application is built using the default Qbs profile that is associated
    with the build and run kit. \QC automatically creates a Qbs profile for each
    kit. You can edit the build profiles by adding new keys and values.

    To check which Qbs version is being used, select \uicontrol Tools >
    \uicontrol Options > \uicontrol Qbs > \uicontrol {Version Info}.

    \section1 Building Qbs

    If you build \QC yourself from the \QC Git repository, you also need to
    fetch the Qbs submodule to get Qbs support:

    \list 1

        \li Fetch the Qbs submodule in your \QC git checkout with
            \c {git submodule update --init}.

        \li Run qmake on \QC and build \QC again.

    \endlist

    \section1 Building Applications with Qbs

    To build your application with Qbs:

    \list 1

        \li Select \uicontrol File > \uicontrol {New File or Project} >
            \uicontrol {Non-Qt Project} > \uicontrol {Plain C Project} or
            \uicontrol {Plain C++ Project} > \uicontrol Choose.

        \li In the \uicontrol {Project Location} dialog, specify the name and
            location for the project and select \uicontrol Next.

        \li In the \uicontrol {Define Build System} dialog, select
            \uicontrol Qbs in the \uicontrol {Build system} field, and then
            select \uicontrol Next.

        \li In the \uicontrol {Kit Selection} dialog, select a build and run kit
            for the project, and then select \uicontrol Next.

        \li In the \uicontrol {Project Management} dialog, select
            \uicontrol Finish to create a Qbs project.

            \image creator-qbs-project.png

        \li Edit the .qbs file for you project. Usually, you must add the
            \c Depends item for a Qt application. For examples, see the
            \c {examples} directory in the qbs repository.

        \li Select \uicontrol Projects to specify \uicontrol {Build Settings} for the
            project.

        \li Select \uicontrol {Build Steps} > \uicontrol Details to specify build steps:

            \image creator-qbs-build-app.png

            \list 1

                \li In the \uicontrol {Build variant} field, select \uicontrol Debug to
                    include debug symbols in the build for debugging the
                    application and \uicontrol Release to create the final
                    installation file.

                \li In the \uicontrol {Parallel jobs} field, specify the number of
                    parallel jobs to use for building.

                \li Select the \uicontrol {Enable QML debugging} check box to debug
                    Qt Quick application projects.

                    \note Debugging requires opening a socket at a well-known
                    port, which presents a security risk. Anyone on the Internet
                    could connect to the application that you are debugging and
                    execute any JavaScript functions. Therefore, you must make
                    sure that the port is properly protected by a firewall.

                \li In the \uicontrol Properties field, specify the properties to pass
                    to the project. Use colons (:) to separate keys from values.
                    For more information, see
                    \l{http://doc.qt.io/qbs/language-introduction.html}
                    {Modules} in the Qbs Manual.

                \li In the \uicontrol Flags field:

                    \list

                        \li Select \uicontrol {Keep going} to continue building when
                            errors occur, if possible.

                        \li Select \uicontrol {Show command lines} to print actual command lines
                            to the compile output pane instead of high-level descriptions.

                        \li Select \uicontrol {Install} to copy artifacts to their install location
                            after building them. This option is enabled by default.

                        \li Select \uicontrol {Clean install root} to remove the contents of
                            the install root directory before the build starts.

                    \endlist

            \endlist

            The \uicontrol {Equivalent command line} field displays the build command
            that is constructed based on the selected options.

        \li Select \uicontrol {Clean Steps} > \uicontrol Details to specify flags for the
            cleaning step.

            \image creator-qbs-build-clean.png

            \list

                \li Select \uicontrol {Dry run} to test cleaning without executing
                    commands or making permanent changes to the build graph.

                \li Select \uicontrol {Keep going} to continue cleaning when errors
                    occur, if possible.

            \endlist

            The \uicontrol {Equivalent command line} field displays the clean command
            that is constructed based on the selected options.

        \li Select \uicontrol Build > \uicontrol {Build Project} to build the application.

        \li Click the
            \inlineimage run_small.png
            (\uicontrol Run) button to deploy and run the application.
        \endlist

    \section1 Editing Build Profiles

    \image qtcreator-options-qbs.png

    You can modify a build profile that is associated with a build and run kit
    by editing the values of the keys generated by \QC and by adding new values:

    \list 1

        \li Select \uicontrol Tools > \uicontrol Options > \uicontrol Qbs.

        \li By default, Qbs profiles are stored in the \c qbs directory in the
            \QC settings directory to ensure that different \QC instances do not
            overwrite each other's profiles. If you only run one \QC instance,
            you can store the profiles in the Qbs settings directory instead,
            by deselecting the \uicontrol {Store profiles in Qt Creator settings
            directory} check box.

        \li In the \uicontrol Kit field, select a build and run kit.

        \li Select \uicontrol Edit to edit the profile associated with the kit.

        \li Select \uicontrol Add to add keys and values to the profile or to
            modify existing values.

        \li In the \uicontrol Key column, spefify the key to add or modify as:
            \c <module_name>.<property_name>.

        \li In the \uicontrol Value column, specify a value as a JSON literal.

        \li Click \uicontrol OK.

    \endlist

    The values that you have modified are displayed in red in the
    \uicontrol {Profile properties} field.

    For a list of available keys and values, see the
    \l{http://doc.qt.io/qbs/list-of-modules.html}{List of Modules} in the
    Qbs Manual.
*/