|
|
|
---
|
|
|
|
short-description: Simple getting started guide
|
|
|
|
...
|
|
|
|
|
|
|
|
# The Absolute Beginner's Guide to Installing and Using Meson
|
|
|
|
|
|
|
|
This page is meant for people who are new to using Meson and possibly
|
|
|
|
even to compiling C and/or C++ code in general. It is meant to contain
|
|
|
|
one simple way of getting your build environment up and running. If
|
|
|
|
you are more experienced and have your own preferred way of installing
|
|
|
|
and using development software, feel free to use that instead. This
|
|
|
|
guide only deals with Linux, Windows and macOS platforms. If you use
|
|
|
|
some other platform, such as one of the BSDs, you probably already
|
|
|
|
know how to install development tools on it (probably better than we
|
|
|
|
do, even).
|
|
|
|
|
|
|
|
There are three phases to getting a development environment running.
|
|
|
|
|
|
|
|
1. Installing a compiler toolchain
|
|
|
|
2. Installing Meson
|
|
|
|
3. Creating a project and building it
|
|
|
|
|
|
|
|
## Installing a compiler toolchain
|
|
|
|
|
|
|
|
### Linux
|
|
|
|
|
|
|
|
All Linux distributions provide easy access to development tools.
|
|
|
|
Typically you need to open a terminal and execute one command, which
|
|
|
|
depends on your distro.
|
|
|
|
|
|
|
|
- Debian, Ubuntu and derivatives: `sudo apt install build-essential`
|
|
|
|
- Fedora, Centos, RHEL and derivatives: `sudo dnf install gcc-c++`
|
|
|
|
- Arch: `sudo pacman -S gcc`
|
|
|
|
|
|
|
|
### Windows
|
|
|
|
|
|
|
|
The most common development toolchain on Windows is Visual Studio,
|
|
|
|
which can be downloaded from [the Visual Studio web
|
|
|
|
site](https://visualstudio.microsoft.com/). Select the Community
|
|
|
|
version unless you have bought a license.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fe192/fe192809bfacad0703e2f5bd2c61ed0e273c67f3" alt="Download page of Visual Studio"
|
|
|
|
|
|
|
|
Download the installer and run it. When you are given a list of things
|
|
|
|
to install, select *Desktop development with C++*. This installs both
|
|
|
|
a C and a C++ compiler.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/05298/05298b4cc3435e4dafff0bfb93e1f0cbc1574a30" alt="Installing the Visual Studio compilers"
|
|
|
|
|
|
|
|
Once the installer finishes the compiler toolchain is ready to use.
|
|
|
|
|
|
|
|
### macOS
|
|
|
|
|
|
|
|
On macOS the development toolchain must be installed via the Mac app
|
|
|
|
store. Search for an app called XCode and install it.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/013c6/013c6bdbfe08e7694d4cae29e8a0a76c69f2d3d1" alt="App store page for XCode"
|
|
|
|
|
|
|
|
*Note:* Installing XCode is not sufficient by itself. You also need to
|
|
|
|
start XCode' GUI application once. This will make XCode download and
|
|
|
|
install more files that are needed for compilation.
|
|
|
|
|
|
|
|
## Installing Meson
|
|
|
|
|
|
|
|
### Linux
|
|
|
|
|
|
|
|
Installing Meson is just as simple as installing the compiler toolchain.
|
|
|
|
|
|
|
|
- Debian, Ubuntu and derivatives: `sudo apt install meson ninja-build`
|
|
|
|
- Fedora, Centos, RHEL and derivatives: `sudo dnf install meson ninja-build`
|
|
|
|
- Arch: `sudo pacman -S meson`
|
|
|
|
|
|
|
|
### Windows
|
|
|
|
|
|
|
|
Meson provides a standard Windows `.msi` installer that can be
|
|
|
|
downloaded from [the Releases
|
|
|
|
page](https://github.com/mesonbuild/meson/releases).
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bfb7c/bfb7c2441d9afb9947ae35f87d5e0953ebf3af6f" alt="Meson installed download"
|
|
|
|
|
|
|
|
Download and run it to install all the necessary bits. You can verify
|
|
|
|
that your installation is working by running the Visual Studio
|
|
|
|
developer tools command prompt that can be found in the start menu.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9b725/9b72576d89a8fe781053bafd73585004e4e562d6" alt="Devtool prompt"
|
|
|
|
|
|
|
|
You should be able to run both `meson` and `ninja` and query their
|
|
|
|
versions.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d603e/d603e464dcdcc59baef7b14d94edc046ca53aaa3" alt="A working Windows install"
|
|
|
|
|
|
|
|
### macOS
|
|
|
|
|
|
|
|
#### With Homebrew
|
|
|
|
`brew install meson ninja`
|
|
|
|
|
|
|
|
#### Without Homebrew
|
|
|
|
Start by downloading the installation package from [the Releases
|
|
|
|
page](https://github.com/mesonbuild/meson/releases).
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/eba04/eba0412f5ba78734d19eca3ac4971dfbd7733419" alt="Downloading the macOS installer"
|
|
|
|
|
|
|
|
Double click the downloaded installer to start. If you are running a
|
|
|
|
new macOS version, it might refuse to run the application with the
|
|
|
|
following error message:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b31a1/b31a19a62964865f5b5f4b059c6d70fc199fba1d" alt="A macOS signing warning"
|
|
|
|
|
|
|
|
This can be fixed by starting System Preferences, selecting the
|
|
|
|
Security and Privacy entry. At the bottom it shows the blocked app and
|
|
|
|
you can enable it by clicking on the "Open anyway" button.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3916d/3916dcc8ba67985b56a0268ce4c9e4e4814d183a" alt="Security settings"
|
|
|
|
|
|
|
|
Now the installer should start. If not, double click on the downloaded
|
|
|
|
installer file again.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b2742/b274222c4387e62fe2dd878fb4b71300e0509a7b" alt="Installer running"
|
|
|
|
|
|
|
|
Once the installation is finished you can verify that the system is working via the terminal app.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5461e/5461e7071966c137af6eca8b6c026478ee564729" alt="A successful install"
|
|
|
|
|
|
|
|
## Running Meson
|
|
|
|
|
|
|
|
Start a terminal application. On Windows you have to use the Visual
|
|
|
|
Studio Developer Tools Command Prompt as discussed above, because the
|
|
|
|
compilers are only available in that terminal. You also need to change
|
|
|
|
into your home directory (Linux and macOS terminals start in the home
|
|
|
|
directory by default).
|
|
|
|
|
|
|
|
cd \users\username
|
|
|
|
|
|
|
|
Create a new directory to hold your project.
|
|
|
|
|
|
|
|
mkdir testproject
|
|
|
|
cd testproject
|
|
|
|
|
|
|
|
Use Meson to create and build a new sample project.
|
|
|
|
|
|
|
|
meson init --name testproject --build
|
|
|
|
|
|
|
|
This will create a project skeleton for you and compile it. The result
|
|
|
|
is put in the `build` subdirectory and can be run directly from there.
|
|
|
|
|
|
|
|
build/testproject
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fac2d/fac2da8e58d093323912fac7bdb02a359b20284f" alt="All finished and ready to go"
|
|
|
|
|
|
|
|
The project is now ready for development. You can edit the code with
|
|
|
|
any editor and it is rebuilt by going in the `build` subdirectory and
|
|
|
|
executing the `meson compile` command. If your version of Meson is too
|
|
|
|
old, you can compile the project by running the command `ninja`
|
|
|
|
instead.
|