4.3. Supported command-line parameters#

4.3.1. Generic#

--pretend (or --dry-run or -p)
Operate in a "dry run" mode. No network accesses are made, no log files are created, no projects are built, and no other permanent changes to disk are made. One important exception is that if you try to build a project that comes from the KDE projects, and the repo-metadata hasn't been downloaded yet, the repo-metadata will be downloaded since the pretend-mode output may change significantly based on the repo-metadata results.

Simple read-only commands (such as reading file information) may still be run to make the output more relevant (such as correctly simulating whether source code would be checked out or updated).

--include-dependencies (or -d), --no-include-dependencies (or -D)
This option causes kde-builder to automatically include other KDE and Qt projects (modules) in the build, if required, for the projects you have requested to build on the command line or in your configuration file.

The projects that are added are as recorded within the KDE repo-metadata dependencies. See the section called The official KDE module database.

The corresponding configuration file option is include-dependencies.

This option is enabled by default.

--ignore-projects (or -!) project [project ...]
Do not include the projects passed on the rest of the command line in the update/build process (this is useful if you want to build most of the projects in your configuration file and just skip a few).

Note that this option does not override ignore-projects config option in global section. Instead, it appends it.

--run (or --start-program) [-f|--fork] <program> [parameters ...]
This option interprets the next item on the command line as a program to run, and kde-builder will then finish reading the configuration file, source the prefix.sh to apply environment variables, and then execute the given program.

The "-f", "--fork" option launches the program, and detaches its process from current terminal.

Usage examples:

Launch kate with "-l 5 file1.txt" arguments:

kde-builder --run kate -l 5 file1.txt

Launch kate with "-l 5 file1.txt" arguments, and detach its process from current terminal:

kde-builder --run -f kate -l 5 file1.txt

Launch kate-syntax-highlighter executable (installed by "kate" module) with "--list-themes" argument:

kde-builder --run kate-syntax-highlighter --list-themes

--source-when-start-program <file>
With this option, you can specify a path to shell file, which will be sourced before the project is launched with --run option. For example, you can use it to set QT_LOGGING_RULES and QT_MESSAGE_PATTERN variables, so you could customize the debug output.

--revision <id>
This option causes kde-builder to checkout a specific numbered revision for each project, overriding any branch, tag, or revision options already set for these projects.

This option is likely not a good idea, and is only supported for compatibility with older scripts.

--delete-my-patches, --no-delete-my-patches
This option is used to let kde-builder delete source directories that may contain user data, so that the project can be re-downloaded. This would normally only be useful for KDE developers (who might have local changes that would be deleted).

You should not use this option normally, kde-builder will prompt to be re-run with it if it is needed.

This option must be passed to allow kde-builder to remove conflicting source directories. Currently even this only happens when trying to git clone a project if an existing source directory is present. Never specify this option unless it is suggested by kde-builder, and only if you don't mind the source directories that are referenced being deleted and re-cloned.

--delete-my-settings, --no-delete-my-settings
This option is used to let kde-builder overwrite existing files which may contain user data.

