mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-14 00:06:24 +01:00
docs: Soft-deprecate gsize in favour of standard size_t
We have chosen the underlying type that implements gsize to be the same size as the standard C89 size_t (the top-level meson.build sets this up). Unfortunately, we cannot guarantee that GLib and the C toolchain have chosen the *same* fixed-size type: for example, on a typical ILP32 platform like 32-bit Windows or Linux, each of gsize and size_t can either be int or long, while on a LP64 platform like 64-bit Linux, each could either be long or long long. meson.build tries to choose the same type to reduce compiler warnings, but it can only do this if the compiler implements `-Werror`. The in-memory representation is the same either way, but the choice of underlying type matters when building printf format strings or issuing compiler warnings, and can affect the C++ ABI of GLib-based software. As a result, we can't just typedef gsize as size_t. I've expanded the doc-comment to say a bit more about the implications of the different types here, so that I can point to it from the doc-comments of other types without repeating myself too much. Helps: https://gitlab.gnome.org/GNOME/glib/-/issues/1484 Signed-off-by: Simon McVittie <smcv@collabora.com>
This commit is contained in:
parent
d0b3021f7f
commit
9f19eb454b
40
glib/docs.c
40
glib/docs.c
@ -617,7 +617,11 @@
|
|||||||
* An unsigned integer type of the result of the `sizeof` operator,
|
* An unsigned integer type of the result of the `sizeof` operator,
|
||||||
* corresponding to the `size_t` type defined in C99.
|
* corresponding to the `size_t` type defined in C99.
|
||||||
*
|
*
|
||||||
* It is usually 32 bit wide on a 32-bit platform and 64 bit wide
|
* The standard `size_t` type should be preferred in new code, unless
|
||||||
|
* consistency with pre-existing APIs requires `gsize`
|
||||||
|
* (see below for more details).
|
||||||
|
*
|
||||||
|
* `gsize` is usually 32 bit wide on a 32-bit platform and 64 bit wide
|
||||||
* on a 64-bit platform. Values of this type can range from 0 to
|
* on a 64-bit platform. Values of this type can range from 0 to
|
||||||
* %G_MAXSIZE.
|
* %G_MAXSIZE.
|
||||||
*
|
*
|
||||||
@ -632,6 +636,27 @@
|
|||||||
*
|
*
|
||||||
* To print or scan values of this type, use
|
* To print or scan values of this type, use
|
||||||
* %G_GSIZE_MODIFIER and/or %G_GSIZE_FORMAT.
|
* %G_GSIZE_MODIFIER and/or %G_GSIZE_FORMAT.
|
||||||
|
*
|
||||||
|
* Note that on platforms where more than one standard integer type is
|
||||||
|
* the same size, `size_t` and `gsize` are always the same size but are
|
||||||
|
* not necessarily implemented by the same standard integer type.
|
||||||
|
* For example, on an ILP32 platform where `int`, `long` and pointers
|
||||||
|
* are all 32-bit, `size_t` might be `unsigned long` while `gsize`
|
||||||
|
* might be `unsigned int`.
|
||||||
|
* This can result in compiler warnings or unexpected C++ name-mangling
|
||||||
|
* if the two types are used inconsistently.
|
||||||
|
*
|
||||||
|
* As a result, changing a type from `gsize` to `size_t` in existing APIs
|
||||||
|
* might be an incompatible API or ABI change, especially if C++
|
||||||
|
* is involved. The safe option is to leave existing APIs using the same type
|
||||||
|
* that they have historically used, and only use the standard C types in
|
||||||
|
* new APIs.
|
||||||
|
*
|
||||||
|
* Similar considerations apply to all the fixed-size types
|
||||||
|
* (#gint8, #guint8, #gint16, #guint16, #gint32, #guint32, #gint64,
|
||||||
|
* #guint64 and #goffset), as well as #gintptr and #guintptr.
|
||||||
|
* Types that are 32 bits or larger are particularly likely to be
|
||||||
|
* affected by this.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -639,6 +664,9 @@
|
|||||||
*
|
*
|
||||||
* The maximum value which can be held in a #gsize.
|
* The maximum value which can be held in a #gsize.
|
||||||
*
|
*
|
||||||
|
* This is the same as standard C `SIZE_MAX` (available since C99),
|
||||||
|
* which should be preferred in new code.
|
||||||
|
*
|
||||||
* Since: 2.4
|
* Since: 2.4
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -649,6 +677,11 @@
|
|||||||
* for scanning and printing values of type #gsize. It
|
* for scanning and printing values of type #gsize. It
|
||||||
* is a string literal.
|
* is a string literal.
|
||||||
*
|
*
|
||||||
|
* Note that this is not necessarily the correct modifier to scan or
|
||||||
|
* print a `size_t`, even though the in-memory representation is the
|
||||||
|
* same. The Standard C `"z"` modifier should be used for `size_t`,
|
||||||
|
* assuming a C99-compliant `printf` implementation is available.
|
||||||
|
*
|
||||||
* Since: 2.6
|
* Since: 2.6
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -658,6 +691,11 @@
|
|||||||
* This is the platform dependent conversion specifier for scanning
|
* This is the platform dependent conversion specifier for scanning
|
||||||
* and printing values of type #gsize. See also %G_GINT16_FORMAT.
|
* and printing values of type #gsize. See also %G_GINT16_FORMAT.
|
||||||
*
|
*
|
||||||
|
* Note that this is not necessarily the correct format to scan or
|
||||||
|
* print a `size_t`, even though the in-memory representation is the
|
||||||
|
* same. The standard C `"zu"` format should be used for `size_t`,
|
||||||
|
* assuming a C99-compliant `printf` implementation is available.
|
||||||
|
*
|
||||||
* Since: 2.6
|
* Since: 2.6
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user