<type_traits>
include to consumers
When included inside an `extern "C"` block, this causes build failures that look something like: /usr/include/c++/10/type_traits:2930:3: error: template with C linkage 2930 | template<typename _Fn, typename... _Args> | ^~~~~~~~ ../../disas/arm-a64.cc:20:1: note: ‘extern "C"’ linkage started here 20 | extern "C" { | ^~~~~~~~~~ Commit 4273c43902a7e6b22cea0041436ee5715c93be76 made this opt in for projects which are defining `GLIB_VERSION_MIN_REQUIRED`, but the include of `<type_traits>` via `gmacros.h` was not included in this. If we move the include out to the places where `glib_typeof` is called, we can make it covered by this macro too, and save a few consumers from FTBFSing. That also means that, if you don't want to fix your use of the headers, and as long as this version is sufficient for you, a quick workaround is to define `GLIB_VERSION_MIN_REQUIRED` to `GLIB_VERSION_2_66` or lower. Suggested by Simon McVittie. Alternative to: https://gitlab.gnome.org/GNOME/glib/-/merge_requests/1935 Fixes: https://gitlab.gnome.org/GNOME/glib/-/issues/2331
GLib
GLib is the low-level core library that forms the basis for projects such as GTK and GNOME. It provides data structure handling for C, portability wrappers, and interfaces for such runtime functionality as an event loop, threads, dynamic loading, and an object system.
The official download locations are: https://download.gnome.org/sources/glib
The official web site is: https://www.gtk.org/
Installation
See the file 'INSTALL.in'
How to report bugs
Bugs should be reported to the GNOME issue tracking system. (https://gitlab.gnome.org/GNOME/glib/issues/new). You will need to create an account for yourself.
In the bug report please include:
- Information about your system. For instance:
- What operating system and version
- For Linux, what version of the C library
- And anything else you think is relevant.
- How to reproduce the bug.
- If you can reproduce it with one of the test programs that are built in the tests/ subdirectory, that will be most convenient. Otherwise, please include a short test program that exhibits the behavior. As a last resort, you can also provide a pointer to a larger piece of software that can be downloaded.
- If the bug was a crash, the exact text that was printed out when the crash occurred.
- Further information such as stack traces may be useful, but is not necessary.
Patches
Patches should also be submitted as merge requests to gitlab.gnome.org. If the patch fixes an existing issue, please refer to the issue in your commit message with the following notation (for issue 123): Closes: #123
Otherwise, create a new merge request that introduces the change, filing a separate issue is not required.