aboutsummaryrefslogtreecommitdiff
path: root/docs/markdown/snippets
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2022-02-19 18:17:28 +0200
committerJussi Pakkanen <jpakkane@gmail.com>2022-03-08 23:40:03 +0200
commite257a870fe5e676c55a2282b0e7fc9be34bba2ac (patch)
treea185f567f29b44e69377318c123b9e86fd075019 /docs/markdown/snippets
parent789f440f7c2bfda2e17f05ecdcb1a19245f892df (diff)
downloadmeson-e257a870fe5e676c55a2282b0e7fc9be34bba2ac.zip
meson-e257a870fe5e676c55a2282b0e7fc9be34bba2ac.tar.gz
meson-e257a870fe5e676c55a2282b0e7fc9be34bba2ac.tar.bz2
Add new env2cross command.
Diffstat (limited to 'docs/markdown/snippets')
-rw-r--r--docs/markdown/snippets/env2cross.md40
1 files changed, 40 insertions, 0 deletions
diff --git a/docs/markdown/snippets/env2cross.md b/docs/markdown/snippets/env2cross.md
new file mode 100644
index 0000000..bb53145
--- /dev/null
+++ b/docs/markdown/snippets/env2cross.md
@@ -0,0 +1,40 @@
+## Experimental command to convert environments to cross files
+
+Meson has a new command `env2mfile` that can be used to convert
+"environment variable based" cross and native compilation environments
+to Meson machine files. This is especially convenient for e.g. distro
+packagers so they can easily generate unambiguous configuration files
+for packge building.
+
+As an example here's how you would generate a cross file that takes
+its settings from the `CC`, `CXX`, `CFLAGS` etc environment variables.
+
+ meson env2mfile --cross --system=baremetal --cpu=armv7 --cpu-family=arm -o armcross.txt
+
+The command also has support for generating Debian build files using
+system introspection:
+
+ meson env2mfile --cross --debarch armhf -o debarmhf_cross.txt
+
+Note how you don't need to specify any system details, the command
+gets them transparently via `dpkg-architecture`.
+
+Creating a native file is done in the same way:
+
+ meson env2mfile --native -o current_system.txt
+
+This system will detect if the `_FOR_BUILD` environment variables are
+enabled and then uses them as needed.
+
+With this you should be able to convert any envvar-based cross build
+setup to cross and native files and then use those. Thit means, among
+other things, that you can then run your compilations from any shell,
+not just the special one that has all the environment variables set.
+
+As this functionality is still a bit in flux, the specific behaviour
+and command line arguments to use are subject to change. Because of
+this the main documentation has not yet been updated.
+
+Please try this for your use cases and report to us if it is working.
+Patches to make the autodetection work on other distros and platforms
+are also welcome.