2021-02-10 14:03:56 +00:00
|
|
|
Title: Compiling GTK Applications on UNIX
|
|
|
|
Slug: gtk-compiling
|
2001-02-09 06:14:34 +00:00
|
|
|
|
2019-02-05 09:14:31 +00:00
|
|
|
To compile a GTK application, you need to tell the compiler where to
|
|
|
|
find the GTK header files and libraries. This is done with the
|
2020-05-24 04:04:36 +00:00
|
|
|
`pkg-config` utility.
|
|
|
|
|
|
|
|
The following interactive shell session demonstrates how `pkg-config`
|
|
|
|
is used (the actual output on your system may be different):
|
|
|
|
|
|
|
|
```
|
2019-02-05 09:14:31 +00:00
|
|
|
$ pkg-config --cflags gtk4
|
Remove ATK
To build a better world sometimes means having to tear the old one down.
-- Alexander Pierce, "Captain America: The Winter Soldier"
ATK served us well for nearly 20 years, but the world has changed, and
GTK has changed with it. Now ATK is mostly a hindrance towards improving
the accessibility stack:
- it maps to a very specific implementation, AT-SPI, which is Linux and
Unix specific
- it requires implementing the same functionality in three different
layers of the stack: AT-SPI, ATK, and GTK
- only GTK uses it; every other Linux and Unix toolkit and application
talks to AT-SPI directly, including assistive technologies
Sadly, we cannot incrementally port GTK to a new accessibility stack;
since ATK insulates us entirely from the underlying implementation, we
cannot replace it piecemeal. Instead, we're going to remove everything
and then incrementally build on a clean slate:
- add an "accessible" interface, implemented by GTK objects directly,
which describe the accessible role and state changes for every UI
element
- add an "assistive technology context" to proxy a native accessibility
API, and assign it to every widget
- implement the AT context depending on the platform
For more information, see: https://gitlab.gnome.org/GNOME/gtk/-/issues/2833
2020-06-16 15:41:59 +00:00
|
|
|
-pthread -I/usr/include/gtk-4.0 -I/usr/lib64/gtk-4.0/include -I/usr/include/cairo -I/usr/include/pango-1.0 -I/usr/include/glib-2.0 -I/usr/lib64/glib-2.0/include -I/usr/include/pixman-1 -I/usr/include/freetype2 -I/usr/include/libpng12
|
2019-02-05 09:14:31 +00:00
|
|
|
$ pkg-config --libs gtk4
|
Remove ATK
To build a better world sometimes means having to tear the old one down.
-- Alexander Pierce, "Captain America: The Winter Soldier"
ATK served us well for nearly 20 years, but the world has changed, and
GTK has changed with it. Now ATK is mostly a hindrance towards improving
the accessibility stack:
- it maps to a very specific implementation, AT-SPI, which is Linux and
Unix specific
- it requires implementing the same functionality in three different
layers of the stack: AT-SPI, ATK, and GTK
- only GTK uses it; every other Linux and Unix toolkit and application
talks to AT-SPI directly, including assistive technologies
Sadly, we cannot incrementally port GTK to a new accessibility stack;
since ATK insulates us entirely from the underlying implementation, we
cannot replace it piecemeal. Instead, we're going to remove everything
and then incrementally build on a clean slate:
- add an "accessible" interface, implemented by GTK objects directly,
which describe the accessible role and state changes for every UI
element
- add an "assistive technology context" to proxy a native accessibility
API, and assign it to every widget
- implement the AT context depending on the platform
For more information, see: https://gitlab.gnome.org/GNOME/gtk/-/issues/2833
2020-06-16 15:41:59 +00:00
|
|
|
-pthread -lgtk-4 -lgdk-4 -lgio-2.0 -lpangoft2-1.0 -lgdk_pixbuf-2.0 -lpangocairo-1.0 -lcairo -lpango-1.0 -lfreetype -lfontconfig -lgobject-2.0 -lgmodule-2.0 -lgthread-2.0 -lrt -lglib-2.0
|
2020-05-24 04:04:36 +00:00
|
|
|
```
|
2001-09-08 04:39:53 +00:00
|
|
|
The simplest way to compile a program is to use the "backticks"
|
|
|
|
feature of the shell. If you enclose a command in backticks
|
2020-05-24 04:04:36 +00:00
|
|
|
(*not single quotes*), then its output will be substituted into the
|
|
|
|
command line before execution. So to compile a GTK Hello, World, you
|
|
|
|
would type the following:
|
|
|
|
```
|
2019-02-05 09:14:31 +00:00
|
|
|
$ cc `pkg-config --cflags gtk4` hello.c -o hello `pkg-config --libs gtk4`
|
2020-05-24 04:04:36 +00:00
|
|
|
```
|
2019-02-05 09:14:31 +00:00
|
|
|
Deprecated GTK functions are annotated to make the compiler
|
2011-11-10 03:08:43 +00:00
|
|
|
emit warnings when they are used (e.g. with gcc, you need to use
|
|
|
|
the -Wdeprecated-declarations option). If these warnings are
|
|
|
|
problematic, they can be turned off by defining the preprocessor
|
2012-02-27 12:56:29 +00:00
|
|
|
symbol %GDK_DISABLE_DEPRECATION_WARNINGS by using the commandline
|
2020-05-24 04:04:36 +00:00
|
|
|
option `-DGDK_DISABLE_DEPRECATION_WARNINGS`.
|
2011-11-10 03:08:43 +00:00
|
|
|
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK deprecation annotations are versioned; by defining the
|
2012-02-27 12:56:29 +00:00
|
|
|
macros %GDK_VERSION_MIN_REQUIRED and %GDK_VERSION_MAX_ALLOWED,
|
2019-02-05 09:14:31 +00:00
|
|
|
you can specify the range of GTK versions whose API you want
|
2012-02-27 12:56:29 +00:00
|
|
|
to use. APIs that were deprecated before or introduced after
|
|
|
|
this range will trigger compiler warnings.
|
|
|
|
|
2012-08-02 23:49:56 +00:00
|
|
|
Here is how you would compile hello.c if you want to allow it
|
2019-02-05 09:14:31 +00:00
|
|
|
to use symbols that were not deprecated in 4.2:
|
2020-05-24 04:04:36 +00:00
|
|
|
```
|
2020-06-04 06:37:22 +00:00
|
|
|
$ cc `pkg-config --cflags gtk4` -DGDK_VERSION_MIN_REQUIRED=GDK_VERSION_4_2 hello.c -o hello `pkg-config --libs gtk4`
|
2020-05-24 04:04:36 +00:00
|
|
|
```
|
2012-08-02 23:49:56 +00:00
|
|
|
|
|
|
|
And here is how you would compile hello.c if you don't want
|
2019-02-05 09:14:31 +00:00
|
|
|
it to use any symbols that were introduced after 4.2:
|
2020-05-24 04:04:36 +00:00
|
|
|
```
|
2019-02-05 09:14:31 +00:00
|
|
|
$ cc `pkg-config --cflags gtk4` -DGDK_VERSION_MAX_ALLOWED=GDK_VERSION_4_2 hello.c -o hello `pkg-config --libs gtk4`
|
2020-05-24 04:04:36 +00:00
|
|
|
```
|
2011-11-10 03:08:43 +00:00
|
|
|
The older deprecation mechanism of hiding deprecated interfaces
|
|
|
|
entirely from the compiler by using the preprocessor symbol
|
|
|
|
GTK_DISABLE_DEPRECATED is still used for deprecated macros,
|
|
|
|
enumeration values, etc. To detect uses of these in your code,
|
2020-05-24 04:04:36 +00:00
|
|
|
use the commandline option `-DGTK_DISABLE_DEPRECATED`.
|
2010-06-03 05:09:53 +00:00
|
|
|
There are similar symbols GDK_DISABLE_DEPRECATED,
|
2020-05-24 04:04:36 +00:00
|
|
|
GDK_PIXBUF_DISABLE_DEPRECATED and G_DISABLE_DEPRECATED for GDK,
|
|
|
|
GdkPixbuf and GLib.
|