forked from lix-project/lix
Merge changes Ia3e7b1e6,If09be814 into main
* changes: meson: flip the switch!! meson: fix cross compilation
This commit is contained in:
commit
be4a3168c9
5 changed files with 203 additions and 162 deletions
|
@ -1,61 +1,125 @@
|
||||||
# Hacking
|
# Hacking
|
||||||
|
|
||||||
This section provides some notes on how to hack on Nix. To get the
|
This section provides some notes on how to hack on Nix. To get the latest version of Lix from Forgejo:
|
||||||
latest version of Nix from GitHub:
|
|
||||||
|
|
||||||
```console
|
```console
|
||||||
$ git clone https://github.com/NixOS/nix.git
|
$ git clone https://git.lix.systems/lix-project/lix
|
||||||
$ cd nix
|
$ cd lix
|
||||||
```
|
```
|
||||||
|
|
||||||
The following instructions assume you already have some version of Nix installed locally, so that you can use it to set up the development environment. If you don't have it installed, follow the [installation instructions].
|
The following instructions assume you already have some version of Nix or Lix installed locally, so that you can use it to set up the development environment. If you don't have it installed, follow the [installation instructions].
|
||||||
|
|
||||||
[installation instructions]: ../installation/installation.md
|
[installation instructions]: ../installation/installation.md
|
||||||
|
|
||||||
## Building Nix with flakes
|
## Building Lix in a development shell
|
||||||
|
|
||||||
This section assumes you are using Nix with the [`flakes`] and [`nix-command`] experimental features enabled.
|
### Setting up the development shell
|
||||||
See the [Building Nix](#building-nix) section for equivalent instructions using stable Nix interfaces.
|
|
||||||
|
If you are using Lix or Nix with the [`flakes`] and [`nix-command`] experimental features enabled, the following command will build all dependencies and start a shell in which all environment variables are setup for those dependencies to be found:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ nix develop
|
||||||
|
```
|
||||||
|
|
||||||
|
That will use the default stdenv for your system. To get a shell with one of the other [supported compilation environments](#compilation-environments), specify its attribute name after a hash (which you may need to quote, depending on your shell):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ nix develop ".#native-clangStdenvPackages"
|
||||||
|
```
|
||||||
|
|
||||||
|
For classic Nix, use:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ nix-shell -A native-clangStdenvPackages
|
||||||
|
```
|
||||||
|
|
||||||
[`flakes`]: @docroot@/contributing/experimental-features.md#xp-feature-flakes
|
[`flakes`]: @docroot@/contributing/experimental-features.md#xp-feature-flakes
|
||||||
[`nix-command`]: @docroot@/contributing/experimental-features.md#xp-nix-command
|
[`nix-command`]: @docroot@/contributing/experimental-features.md#xp-nix-command
|
||||||
|
|
||||||
To build all dependencies and start a shell in which all environment variables are set up so that those dependencies can be found:
|
|
||||||
|
|
||||||
```console
|
### Building from the development shell
|
||||||
$ nix develop
|
|
||||||
|
As always you may run [stdenv's phases by name](https://nixos.org/manual/nixpkgs/unstable/#sec-building-stdenv-package-in-nix-shell), e.g.:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ configurePhase
|
||||||
|
$ buildPhase
|
||||||
|
$ checkPhase
|
||||||
|
$ installPhase
|
||||||
|
$ installCheckPhase
|
||||||
```
|
```
|
||||||
|
|
||||||
This shell also adds `./outputs/bin/nix` to your `$PATH` so you can run `nix` immediately after building it.
|
To build manually, however, use the following:
|
||||||
|
|
||||||
To get a shell with one of the other [supported compilation environments](#compilation-environments):
|
```bash
|
||||||
|
$ meson setup ./build "--prefix=$out" $mesonFlags
|
||||||
```console
|
|
||||||
$ nix develop .#native-clangStdenvPackages
|
|
||||||
```
|
```
|
||||||
|
|
||||||
> **Note**
|
(A simple `meson setup ./build` will also build, but will do a different thing, not having the settings from package.nix applied).
|
||||||
>
|
|
||||||
> Use `ccacheStdenv` to drastically improve rebuild time.
|
|
||||||
> By default, [ccache](https://ccache.dev) keeps artifacts in `~/.cache/ccache/`.
|
|
||||||
|
|
||||||
To build Nix itself in this shell:
|
```bash
|
||||||
|
$ meson compile -C build
|
||||||
```console
|
$ meson test -C build --suite=check
|
||||||
[nix-shell]$ autoreconfPhase
|
$ meson install -C build
|
||||||
[nix-shell]$ configurePhase
|
$ meson test -C build --suite=installcheck
|
||||||
[nix-shell]$ make -j $NIX_BUILD_CORES
|
|
||||||
```
|
```
|
||||||
|
|
||||||
To install it in `$(pwd)/outputs` and test it:
|
(Check and installcheck may both be done after install, allowing you to omit the --suite argument entirely, but this is the order package.nix runs them in.)
|
||||||
|
|
||||||
```console
|
This will install Lix to `$PWD/outputs`, the `/bin` of which is prepended to PATH in the development shells.
|
||||||
[nix-shell]$ make install
|
|
||||||
[nix-shell]$ make installcheck -j $NIX_BUILD_CORES
|
If the tests fail and Meson helpfully has no output for why, use the `--print-error-logs` option to `meson test`.
|
||||||
[nix-shell]$ nix --version
|
|
||||||
nix (Nix) 2.12
|
If you change a setting in the buildsystem (i.e., any of the `meson.build` files), most cases will automatically regenerate the Meson configuration just before compiling.
|
||||||
|
Some cases, however, like trying to build a specific target whose name is new to the buildsystem (e.g. `meson compile -C build src/libmelt/libmelt.dylib`, when `libmelt.dylib` did not exist as a target the last time the buildsystem was generated), then you can reconfigure using new settings but existing options, and only recompiling stuff affected by the changes:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ meson setup --reconfigure build
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Note that changes to the default values in `meson.options` or in the `default_options :` argument to `project()` are **not** propagated with `--reconfigure`.
|
||||||
|
|
||||||
|
If you want a totally clean build, you can use:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ meson setup --wipe build
|
||||||
|
```
|
||||||
|
|
||||||
|
That will work regardless of if `./build` exists or not.
|
||||||
|
|
||||||
|
Specific, named targets may be addressed in `meson build -C build <target>`, with the "target ID", if there is one, which is the first string argument passed to target functions that have one, and unrelated to the variable name, e.g.:
|
||||||
|
|
||||||
|
```meson
|
||||||
|
libexpr_dylib = library('nixexpr', …)
|
||||||
|
```
|
||||||
|
|
||||||
|
can be addressed with:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ meson compile -C build nixexpr
|
||||||
|
```
|
||||||
|
|
||||||
|
All targets may be addressed as their output, relative to the build directory, e.g.:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ meson compile -C build src/libexpr/libnixexpr.so
|
||||||
|
```
|
||||||
|
|
||||||
|
But Meson does not consider intermediate files like object files targets.
|
||||||
|
To build a specific object file, use Ninja directly and specify the output file relative to the build directory:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ ninja -C build src/libexpr/libnixexpr.so.p/nixexpr.cc.o
|
||||||
|
```
|
||||||
|
|
||||||
|
To inspect the canonical source of truth on what the state of the buildsystem configuration is, use:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ meson introspect
|
||||||
|
```
|
||||||
|
|
||||||
|
## Building Lix outside of development shells
|
||||||
|
|
||||||
To build a release version of Nix for the current operating system and CPU architecture:
|
To build a release version of Nix for the current operating system and CPU architecture:
|
||||||
|
|
||||||
```console
|
```console
|
||||||
|
@ -64,50 +128,11 @@ $ nix build
|
||||||
|
|
||||||
You can also build Nix for one of the [supported platforms](#platforms).
|
You can also build Nix for one of the [supported platforms](#platforms).
|
||||||
|
|
||||||
## Building Nix
|
|
||||||
|
|
||||||
To build all dependencies and start a shell in which all environment variables are set up so that those dependencies can be found:
|
|
||||||
|
|
||||||
```console
|
|
||||||
$ nix-shell
|
|
||||||
```
|
|
||||||
|
|
||||||
To get a shell with one of the other [supported compilation environments](#compilation-environments):
|
|
||||||
|
|
||||||
```console
|
|
||||||
$ nix-shell --attr devShells.x86_64-linux.native-clangStdenvPackages
|
|
||||||
```
|
|
||||||
|
|
||||||
> **Note**
|
> **Note**
|
||||||
>
|
>
|
||||||
> You can use `native-ccacheStdenvPackages` to drastically improve rebuild time.
|
> You can use `native-ccacheStdenvPackages` to drastically improve rebuild time.
|
||||||
> By default, [ccache](https://ccache.dev) keeps artifacts in `~/.cache/ccache/`.
|
> By default, [ccache](https://ccache.dev) keeps artifacts in `~/.cache/ccache/`.
|
||||||
|
|
||||||
To build Nix itself in this shell:
|
|
||||||
|
|
||||||
```console
|
|
||||||
[nix-shell]$ autoreconfPhase
|
|
||||||
[nix-shell]$ ./configure $configureFlags --prefix=$(pwd)/outputs/out
|
|
||||||
[nix-shell]$ make -j $NIX_BUILD_CORES
|
|
||||||
```
|
|
||||||
|
|
||||||
To install it in `$(pwd)/outputs` and test it:
|
|
||||||
|
|
||||||
```console
|
|
||||||
[nix-shell]$ make install
|
|
||||||
[nix-shell]$ make installcheck -j $NIX_BUILD_CORES
|
|
||||||
[nix-shell]$ ./outputs/out/bin/nix --version
|
|
||||||
nix (Nix) 2.12
|
|
||||||
```
|
|
||||||
|
|
||||||
To build a release version of Nix for the current operating system and CPU architecture:
|
|
||||||
|
|
||||||
```console
|
|
||||||
$ nix-build
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also build Nix for one of the [supported platforms](#platforms).
|
|
||||||
|
|
||||||
## Platforms
|
## Platforms
|
||||||
|
|
||||||
Nix can be built for various platforms, as specified in [`flake.nix`]:
|
Nix can be built for various platforms, as specified in [`flake.nix`]:
|
||||||
|
@ -148,55 +173,38 @@ Add more [system types](#system-type) to `crossSystems` in `flake.nix` to bootst
|
||||||
|
|
||||||
### Building for multiple platforms at once
|
### Building for multiple platforms at once
|
||||||
|
|
||||||
It is useful to perform multiple cross and native builds on the same source tree,
|
It is useful to perform multiple cross and native builds on the same source tree, for example to ensure that better support for one platform doesn't break the build for another.
|
||||||
for example to ensure that better support for one platform doesn't break the build for another.
|
As Lix now uses Meson, out-of-tree builds are supported first class. In the invocation
|
||||||
In order to facilitate this, Nix has some support for being built out of tree – that is, placing build artefacts in a different directory than the source code:
|
|
||||||
|
|
||||||
1. Create a directory for the build, e.g.
|
```bash
|
||||||
|
$ meson setup build
|
||||||
|
```
|
||||||
|
|
||||||
```bash
|
the argument after `setup` specifies the directory for this build, conventionally simply called "build", but it may be called anything, and you may run `meson setup <somedir>` for as many different directories as you want.
|
||||||
mkdir build
|
To compile the configuration for a given build directory, pass that build directory to the `-C` argument of `meson compile`:
|
||||||
```
|
|
||||||
|
|
||||||
2. Run the configure script from that directory, e.g.
|
```bash
|
||||||
|
$ meson setup some-custom-build
|
||||||
```bash
|
$ meson compile -C some-custom-build
|
||||||
cd build
|
```
|
||||||
../configure <configure flags>
|
|
||||||
```
|
|
||||||
|
|
||||||
3. Run make from the source directory, but with the build directory specified, e.g.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
make builddir=build <make flags>
|
|
||||||
```
|
|
||||||
|
|
||||||
## System type
|
## System type
|
||||||
|
|
||||||
Nix uses a string with he following format to identify the *system type* or *platform* it runs on:
|
Lix uses a string with the following format to identify the *system type* or *platform* it runs on:
|
||||||
|
|
||||||
```
|
```
|
||||||
<cpu>-<os>[-<abi>]
|
<cpu>-<os>[-<abi>]
|
||||||
```
|
```
|
||||||
|
|
||||||
It is set when Nix is compiled for the given system, and based on the output of [`config.guess`](https://github.com/nixos/nix/blob/master/config/config.guess) ([upstream](https://git.savannah.gnu.org/cgit/config.git/tree/config.guess)):
|
It is set when Nix is compiled for the given system, and determined by [Meson's `host_machine.cpu_family()` and `host_machine.system()` values](https://mesonbuild.com/Reference-manual_builtin_host_machine.html).
|
||||||
|
|
||||||
```
|
For historic reasons and backward-compatibility, some CPU and OS identifiers are translated from the GNU Autotools naming convention in [`meson.build`](https://git.lix.systems/lix-project/lix/blob/main/meson.build) as follows:
|
||||||
<cpu>-<vendor>-<os>[<version>][-<abi>]
|
|
||||||
```
|
|
||||||
|
|
||||||
When Nix is built such that `./configure` is passed any of the `--host`, `--build`, `--target` options, the value is based on the output of [`config.sub`](https://github.com/nixos/nix/blob/master/config/config.sub) ([upstream](https://git.savannah.gnu.org/cgit/config.git/tree/config.sub)):
|
| `host_machine.cpu_family()` | Nix |
|
||||||
|
|
||||||
```
|
|
||||||
<cpu>-<vendor>[-<kernel>]-<os>
|
|
||||||
```
|
|
||||||
|
|
||||||
For historic reasons and backward-compatibility, some CPU and OS identifiers are translated from the GNU Autotools naming convention in [`configure.ac`](https://github.com/nixos/nix/blob/master/configure.ac) as follows:
|
|
||||||
|
|
||||||
| `config.guess` | Nix |
|
|
||||||
|----------------------------|---------------------|
|
|----------------------------|---------------------|
|
||||||
| `amd64` | `x86_64` |
|
| `x86` | `i686` |
|
||||||
| `i*86` | `i686` |
|
| `i686` | `i686` |
|
||||||
|
| `i686` | `i686` |
|
||||||
| `arm6` | `arm6l` |
|
| `arm6` | `arm6l` |
|
||||||
| `arm7` | `arm7l` |
|
| `arm7` | `arm7l` |
|
||||||
| `linux-gnu*` | `linux` |
|
| `linux-gnu*` | `linux` |
|
||||||
|
@ -229,13 +237,14 @@ You can use any of the other supported environments in place of `nix-ccacheStden
|
||||||
|
|
||||||
## Editor integration
|
## Editor integration
|
||||||
|
|
||||||
The `clangd` LSP server is installed by default on the `clang`-based `devShell`s.
|
The `clangd` LSP server is installed by default in each development shell.
|
||||||
See [supported compilation environments](#compilation-environments) and instructions how to set up a shell [with flakes](#nix-with-flakes) or in [classic Nix](#classic-nix).
|
See [supported compilation environments](#compilation-environments) and instructions how to set up a shell [with flakes](#nix-with-flakes) or in [classic Nix](#classic-nix).
|
||||||
|
|
||||||
To use the LSP with your editor, you first need to [set up `clangd`](https://clangd.llvm.org/installation#project-setup) by running:
|
Clangd requires a compilation database, which Meson generates by default. After running `meson setup`, there will already be a `compile_commands.json` file in the build directory.
|
||||||
|
Some editor configurations may prefer that file to be in the root directory, which you can accomplish with a simple:
|
||||||
|
|
||||||
```console
|
```bash
|
||||||
make clean && bear -- make -j$NIX_BUILD_CORES install
|
$ ln -sf ./build/compile_commands.json ./compile_commands.json
|
||||||
```
|
```
|
||||||
|
|
||||||
Configure your editor to use the `clangd` from the shell, either by running it inside the development shell, or by using [nix-direnv](https://github.com/nix-community/nix-direnv) and [the appropriate editor plugin](https://github.com/direnv/direnv/wiki#editor-integration).
|
Configure your editor to use the `clangd` from the shell, either by running it inside the development shell, or by using [nix-direnv](https://github.com/nix-community/nix-direnv) and [the appropriate editor plugin](https://github.com/direnv/direnv/wiki#editor-integration).
|
||||||
|
@ -253,15 +262,7 @@ This happens late in the process, so `nix build` is not suitable for iterating.
|
||||||
To build the manual incrementally, run:
|
To build the manual incrementally, run:
|
||||||
|
|
||||||
```console
|
```console
|
||||||
make html -j $NIX_BUILD_CORES
|
meson compile -C build manual
|
||||||
```
|
|
||||||
|
|
||||||
In order to reflect changes to the [Makefile], clear all generated files before re-building:
|
|
||||||
|
|
||||||
[Makefile]: https://github.com/NixOS/nix/blob/master/doc/manual/local.mk
|
|
||||||
|
|
||||||
```console
|
|
||||||
rm $(git ls-files doc/manual/ -o | grep -F '.md') && rmdir doc/manual/src/command-ref/new-cli && make html -j $NIX_BUILD_CORES
|
|
||||||
```
|
```
|
||||||
|
|
||||||
[`mdbook-linkcheck`] does not implement checking [URI fragments] yet.
|
[`mdbook-linkcheck`] does not implement checking [URI fragments] yet.
|
||||||
|
@ -292,9 +293,9 @@ can also build and view it yourself:
|
||||||
|
|
||||||
or inside a `nix develop` shell by running:
|
or inside a `nix develop` shell by running:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
# make internal-api-html
|
$ meson compile -C build internal-api-docs
|
||||||
# xdg-open ./outputs/doc/share/doc/nix/internal-api/html/index.html
|
$ xdg-open ./outputs/doc/share/doc/nix/internal-api/html/index.html
|
||||||
```
|
```
|
||||||
|
|
||||||
## Coverage analysis
|
## Coverage analysis
|
||||||
|
|
22
flake.nix
22
flake.nix
|
@ -196,24 +196,6 @@
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
# FIXME(Qyriad): remove this when the migration to Meson has been completed.
|
|
||||||
# NOTE: mesonBuildClang depends on mesonBuild depends on build to avoid OOMs
|
|
||||||
# on aarch64 builders caused by too many parallel compiler/linker processes.
|
|
||||||
mesonBuild = forAllSystems (
|
|
||||||
system:
|
|
||||||
(self.packages.${system}.nix.override { buildWithMeson = true; }).overrideAttrs (prev: {
|
|
||||||
buildInputs = prev.buildInputs ++ [ self.packages.${system}.nix ];
|
|
||||||
})
|
|
||||||
);
|
|
||||||
mesonBuildClang = forAllSystems (
|
|
||||||
system:
|
|
||||||
(nixpkgsFor.${system}.stdenvs.clangStdenvPackages.nix.override { buildWithMeson = true; })
|
|
||||||
.overrideAttrs
|
|
||||||
(prev: {
|
|
||||||
buildInputs = prev.buildInputs ++ [ self.hydraJobs.mesonBuild.${system} ];
|
|
||||||
})
|
|
||||||
);
|
|
||||||
|
|
||||||
# Perl bindings for various platforms.
|
# Perl bindings for various platforms.
|
||||||
perlBindings = forAllSystems (system: nixpkgsFor.${system}.native.nix.perl-bindings);
|
perlBindings = forAllSystems (system: nixpkgsFor.${system}.native.nix.perl-bindings);
|
||||||
|
|
||||||
|
@ -237,7 +219,6 @@
|
||||||
inherit (pkgs) build-release-notes;
|
inherit (pkgs) build-release-notes;
|
||||||
internalApiDocs = true;
|
internalApiDocs = true;
|
||||||
busybox-sandbox-shell = pkgs.busybox-sandbox-shell;
|
busybox-sandbox-shell = pkgs.busybox-sandbox-shell;
|
||||||
buildWithMeson = true;
|
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
nix.overrideAttrs (prev: {
|
nix.overrideAttrs (prev: {
|
||||||
|
@ -367,9 +348,6 @@
|
||||||
checks = forAllSystems (
|
checks = forAllSystems (
|
||||||
system:
|
system:
|
||||||
{
|
{
|
||||||
# FIXME(Qyriad): remove this when the migration to Meson has been completed.
|
|
||||||
mesonBuild = self.hydraJobs.mesonBuild.${system};
|
|
||||||
mesonBuildClang = self.hydraJobs.mesonBuildClang.${system};
|
|
||||||
binaryTarball = self.hydraJobs.binaryTarball.${system};
|
binaryTarball = self.hydraJobs.binaryTarball.${system};
|
||||||
perlBindings = self.hydraJobs.perlBindings.${system};
|
perlBindings = self.hydraJobs.perlBindings.${system};
|
||||||
nixpkgsLibTests = self.hydraJobs.tests.nixpkgsLibTests.${system};
|
nixpkgsLibTests = self.hydraJobs.tests.nixpkgsLibTests.${system};
|
||||||
|
|
42
meson.build
42
meson.build
|
@ -85,8 +85,8 @@ endif
|
||||||
enable_docs = get_option('enable-docs')
|
enable_docs = get_option('enable-docs')
|
||||||
enable_internal_api_docs = get_option('internal-api-docs')
|
enable_internal_api_docs = get_option('internal-api-docs')
|
||||||
|
|
||||||
doxygen = find_program('doxygen', required : enable_internal_api_docs)
|
doxygen = find_program('doxygen', required : enable_internal_api_docs, native : true)
|
||||||
bash = find_program('bash')
|
bash = find_program('bash', native : true)
|
||||||
|
|
||||||
rapidcheck_meson = dependency('rapidcheck', required : enable_internal_api_docs)
|
rapidcheck_meson = dependency('rapidcheck', required : enable_internal_api_docs)
|
||||||
|
|
||||||
|
@ -114,6 +114,25 @@ endif
|
||||||
|
|
||||||
cxx = meson.get_compiler('cpp')
|
cxx = meson.get_compiler('cpp')
|
||||||
|
|
||||||
|
# Translate some historical and Mesony CPU names to Lixy CPU names.
|
||||||
|
# FIXME(Qyriad): the 32-bit x86 code is not tested right now, because cross compilation for Lix
|
||||||
|
# to those architectures is currently broken for other reasons, namely:
|
||||||
|
# - nixos-23.11's x86_64-linux -> i686-linux glibc does not build (also applies to cppnix)
|
||||||
|
# - nixpkgs-unstable (as of 2024/04)'s boehmgc is not compatible with our patches
|
||||||
|
# It's also broken in cppnix, though.
|
||||||
|
host_cpu = host_machine.cpu_family()
|
||||||
|
if host_cpu in ['x86', 'i686', 'i386']
|
||||||
|
# Meson considers 32-bit x86 CPUs to be "x86", and does not consider 64-bit
|
||||||
|
# x86 CPUs to be "x86" (instead using "x86_64", which needs no translation).
|
||||||
|
host_cpu = 'i686'
|
||||||
|
elif host_cpu == 'amd64'
|
||||||
|
# This should not be needed under normal circumstances, but someone could pass a --cross-file
|
||||||
|
# that sets the cpu_family to this.
|
||||||
|
host_cpu = 'x86_64'
|
||||||
|
elif host_cpu in ['armv6', 'armv7']
|
||||||
|
host_cpu += 'l'
|
||||||
|
endif
|
||||||
|
|
||||||
host_system = host_machine.cpu_family() + '-' + host_machine.system()
|
host_system = host_machine.cpu_family() + '-' + host_machine.system()
|
||||||
message('canonical Nix system name:', host_system)
|
message('canonical Nix system name:', host_system)
|
||||||
|
|
||||||
|
@ -181,6 +200,7 @@ openssl = dependency('libcrypto', 'openssl', required : true)
|
||||||
deps += openssl
|
deps += openssl
|
||||||
|
|
||||||
aws_sdk = dependency('aws-cpp-sdk-core', required : false)
|
aws_sdk = dependency('aws-cpp-sdk-core', required : false)
|
||||||
|
aws_sdk_transfer = dependency('aws-cpp-sdk-transfer', required : aws_sdk.found())
|
||||||
if aws_sdk.found()
|
if aws_sdk.found()
|
||||||
# The AWS pkg-config adds -std=c++11.
|
# The AWS pkg-config adds -std=c++11.
|
||||||
# https://github.com/aws/aws-sdk-cpp/issues/2673
|
# https://github.com/aws/aws-sdk-cpp/issues/2673
|
||||||
|
@ -198,7 +218,7 @@ if aws_sdk.found()
|
||||||
'AWS_VERSION_MINOR': s[1].to_int(),
|
'AWS_VERSION_MINOR': s[1].to_int(),
|
||||||
'AWS_VERSION_PATCH': s[2].to_int(),
|
'AWS_VERSION_PATCH': s[2].to_int(),
|
||||||
}
|
}
|
||||||
aws_sdk_transfer = dependency('aws-cpp-sdk-transfer', required : true).partial_dependency(
|
aws_sdk_transfer = aws_sdk_transfer.partial_dependency(
|
||||||
compile_args : false,
|
compile_args : false,
|
||||||
includes : true,
|
includes : true,
|
||||||
link_args : true,
|
link_args : true,
|
||||||
|
@ -255,7 +275,7 @@ gtest = [
|
||||||
]
|
]
|
||||||
deps += gtest
|
deps += gtest
|
||||||
|
|
||||||
toml11 = dependency('toml11', version : '>=3.7.0', required : true)
|
toml11 = dependency('toml11', version : '>=3.7.0', required : true, method : 'cmake')
|
||||||
deps += toml11
|
deps += toml11
|
||||||
|
|
||||||
nlohmann_json = dependency('nlohmann_json', required : true)
|
nlohmann_json = dependency('nlohmann_json', required : true)
|
||||||
|
@ -272,17 +292,17 @@ deps += lix_doc
|
||||||
#
|
#
|
||||||
# Build-time tools
|
# Build-time tools
|
||||||
#
|
#
|
||||||
coreutils = find_program('coreutils')
|
coreutils = find_program('coreutils', native : true)
|
||||||
dot = find_program('dot', required : false)
|
dot = find_program('dot', required : false, native : true)
|
||||||
pymod = import('python')
|
pymod = import('python')
|
||||||
python = pymod.find_installation('python3')
|
python = pymod.find_installation('python3')
|
||||||
|
|
||||||
if enable_docs
|
if enable_docs
|
||||||
mdbook = find_program('mdbook')
|
mdbook = find_program('mdbook', native : true)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Used to workaround https://github.com/mesonbuild/meson/issues/2320 in src/nix/meson.build.
|
# Used to workaround https://github.com/mesonbuild/meson/issues/2320 in src/nix/meson.build.
|
||||||
installcmd = find_program('install')
|
installcmd = find_program('install', native : true)
|
||||||
|
|
||||||
enable_embedded_sandbox_shell = get_option('enable-embedded-sandbox-shell')
|
enable_embedded_sandbox_shell = get_option('enable-embedded-sandbox-shell')
|
||||||
if enable_embedded_sandbox_shell
|
if enable_embedded_sandbox_shell
|
||||||
|
@ -307,9 +327,9 @@ endif
|
||||||
# FIXME(Qyriad): the autoconf system checks that busybox has the "standalone" feature, indicating
|
# FIXME(Qyriad): the autoconf system checks that busybox has the "standalone" feature, indicating
|
||||||
# that busybox sh won't run busybox applets as builtins (which would break our sandbox).
|
# that busybox sh won't run busybox applets as builtins (which would break our sandbox).
|
||||||
|
|
||||||
lsof = find_program('lsof')
|
lsof = find_program('lsof', native : true)
|
||||||
bison = find_program('bison')
|
bison = find_program('bison', native : true)
|
||||||
flex = find_program('flex')
|
flex = find_program('flex', native : true)
|
||||||
|
|
||||||
# This is how Nix does generated headers...
|
# This is how Nix does generated headers...
|
||||||
# other instances of header generation use a very similar command.
|
# other instances of header generation use a very similar command.
|
||||||
|
|
54
package.nix
54
package.nix
|
@ -62,7 +62,7 @@
|
||||||
|
|
||||||
# FIXME(Qyriad): build Lix using Meson instead of autoconf and make.
|
# FIXME(Qyriad): build Lix using Meson instead of autoconf and make.
|
||||||
# This flag will be removed when the migration to Meson is complete.
|
# This flag will be removed when the migration to Meson is complete.
|
||||||
buildWithMeson ? false,
|
buildWithMeson ? true,
|
||||||
|
|
||||||
# Not a real argument, just the only way to approximate let-binding some
|
# Not a real argument, just the only way to approximate let-binding some
|
||||||
# stuff for argument defaults.
|
# stuff for argument defaults.
|
||||||
|
@ -100,6 +100,43 @@ let
|
||||||
|
|
||||||
testConfigureFlags = [ "RAPIDCHECK_HEADERS=${lib.getDev rapidcheck}/extras/gtest/include" ];
|
testConfigureFlags = [ "RAPIDCHECK_HEADERS=${lib.getDev rapidcheck}/extras/gtest/include" ];
|
||||||
|
|
||||||
|
# Reimplementation of Nixpkgs' Meson cross file, with some additions to make
|
||||||
|
# it actually work.
|
||||||
|
mesonCrossFile =
|
||||||
|
let
|
||||||
|
cpuFamily =
|
||||||
|
platform:
|
||||||
|
with platform;
|
||||||
|
if isAarch32 then
|
||||||
|
"arm"
|
||||||
|
else if isx86_32 then
|
||||||
|
"x86"
|
||||||
|
else
|
||||||
|
platform.uname.processor;
|
||||||
|
in
|
||||||
|
builtins.toFile "lix-cross-file.conf" ''
|
||||||
|
[properties]
|
||||||
|
bindgen_clang_arguments = ['-target', '${stdenv.targetPlatform.config}']
|
||||||
|
# Meson is convinced that if !buildPlatform.canExecute hostPlatform then we cannot
|
||||||
|
# build anything at all, which is not at all correct. If we can't execute the host
|
||||||
|
# platform, we'll just disable tests and doc gen.
|
||||||
|
needs_exe_wrapper = false
|
||||||
|
|
||||||
|
[host_machine]
|
||||||
|
system = '${stdenv.targetPlatform.parsed.kernel.name}'
|
||||||
|
cpu_family = '${cpuFamily stdenv.targetPlatform}'
|
||||||
|
cpu = '${stdenv.targetPlatform.parsed.cpu.name}'
|
||||||
|
endian = ${if stdenv.targetPlatform.isLittleEndian then "'little'" else "'big'"}
|
||||||
|
|
||||||
|
[binaries]
|
||||||
|
llvm-config = 'llvm-config-native'
|
||||||
|
rust = ['rustc', '--target', '${stdenv.targetPlatform.rust.rustcTargetSpec}']
|
||||||
|
# Meson refuses to consider any CMake binary during cross compilation if it's
|
||||||
|
# not explicitly specified here, in the cross file.
|
||||||
|
# https://github.com/mesonbuild/meson/blob/0ed78cf6fa6d87c0738f67ae43525e661b50a8a2/mesonbuild/cmake/executor.py#L72
|
||||||
|
cmake = 'cmake'
|
||||||
|
'';
|
||||||
|
|
||||||
# The internal API docs need these for the build, but if we're not building
|
# The internal API docs need these for the build, but if we're not building
|
||||||
# Nix itself, then these don't need to be propagated.
|
# Nix itself, then these don't need to be propagated.
|
||||||
maybePropagatedInputs = [
|
maybePropagatedInputs = [
|
||||||
|
@ -184,10 +221,15 @@ stdenv.mkDerivation (finalAttrs: {
|
||||||
]
|
]
|
||||||
++ lib.optional stdenv.hostPlatform.isStatic "-Denable-embedded-sandbox-shell=true"
|
++ lib.optional stdenv.hostPlatform.isStatic "-Denable-embedded-sandbox-shell=true"
|
||||||
++ lib.optional (finalAttrs.dontBuild) "-Denable-build=false"
|
++ lib.optional (finalAttrs.dontBuild) "-Denable-build=false"
|
||||||
# mesonConfigurePhase automatically passes -Dauto_features=enabled,
|
++ [
|
||||||
# so we must explicitly enable or disable features that we are not passing
|
# mesonConfigurePhase automatically passes -Dauto_features=enabled,
|
||||||
# dependencies for.
|
# so we must explicitly enable or disable features that we are not passing
|
||||||
++ lib.singleton (lib.mesonEnable "internal-api-docs" internalApiDocs);
|
# dependencies for.
|
||||||
|
(lib.mesonEnable "internal-api-docs" internalApiDocs)
|
||||||
|
(lib.mesonBool "enable-tests" finalAttrs.doCheck)
|
||||||
|
(lib.mesonBool "enable-docs" canRunInstalled)
|
||||||
|
]
|
||||||
|
++ lib.optional (stdenv.hostPlatform != stdenv.buildPlatform) "--cross-file=${mesonCrossFile}";
|
||||||
|
|
||||||
# We only include CMake so that Meson can locate toml11, which only ships CMake dependency metadata.
|
# We only include CMake so that Meson can locate toml11, which only ships CMake dependency metadata.
|
||||||
dontUseCmakeConfigure = true;
|
dontUseCmakeConfigure = true;
|
||||||
|
@ -315,7 +357,7 @@ stdenv.mkDerivation (finalAttrs: {
|
||||||
|
|
||||||
makeFlags = "profiledir=$(out)/etc/profile.d PRECOMPILE_HEADERS=1";
|
makeFlags = "profiledir=$(out)/etc/profile.d PRECOMPILE_HEADERS=1";
|
||||||
|
|
||||||
doCheck = true;
|
doCheck = canRunInstalled;
|
||||||
|
|
||||||
mesonCheckFlags = lib.optionals (buildWithMeson || forDevShell) [ "--suite=check" ];
|
mesonCheckFlags = lib.optionals (buildWithMeson || forDevShell) [ "--suite=check" ];
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ foreach header : [ 'schema.sql', 'ca-specific-schema.sql' ]
|
||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
if enable_embedded_sandbox_shell
|
if enable_embedded_sandbox_shell
|
||||||
hexdump = find_program('hexdump', required : true)
|
hexdump = find_program('hexdump', required : true, native : true)
|
||||||
embedded_sandbox_shell_gen = custom_target(
|
embedded_sandbox_shell_gen = custom_target(
|
||||||
'embedded-sandbox-shell.gen.hh',
|
'embedded-sandbox-shell.gen.hh',
|
||||||
command : [
|
command : [
|
||||||
|
|
Loading…
Reference in a new issue