--hold-work-branches, --no-hold-work-branches
This option allows you to skip updating sources for projects that have current branch which name starts with work/* or mr/* (for example, work/your-username/my-awesome-feature).

This simplifies workflow when you want to work on specific project. If you checkout someone's mr (see wiki documentation), the branch will be called something like "mr/80", and kde-builder will behave like if you have specified a "no-src" option for that project in the config.

--all-config-projects
This option is used to select all projects defined in user config for kde-builder to operate on.

--all-kde-projects
This option is used to select all known projects defined in metadata for kde-builder to operate on.

--<option-name> <value>
You can use this option to override an option in your configuration file for every project. For instance, to override the log-dir option, you would do: --log-dir /path/to/dir.

Note

This feature can only be used for option names already recognized by kde-builder, that are not already supported by relevant command line options. For example the async configuration file option has specific --async and --no-async command line options that are preferred by kde-builder.

--set-project-option-value <project-name>,<option-name>,<option-value>
You can use this option to override an option in your configuration file for a specific project.

4.3.2. Resuming and stopping#

--resume-from (or --from or -f) <project>
This option is used to resume the build starting from the given project. You should not specify other project names on the command line.

Note

If you want to avoid source updates when resuming, simply pass --no-src in addition to the other options.

See also: --resume-after and the section called Resuming a failed or canceled build. You would prefer to use this command line option if you have fixed the build error and want kde-builder to complete the build.

--resume-after (or --after or -a) <project>
This option is used to resume the build starting after the given project. You should not specify other project names on the command line.

Note

If you want to avoid source updates when resuming, simply pass --no-src in addition to the other options.

See also: --resume-from and the section called Resuming a failed or canceled build. You would prefer to use this command line option if you have fixed the build error and have also built and installed the project yourself, and want kde-builder to start again with the next project.

--resume
This option can be used to run kde-builder after it has had a build failure.

It resumes the build from the project that failed, using the list of projects that were waiting to be built before, and disables source and metadata updates as well. The use case is when a simple mistake or missing dependency causes the build failure. Once you correct the error you can quickly get back into building the projects you were building before, without fiddling with --resume-from and --stop-before.

--resume-refresh-build-first (or -R)
This option is an alias for using --resume and --refresh-build-first at the same time. It is convenient to use when some project failed to build, and you want to refresh build it, and then continue (re-)building projects after that one, as if it was built successfully in the first place.

--stop-before (or --until) <project>
This option is used to stop the normal build process just before a project would ordinarily be built.

For example, if the normal build list was projectA, projectB, projectC, then --stop-before moduleB would cause kde-builder to only build projectA.

--stop-after (or --to) <project>
This option is used to stop the normal build process just after a project would ordinarily be built.

For example, if the normal build list was projectA, projectB, projectC, then --stop-after moduleB would cause kde-builder to build projectA and projectB.

--stop-on-failure, --no-stop-on-failure
This option controls if the build will be aborted as soon as a failure occurs. Default behavior is --stop-on-failure. You may override it if you wish to still process the rest of the projects in the build, to avoid wasting time in case the problem is with a single project.

See also the stop-on-failure configuration file option.

--rebuild-failures
Use this option to build only those projects which failed to build on a previous kde-builder run. This is useful if a significant number of failures occurred mixed with successful builds. After fixing the issue causing the build failures you can then easily build only the projects that failed previously.

Note

Note that the list of "previously-failed projects" is reset every time a kde-builder run finishes with some project failures. However, it is not reset by a completely successful build, so you can successfully rebuild a project or two and this flag will still work.

4.3.3. Modules information#

--query mode
This command causes kde-builder to query a parameter of the projects in the build list (either passed on the command line or read in from the configuration file), outputting the result to screen (one project per line).

This option must be provided with a "mode", which may be one of the following:

  • source-dir - the full path to where the project's source code is stored.

  • build-dir - the full path to where the project build process occurs.

  • install-dir - the full path to where the project will be installed.

  • project-path - the location of the project within the hierarchy of KDE source code repositories. See the section called The official KDE module database for more information on this hierarchy.

  • branch - the resolved git branch that will be used for each project, based on the tag, branch and branch-group settings in effect.

  • module-set - the name of group which contains the project. This can be used to generate zsh autocompletion cache.

  • build-system - the name of build system detected for the project. This can be used to debug build system auto-detection problems, or when developing tests for specific build systems.

  • project-info - the full project information, including its path, branch, repository, build options, and dependencies.

  • Any option name that is valid for modules in the configuration file.

For example, the command kde-builder --query branch kactivities kdepim might end up with output like:

kactivities: master
kdepim: master

--dependency-tree
Prints the tree of the dependencies, generated from the projects specified in command line. The tree will be recursive, i.e. you could see the dependencies of dependencies. The output format looks similar to the tree utility. In addition, each line will have information if the dependency will be built, and if case it will, also a branch to be used.

If you want to grep in the output, you can use --dependency-tree-fullpath instead.

--dependency-tree-fullpath
Prints the tree of the dependencies, generated from the projects specified in command line. The tree will be recursive, i.e. you could see the dependencies of dependencies. The output format looks similar to the find utility.

It is easier to grep something with this format. However, if you want to visualize the tree, you can use --dependency-tree instead.

--list-installed
Print installed projects and exit. This can be used to generate autocompletion for the --run option.

4.3.4. Exclude specific action#

--no-metadata (or -M)
Skip the metadata update phase. The source updates for the projects themselves will still occur unless you pass --no-src as well.

This can be useful if you are frequently re-running kde-builder since the metadata does not change very often. But note that many other features require the metadata to be available. You might want to consider running kde-builder with the --metadata-only option one time and then using this option for subsequent runs.

--no-src (or -S)
Skips the source update phase. Other phases are included as normal.

--no-build
Skip the build phase for the build. Internally the install phase depends on the build phase completing so this is effectively equivalent to --src-only, but the semantics may change in the future (e.g. when test suites are moved into their own phase).

--no-install
Skip the install phase from the build. Other phases are included as normal.

4.3.5. Only specific action#

--metadata-only
Only perform the metadata download process. kde-builder normally handles this automatically.

--src-only (or -s)
Only perform the source update.

--build-only
Forces the build process to be performed without updating source code first. In addition, installation is not performed. (Testing is still performed if applicable, but this will change in a future release).

--install-only
If this is the only command-line option, it tries to install all the projects contained in log/latest/build-status. If command-line options are specified after this option, they are all assumed to be projects to install (even if they did not successfully build on the last run).

--uninstall Skips the update and build phase and immediately attempts to uninstall the projects given. NOTE: This is only supported for buildsystems that supports the make uninstall command (e.g. KDE CMake-based).

--build-system-only
Interrupts the build process for each project built. The build process consists of normal setup up to and including running cmake or configure (as appropriate), but make is not run and no installation is attempted. This is mostly only useful to get things like configure --help and cmake-gui to work. Normally you want --reconfigure or --refresh-build.
This option causes kde-builder to abort building a project just before the make command would have been run. This is supported for compatibility with older versions only, this effect is not helpful for the current KDE build system.

--install-login-session-only
Can be used to only invoke the session installation script, so you can bypass any project update/build phases. See Installing login session for more information.

4.3.6. Build behavior#

--build-when-unchanged (or --force-build), --no-build-when-unchanged (or --no-force-build)
Enabling this option explicitly disables skipping the build process (an optimization controlled by the build-when-unchanged option). This is useful for making kde-builder run the build when you have changed something that kde-builder cannot check. This option is enabled by default.

--refresh-build (or -r)
Removes the build directory for a project before the build phase starts. This has the desired side effect of forcing kde-builder to re-configure the project and build it from a "pristine" state with no existing temporary or intermediate output files. Use this option if you have problems getting a project to build but realize it will take longer (possibly much longer) for the build to complete as a result. When in doubt use this option for the entire kde-builder run.

--refresh-build-first
Enables the refresh-build option for the first project appeared in final projects list to build. Useful in conjunction with --resume. See also --resume-refresh-build-first.

--reconfigure
Run cmake (for KDE projects) or configure (for non-cmake projects) again, without cleaning the build directory. Usually you actually want --refresh-build, but if you are 100% sure your change to cmake-options will not invalidate your current intermediate output then this can save some time. You should not normally have to specify this, as kde-builder will detect when you change the relevant options and automatically re-run the build setup. This option is implied if --refresh-build is used.

--install-dir path
This allows you to change the directory where projects will be installed to. This option implies --reconfigure, but using --refresh-build may still be required.

--generate-clion-project-config, --no-generate-clion-project-config
Generate a .idea directory with configurations for building and debugging in CLion. This option is disabled by default.

--generate-vscode-project-config, --no-generate-vscode-project-config
Generate a .vscode directory with configurations for building and debugging in Visual Studio Code. This option is disabled by default.

--generate-qtcreator-project-config, --no-generate-qtcreator-project-config
Generate a .qtcreator directory with files that can be used for copying to the Qt Creator configuration for building and debugging. This option is disabled by default.

4.3.7. Script runtime#

--async, --no-async
Enables or disables the asynchronous mode, which can perform the source code updates and project builds at the same time. If disabled, the update will be performed in its entirety before the build starts. Disabling this option will slow down the overall process. If you encounter IPC errors while running kde-builder try disabling it, and submitting a bug report. This option is enabled by default.

--color (or --colorful-output), --no-color (or --no-colorful-output)
Enable or disable colorful output. By default, this option is enabled for interactive terminals.

--debug
Enables DEBUG level for every logger of the kde-builder. See Changing the amount of output from kde-builder.

--nice (or --niceness) <value>
This value adjusts the computer CPU priority requested by kde-builder, and should be in the range of 0-20. 0 is highest priority (because it is the least "nice"), 20 is the lowest priority. This option defaults to 10.

Changes the CPU priority given to kde-builder (and all processes used by kde-builder e.g. make(1)). Value should be an integer number between -20 and 19. Positive values are "nicer" to the rest of the system (i.e. lower priority).

Note that the possible priorities available on your system may be different from listed here, see nice(2) for more information. Note also that this only changes CPU priority, often you want to change I/O priority on systems where that is supported. There is no command-line option for I/O priority adjustment, but there is a configuration file option: use-idle-io-priority (although like all options, there is a generic way to set this from the command line).

--rc-file <file>
Path to the configuration file to use by kde-builder. The default is kde-builder.yaml from current working directory (if exists) or otherwise ~/.config/kde-builder.yaml.

--log-level logger-name=LEVEL
Set the verbosity level of some internal logger. This can be used in order to conveniently debug behavior of kde-builder itself. Name of the logger should be followed by equal sign, and then followed by name of the level. Can be used several times in one command.

Example:

kde-builder wayland --log-level logged-command=INFO --log-level ide_project_configs=DEBUG

Available logger names can be seen in the data/kde-builder-logging.yaml file. Level names can be one of "ERROR", "WARNING", "INFO", "DEBUG". See also Project loggers.

4.3.8. Setup#

--initial-setup
Has kde-builder perform the one-time initial setup necessary to prepare the system for kde-builder to operate, and for the newly-installed KDE software to run.

This includes:

  • Installing known dependencies (on supported Linux distributions)

  • Generating kde-builder.yaml config

This option is exactly equivalent to using --install-distro-packages and --generate-config at the same time.

--install-distro-packages
Installs distro packages (on supported Linux distributions) necessary to prepare the system for kde-builder to operate, and for the newly-installed KDE software to run.

See also --initial-setup

--generate-config
Generate the kde-builder configuration file.

See also --initial-setup

--prompt-answer <value>
Prevent the interactive prompts, and use the value as the prompt answer. Such prompts can be seen in install-distro-packages step.

4.3.9. Script information#

--version (or -v)
Display the program version.

--help (or -h)
Only display simple help on this script.

--show-info
Displays information about kde-builder and the operating system, that may prove useful in bug reports or when asking for help in forums or mailing lists.

--show-options-specifiers
Print the specifier lines (in the format that GetOpts::Long accepts) for all command line options supported by the script. This may be used by developers, for example, for generating zsh autocompletion functions.