diff options
author | Zack Weinberg <zackw@panix.com> | 2017-12-23 00:06:03 -0500 |
---|---|---|
committer | Zack Weinberg <zackw@panix.com> | 2017-12-24 09:03:28 -0800 |
commit | 48a8f8328122ab8d06b7333cb87be46feeaf7cca (patch) | |
tree | e61a3b567c0c78787c06a38dfe0fce7ccb749f28 /scripts | |
parent | a47ad79afa454192224214a3db2499de12baf93e (diff) | |
download | glibc-48a8f8328122ab8d06b7333cb87be46feeaf7cca.zip glibc-48a8f8328122ab8d06b7333cb87be46feeaf7cca.tar.gz glibc-48a8f8328122ab8d06b7333cb87be46feeaf7cca.tar.bz2 |
Deprecate external use of libio.h and _G_config.h.
libio.h was originally the header for a set of supported GNU
extensions, but they have not been maintained as such in many years,
they are now standing in the way of improvements to stdio, and we
don't think there are any remaining external users. _G_config.h was
never intended for public use, but predates the bits convention.
Move both of these headers into the bits directory and provide stubs
at top level which issue deprecation warnings.
The contents of (bits/)libio.h and (bits/)_G_config.h are still
exposed to external software via stdio.h; changing that requires more
complex surgery than I have time to attempt right now.
* libio/libio.h, libio/_G_config.h: New stub headers which issue a
deprecation warning and then include <bits/libio.h>, <bits/_G_config.h>
respectively.
* libio/libio.h: Rename the original version of this file to
libio/bits/libio.h. Error out if not included by stdio.h or the
stub libio.h.
* include/libio.h: Move to include/bits. Forward to libio/bits/libio.h.
* sysdeps/generic/_G_config.h: Move to top-level bits/. Error out
if not included by bits/libio.h or the stub _G_config.h.
* sysdeps/unix/sysv/linux/_G_config.h: Move to
sysdeps/unix/sysv/linux/bits. Error out if not included by
bits/libio.h or the stub _G_config.h.
* libio/stdio.h: Include bits/libio.h, not libio.h.
* libio/Makefile: Install bits/libio.h and bits/_G_config.h as
well as libio.h and _G_config.h.
* csu/init.c, libio/fmemopen.c, libio/iolibio.h, libio/oldfmemopen.c
* libio/strfile.h, stdio-common/vfscanf.c
* sysdeps/pthread/flockfile.c, sysdeps/pthread/funlockfile.c
Include stdio.h, not _G_config.h nor libio.h.
* libio/iofgetpos.c: Also rename fgetpos64 out of the way.
* libio/iofsetpos.c: Also rename fsetpos64 out of the way.
* scripts/check-installed-headers.sh: Skip libio.h and _G_config.h.
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/check-installed-headers.sh | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/scripts/check-installed-headers.sh b/scripts/check-installed-headers.sh index 4cbef0e..a5e37c3 100644 --- a/scripts/check-installed-headers.sh +++ b/scripts/check-installed-headers.sh @@ -84,6 +84,11 @@ for header in "$@"; do (sys/elf.h) continue;; + # libio.h and _G_config.h are deprecation stubs containing #warnings + # to use stdio.h instead. + (libio.h | _G_config.h) + continue;; + # sys/sysctl.h is unsupported for x32. (sys/sysctl.h) case "$is_x32" in |