Crates.io | ognibuild |
lib.rs | ognibuild |
version | |
source | src |
created_at | 2023-05-23 18:25:32.742083 |
updated_at | 2024-11-28 00:39:20.782496 |
description | Detect and run any build system |
homepage | https://github.com/jelmer/ognibuild |
repository | https://github.com/jelmer/ognibuild.git |
max_upload_size | |
id | 872213 |
Cargo.toml error: | TOML parse error at line 18, column 1 | 18 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include` |
size | 0 |
Ognibuild is a simple wrapper with a common interface for invoking any kind of build tool.
The ideas is that it can be run to build and install any source code directory by detecting the build system that is in use and invoking that with the correct parameters.
It can also detect and install missing dependencies.
The goal of ognibuild is to provide a consistent CLI that can be used for any software package. It is mostly useful for automated building of large sets of diverse packages (e.g. different programming languages).
It is not meant to expose all functionality that is present in the underlying build systems. To use that, invoke those build systems directly.
Ognibuild has a number of subcommands:
ogni clean
- remove any built artifactsogni dist
- create a source tarballogni build
- build the package in-treeogni install
- install the packageogni test
- run the testsuite in the source directoryIt also includes a subcommand that can fix up the build dependencies for Debian packages, called deb-fix-build.
ogni -d https://gitlab.gnome.org/GNOME/fractal install
Ognibuild is functional, but sometimes rough around the edges. If you run into issues (or lack of support for a particular ecosystem), please file a bug.
Package repositories are used to install missing dependencies.
The following "native" repositories are supported:
As well one distribution repository:
Ognibuild is licensed under the GNU GPL, v2 or later.