Xavier Claessens
March 30, 2022
Reading time:
When developing an application or a library, it is very common to want to run it without installing it, or to install it into a custom prefix rather than on the system (i.e. /usr
or /usr/local
).
Meson has always helped with that by setting rpath in the built executables so they can find their shared libraries within the build directory tree. However, it has two main limitations:
Many applications solve that with custom shell scripts that set various environment variables, like GST_PLUGIN_PATH
, GI_TYPELIB_PATH
, etc...
Since Meson 0.58.0, this can be easily done by simply using the meson devenv -C <builddir>
command, and adding the needed environment variables directly in your meson.build
files using meson.add_devenv()
.
Running gst-launch-1.0 using the meson devenv -C <builddir> command |
Doing this directly in Meson instead of relying on custom shell scripts has two big advantages:
As mentioned above, Windows DLLs are searched into the PATH; Meson will automatically set every location within the build directory where a DLL is built.
But that's not all, Meson will also add in PATH every location within the build directory where an executable is built. You can just execute the command to use the built program instead of a program installed on your system.
Let's say you want to test a change you make in a library (e.g. GStreamer) and need to run an application using that library (e.g. Totem) that you have on your system. Since Meson sets LD_LIBRARY_PATH
(or DYLD_LIBRARY_PATH
on OSX, PATH
on Windows), when you run Totem from your system, it will link to GStreamer libraries (and plugins, see below) from your build directory.
Want to test the generated GObject Introspection for your library? Meson sets GI_TYPELIB_PATH
automatically for every project that already uses gnome.generate_gir()
.
gstreamer$ meson devenv -C builddir/ python >>> import gi >>> from gi.repository import Gst >>> Gst.init(None) >>> Gst.version() (major=1, minor=21, micro=0, nano=1)
GLib or GTK applications often use gnome.compile_schemas()
to define their settings. Meson will set GSETTINGS_SCHEMA_DIR
for you, so the application can run and access its settings without having to install their schema on the system.
When using pkg.generate()
Meson also writes <name>-uninstalled.pc
. In the developer environment, PKG_CONFIG_PATH
always includes the directory where Meson wrote those .pc
files so you can configure and build applications that use that library. This is especially useful when the application uses another build system such as autotools
; if the build system is Meson too, it is often easier to use a subproject instead.
Projects that install executables with a command line interface often also install a bash script for auto-completion. Meson detects such script and sources them directly from your source tree.
Requires Meson 0.62.0.
Some C projects ship GDB scripts to help with debugging (e.g. GLib and GStreamer). Those scripts have a filename in the form of <libname>-gdb.{py,gdb,csm}
. When installed in the right location, GDB will load them automatically when libname
is linked by the executable being debugged.
Meson detects those files automatically and writes the needed .gdbinit
configuration file so GDB will load the helper scripts directly from your source tree.
Requires Meson 0.62.0.
Unfortunately, Meson cannot guess everything. Custom environment variables need to be defined manually with the meson.add_devenv()
method.
If your application needs to access data files, you typically would add this in data/meson.build
:
meson.add_devenv({'MY_APP_DATA_DIR': meson.current_source_dir()})
For projects that build various plugins in many different locations (e.g. GStreamer), you can add each location into the environment variable:
# plugin1/meson.build meson.add_devenv({'MY_PLUGIN_PATH': meson.current_build_dir()}, method: 'prepend') # plugin2/meson.build meson.add_devenv({'MY_PLUGIN_PATH': meson.current_build_dir()}, method: 'prepend')
Meson aggregates the developer environment definitions from every subproject. When your application builds some of its dependencies as a subproject, they will work in your developer environment without having to know which environment variables you have to define for every single one of them.
Many projects have their own "uninstalled" script. Replacing them with the proper Meson system benefits everyone, especially when your project can be used by others as a subproject. Please reach out if there is anything else Meson could be doing to help developers!
Most of the features described here are inspired by GStreamer's gst-env.py
script. Thanks to the GStreamer community for such a great tool!
03/12/2024
this is a test post
08/10/2024
Having multiple developers work on pre-merge testing distributes the process and ensures that every contribution is rigorously tested before…
15/08/2024
After rigorous debugging, a new unit testing framework was added to the backend compiler for NVK. This is a walkthrough of the steps taken…
01/08/2024
We're reflecting on the steps taken as we continually seek to improve Linux kernel integration. This will include more detail about the…
27/06/2024
With each board running a mainline-first Linux software stack and tested in a CI loop with the LAVA test framework, the Farm showcased Collabora's…
26/06/2024
WirePlumber 0.5 arrived recently with many new and essential features including the Smart Filter Policy, enabling audio filters to automatically…
Comments (0)
Add a Comment