2021-01-13 12:59:15 +01:00
|
|
|
Up: [Readme.md](../Readme.md), Prev: [Section 1](sec1.md), Next: [Section 3](sec3.md)
|
2021-01-11 03:15:04 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
# Installation of gtk4 to Linux distributions
|
2020-12-21 13:12:05 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
This section describes how to install gtk4 into Linux distributions.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
This tutorial including this section is without any warranty.
|
|
|
|
If you install gtk4 to your computer, do it at your own risk.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
There are two possible way to install gtk4 (April/2021).
|
|
|
|
|
|
|
|
- Build it from the source file.
|
|
|
|
- Install a distribution which uses gtk4.
|
|
|
|
|
|
|
|
Regarding the first way, I only have an experience to install it to Ubuntu 20.10.
|
|
|
|
Probably you need more than the explanation below.
|
|
|
|
However, at present (April/2021), this is the most general way.
|
|
|
|
|
|
|
|
The second way is easy to install.
|
|
|
|
See [Gnome40 website](https://forty.gnome.org/).
|
|
|
|
There are only three choices at present (April/2021).
|
|
|
|
|
|
|
|
- Gnome OS
|
|
|
|
- Fedora 34 Beta
|
|
|
|
- openSUSE
|
|
|
|
|
|
|
|
I've tried installing Fedora 34 Beta with gnome-boxes.
|
|
|
|
It is written at the end of this section.
|
|
|
|
|
|
|
|
## Installation from the source files
|
|
|
|
|
|
|
|
The first part of this section is about the installation from the source files.
|
|
|
|
|
|
|
|
### Prerequisites for gtk4 installation
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
- Ubuntu 20.10. Maybe other versions of late years or other distribution might be OK.
|
|
|
|
- Packages for development such as gcc, meson, ninja, git, wget and so on.
|
|
|
|
- Dev packages necessary for each software below.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Installation target
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
I installed gtk4 under the directory `$HOME/local`.
|
|
|
|
This is a private user area.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-27 01:12:58 +01:00
|
|
|
If you want to install it in the system area, `/opt/gtk4` is one of good choices.
|
2021-03-13 16:14:50 +01:00
|
|
|
[Gtk4 API Reference](https://developer.gnome.org/gtk4/stable/gtk-building.html) gives an installation example to `/opt/gtk4`.
|
2021-01-27 01:12:58 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Don't install it to `/usr/local` which is the default.
|
2021-02-06 09:26:57 +01:00
|
|
|
It is used by Ubuntu applications, which are not build on gtk4.
|
2021-01-13 05:29:35 +01:00
|
|
|
Therefore, the risk is high and probably bad things will happen.
|
2021-02-06 09:26:57 +01:00
|
|
|
Actually I did it and I needed to reinstall Ubuntu.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Glib installation
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Ubuntu includes glib but its version is not high enough to build gtk4.
|
|
|
|
Glib 2.66.0 or higher is required.
|
|
|
|
At present (Jan/2021), its latest version is 2.67.2.
|
|
|
|
I installed 2.67.1 which was the latest version at that time.
|
|
|
|
Download glib source files from the repository, then decompress and extract files.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ wget https://download.gnome.org/sources/glib/2.67/glib-2.67.1.tar.xz
|
|
|
|
$ tar -Jxf glib-2.67.1.tar.xz
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Some packages are required to build glib.
|
|
|
|
You can find them if you run meson.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ meson --prefix $HOME/local _build
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Use apt-get and install the prerequisites.
|
|
|
|
For example,
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ sudo apt-get install -y libpcre2-dev libffi-dev
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
After that, compile glib.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ rm -rf _build
|
|
|
|
$ meson --prefix $HOME/local _build
|
|
|
|
$ ninja -C _build
|
|
|
|
$ ninja -C _build install
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-27 01:12:58 +01:00
|
|
|
Set several environment variables so that the glib libraries installed can be used by build tools.
|
2021-01-13 05:29:35 +01:00
|
|
|
Make a text file below and save it as `env.sh`
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
# compiler
|
|
|
|
CPPFLAGS="-I$HOME/local/include"
|
|
|
|
LDFLAGS="-L$HOME/local/lib"
|
|
|
|
PKG_CONFIG_PATH="$HOME/local/lib/pkgconfig:$HOME/local/lib/x86_64-linux-gnu/pkgconfig"
|
|
|
|
export CPPFLAGS LDFLAGS PKG_CONFIG_PATH
|
|
|
|
# linker
|
|
|
|
LD_LIBRARY_PATH="$HOME/local/lib/x86_64-linux-gnu/"
|
|
|
|
PATH="$HOME/local/bin:$PATH"
|
|
|
|
export LD_LIBRARY_PATH PATH
|
2021-01-15 16:43:48 +01:00
|
|
|
# gsetting
|
|
|
|
export GSETTINGS_SCHEMA_DIR=$HOME/local/share/glib-2.0/schemas
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Then, use . (dot) or source command to include these commands to the current bash.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ . env.sh
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
or
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ source env.sh
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-02-06 09:26:57 +01:00
|
|
|
This command carries out the commands in `env.sh` and changes the environment variables above in the current shell.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Pango installation
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Download and untar.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ wget https://download.gnome.org/sources/pango/1.48/pango-1.48.0.tar.xz
|
|
|
|
$ tar -Jxf pango-1.48.0.tar.xz
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Try meson and check the required packages.
|
|
|
|
Install all the prerequisites.
|
|
|
|
Then, compile and install pango.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ meson --prefix $HOME/local _build
|
|
|
|
$ ninja -C _build
|
|
|
|
$ ninja -C _build install
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
It installs Pnago-1.0.gir under `$HOME/local/share/gir-1.0`.
|
2021-01-27 01:12:58 +01:00
|
|
|
If you installed pango without `--prefix` option, then it would be located at `/usr/local/share/gir-1.0`.
|
2021-01-13 05:29:35 +01:00
|
|
|
This directory (/usr/local/share) is used by applications.
|
|
|
|
They find the directory by the environment variable `XDG_DATA_DIRS`.
|
2021-02-06 09:26:57 +01:00
|
|
|
It is a text file which keep the list of 'share' directories like `/usr/share`, `usr/local/share` and so on.
|
2021-01-13 05:29:35 +01:00
|
|
|
Now `$HOME/local/share` needs to be added to `XDG_DATA_DIRS`, or error will occur in the later compilation.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ export XDG_DATA_DIRS=$HOME/local/share:$XDG_DATA_DIRS
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Gdk-pixbuf and gtk-doc installation
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Download and untar.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ wget https://download.gnome.org/sources/gdk-pixbuf/2.42/gdk-pixbuf-2.42.2.tar.xz
|
|
|
|
$ tar -Jxf gdk-pixbuf-2.42.2.tar.xz
|
|
|
|
$ wget https://download.gnome.org/sources/gtk-doc/1.33/gtk-doc-1.33.1.tar.xz
|
|
|
|
$ tar -Jxf gtk-doc-1.33.1.tar.xz
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Same as before, install prerequisite packages, then compile and install them.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
The installation of gtk-doc put `gtk-doc.pc` under `$HOME/local/share/pkgconfig`.
|
|
|
|
This file is used by pkg-config, which is one of the build tools.
|
|
|
|
The directory needs to be added to the environment variable `PKG_CONFIG_PATH`
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ export PKG_CONFIG_PATH="$HOME/local/share/pkgconfig:$PKG_CONFIG_PATH"
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Gtk4 installation
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
If you want the latest development version of gtk4, use git and clone the repository.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ git clone https://gitlab.gnome.org/GNOME/gtk.git
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
If you want a stable version of gtk4, then download it from [Gnome source website](https://download.gnome.org/sources/gtk/4.0/).
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Compile and install it.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
$ meson --prefix $HOME/local _build
|
|
|
|
$ ninja -C _build
|
|
|
|
$ ninja -C _build install
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-03-13 16:14:50 +01:00
|
|
|
If you want to know more information, refer to [Gtk4 reference manual](https://developer.gnome.org/gtk4/stable/gtk-building.html).
|
2021-01-16 12:20:11 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Modify env.sh
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Because environment variables disappear when you log out, you need to add them again.
|
|
|
|
Modify `env.sh`.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
# compiler
|
|
|
|
CPPFLAGS="-I$HOME/local/include"
|
|
|
|
LDFLAGS="-L$HOME/local/lib"
|
2021-01-25 10:35:49 +01:00
|
|
|
PKG_CONFIG_PATH="$HOME/local/lib/pkgconfig:$HOME/local/lib/x86_64-linux-gnu/pkgconfig:
|
|
|
|
$HOME/local/share/pkgconfig"
|
2021-01-13 05:29:35 +01:00
|
|
|
export CPPFLAGS LDFLAGS PKG_CONFIG_PATH
|
|
|
|
# linker
|
|
|
|
LD_LIBRARY_PATH="$HOME/local/lib/x86_64-linux-gnu/"
|
|
|
|
PATH="$HOME/local/bin:$PATH"
|
|
|
|
export LD_LIBRARY_PATH PATH
|
|
|
|
# gir
|
|
|
|
XDG_DATA_DIRS=$HOME/local/share:$XDG_DATA_DIRS
|
|
|
|
export XDG_DATA_DIRS
|
2021-01-15 16:43:48 +01:00
|
|
|
# gsetting
|
|
|
|
export GSETTINGS_SCHEMA_DIR=$HOME/local/share/glib-2.0/schemas
|
|
|
|
# girepository-1.0
|
|
|
|
export GI_TYPELIB_PATH=$HOME/local/lib/x86_64-linux-gnu/girepository-1.0
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Include this file by . (dot) command before using gtk4 libraries.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
You may think you can add them in your `.profile`.
|
2021-02-17 15:59:50 +01:00
|
|
|
But it's a wrong decision.
|
|
|
|
Never write them to your `.profile`.
|
|
|
|
The environment variables above are necessary only when you compile and run gtk4 applications.
|
|
|
|
Otherwise it's not necessary.
|
|
|
|
If you changed the environment variables above and run gtk3 applications, it probably causes serious damage.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
### Compiling gtk4 applications
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-01-13 05:29:35 +01:00
|
|
|
Before you compile gtk4 applications, define environment variables above.
|
|
|
|
|
|
|
|
$ . env.sh
|
|
|
|
|
|
|
|
After that you can compile them without anything.
|
|
|
|
For example, to compile `sample.c`, type the following.
|
|
|
|
|
|
|
|
$ gcc `pkg-config --cflags gtk4` sample.c `pkg-config --libs gtk4`
|
|
|
|
|
|
|
|
To know how to compile gtk4 applications, refer to the following sections.
|
2020-12-22 03:30:06 +01:00
|
|
|
|
2021-04-26 04:44:35 +02:00
|
|
|
## Installing Fedora 34 Beta with gnome-boxes
|
|
|
|
|
|
|
|
The second part of this section is about installing a distribution based on gtk4.
|
|
|
|
See [Gnome 40 website](https://forty.gnome.org/) first.
|
|
|
|
|
|
|
|
Gnome 40 is a new version of Gnome desktop system.
|
|
|
|
It uses gtk4.
|
|
|
|
So, you don't need to build and install gtk4 from the source file.
|
|
|
|
|
|
|
|
There are two ways to install them.
|
|
|
|
|
|
|
|
- Install them to a hard disk.
|
|
|
|
This is a usual installation.
|
|
|
|
- Install them to a virtual machine.
|
|
|
|
|
|
|
|
I've chosen the second way.
|
|
|
|
I've tried installing Fedora 34 Beta with gnome-boxes.
|
|
|
|
My OS was Ubuntu 21.04 at that time.
|
|
|
|
Gnome-boxes creates a virtual machine in Ubuntu and Fedora will be installed to that virtual machine.
|
|
|
|
|
|
|
|
The instruction is as follows.
|
|
|
|
|
|
|
|
1. Download Fedora 34 Beta iso file.
|
|
|
|
There is an link at the end of [Gnome 40 website](https://forty.gnome.org/).
|
|
|
|
2. Install gnome-boxes with apt-get command.
|
|
|
|
~~~
|
|
|
|
$ sudo apt-get install gnome-boxes
|
|
|
|
~~~
|
|
|
|
3. Run gnome-boxes.
|
|
|
|
4. Click on `+` button on the top left corner and launch a box creation wizard by clicking `Create a Virtual Machine ...`.
|
|
|
|
Then a dialog appears.
|
|
|
|
Click on `Operationg System Image File` and select the iso file you have downloaded.
|
|
|
|
5. Then, the installer of Fedora is executed.
|
|
|
|
Follow the instructions by the installer.
|
|
|
|
At the end of installation, the installer instructs to reboot the system.
|
|
|
|
Click the right of the title bar and select reboot or shutdown.
|
|
|
|
6. Your display is back to the initial window of gnome-boxes, but there is a button `Fedora 34 Workstation` on the upper left of the window.
|
|
|
|
Click on the button then Fedora will be executed.
|
|
|
|
7. A setup dialog appears.
|
|
|
|
Setup Fedora according to the wizard.
|
|
|
|
|
|
|
|
Now you can use Fedora.
|
|
|
|
It includes gtk4 libraries already.
|
|
|
|
But you need to install the gtk4 development package.
|
|
|
|
Use `dnf` to install `gtk4.x86_64` package.
|
|
|
|
|
|
|
|
~~~
|
|
|
|
$ sudo dnf install gtk4.x86_64
|
|
|
|
~~~
|
|
|
|
|
|
|
|
### Test for compiling a gtk4 application
|
|
|
|
|
|
|
|
You can test the gtk4 development package by compiling files which are based on gtk4.
|
|
|
|
I've tried compiling `tfe` text editor, which is written in section 20.
|
|
|
|
|
|
|
|
1. Run Firefox.
|
|
|
|
2. Open this website \([Gtk4-Tutorial](https://github.com/ToshioCP/Gtk4-tutorial)\).
|
|
|
|
3. Click on the green button labeled `Code`.
|
|
|
|
4. Select `Download ZIP` and download the codes from the repository.
|
|
|
|
5. Unzip the file.
|
|
|
|
6. Change your current directory to the top directory of the unzipped source files.
|
|
|
|
7. Compile it.
|
|
|
|
~~~
|
|
|
|
$ meson _build
|
|
|
|
bash: meson: command not found...
|
|
|
|
Install package 'meson' to provide command 'meson'? [N/y] y
|
|
|
|
|
|
|
|
* Waiting in queue...
|
|
|
|
The following packages have to be installed:
|
|
|
|
meson-0.56.2-2.fc34.noarch High productivity build system
|
|
|
|
ninja-build-1.10.2-2.fc34.x86_64 Small build system with a focus on speed
|
|
|
|
vim-filesystem-2:8.2.2787-1.fc34.noarch VIM filesystem layout
|
|
|
|
Proceed with changes? [N/y] y
|
|
|
|
|
|
|
|
... ...
|
|
|
|
... ...
|
|
|
|
|
|
|
|
The Meson build system
|
|
|
|
Version: 0.56.2
|
|
|
|
|
|
|
|
... ...
|
|
|
|
... ...
|
|
|
|
|
|
|
|
Project name: tfe
|
|
|
|
Project version: undefined
|
|
|
|
C compiler for the host machine: cc (gcc 11.0.0 "cc (GCC) 11.0.0 20210210 (Red Hat 11.0.0-0)")
|
|
|
|
C linker for the host machine: cc ld.bfd 2.35.1-38
|
|
|
|
Host machine cpu family: x86_64
|
|
|
|
Host machine cpu: x86_64
|
|
|
|
Found pkg-config: /usr/bin/pkg-config (1.7.3)
|
|
|
|
Run-time dependency gtk4 found: YES 4.2.0
|
|
|
|
Found pkg-config: /usr/bin/pkg-config (1.7.3)
|
|
|
|
Program glib-compile-resources found: YES (/usr/bin/glib-compile-resources)
|
|
|
|
Program glib-compile-schemas found: YES (/usr/bin/glib-compile-schemas)
|
|
|
|
Program glib-compile-schemas found: YES (/usr/bin/glib-compile-schemas)
|
|
|
|
Build targets in project: 4
|
|
|
|
|
|
|
|
Found ninja-1.10.2 at /usr/bin/ninja
|
|
|
|
|
|
|
|
$ ninja -C _build
|
|
|
|
ninja: Entering directory `_build'
|
|
|
|
[12/12] Linking target tfe
|
|
|
|
|
|
|
|
$ ninja -C _build install
|
|
|
|
ninja: Entering directory `_build'
|
|
|
|
[0/1] Installing files.
|
|
|
|
Installing tfe to /usr/local/bin
|
|
|
|
Installation failed due to insufficient permissions.
|
|
|
|
Attempting to use polkit to gain elevated privileges...
|
|
|
|
Installing tfe to /usr/local/bin
|
|
|
|
Installing /home/<username>/Gtk4-tutorial-main/src/tfe7/com.github.ToshioCP.tfe.gschema.xml to /usr/local/share/glib-2.0/schemas
|
|
|
|
Running custom install script '/usr/bin/glib-compile-schemas /usr/local/share/glib-2.0/schemas/'
|
|
|
|
~~~
|
|
|
|
8. Execute it.
|
|
|
|
~~~
|
|
|
|
$ tfe
|
|
|
|
~~~
|
|
|
|
|
|
|
|
Then, the window of `tfe` text editor appears.
|
|
|
|
The compilation and execution have succeeded.
|
|
|
|
|
2021-01-11 03:15:04 +01:00
|
|
|
|
2021-01-13 12:59:15 +01:00
|
|
|
Up: [Readme.md](../Readme.md), Prev: [Section 1](sec1.md), Next: [Section 3](sec3.md)
|