diff options
author | Hans-Peter Nilsson <hp@bitrange.com> | 2000-11-23 11:30:46 +0000 |
---|---|---|
committer | Hans-Peter Nilsson <hp@gcc.gnu.org> | 2000-11-23 11:30:46 +0000 |
commit | d0c3e4f4987cc0e0e0a8880554593ebace217b00 (patch) | |
tree | 139f6032bf8661cbe50be0e498bf661949702035 | |
parent | 99a9c9460d48b857f4aca5667724e3dbf920a114 (diff) | |
download | gcc-d0c3e4f4987cc0e0e0a8880554593ebace217b00.zip gcc-d0c3e4f4987cc0e0e0a8880554593ebace217b00.tar.gz gcc-d0c3e4f4987cc0e0e0a8880554593ebace217b00.tar.bz2 |
os_defines.h: Include <features.h>.
* config/os/gnu-linux/bits/os_defines.h: Include <features.h>.
If not glibc 2.1 or higher, include <gnu/types.h> and define
__off64_t as __loff_t and #define __THROW as empty.
* libio/libio.h [__P]: Move __THROW and __PMT into their own
ifndef:s.
From-SVN: r37695
-rw-r--r-- | libstdc++-v3/ChangeLog | 9 | ||||
-rw-r--r-- | libstdc++-v3/config/os/gnu-linux/bits/os_defines.h | 19 | ||||
-rw-r--r-- | libstdc++-v3/libio/libio.h | 10 |
3 files changed, 36 insertions, 2 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index da45084..0f6c3fd 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,12 @@ +2000-11-23 Hans-Peter Nilsson <hp@bitrange.com> + + * config/os/gnu-linux/bits/os_defines.h: Include <features.h>. + If not glibc 2.1 or higher, include <gnu/types.h> and define + __off64_t as __loff_t and #define __THROW as empty. + + * libio/libio.h [__P]: Move __THROW and __PMT into their own + ifndef:s. + 2000-11-23 David Edelsohn <edelsohn@gnu.org> * porting.texi: Expand libtool information. diff --git a/libstdc++-v3/config/os/gnu-linux/bits/os_defines.h b/libstdc++-v3/config/os/gnu-linux/bits/os_defines.h index a98b348..3289d0c 100644 --- a/libstdc++-v3/config/os/gnu-linux/bits/os_defines.h +++ b/libstdc++-v3/config/os/gnu-linux/bits/os_defines.h @@ -40,6 +40,25 @@ // This keeps isanum, et al from being propagated as macros. #define __NO_CTYPE 1 +#include <features.h> + +#if !defined (__GLIBC__) || (__GLIBC__ == 2 && __GLIBC_MINOR__+0 == 0) + +// The types __off_t and __off64_t are not defined through <sys/types.h> +// as _G_config assumes. For libc5 and glibc 2.0 instead use +// <gnu/types.h> and the old name for __off64_t. +#include <gnu/types.h> +typedef __loff_t __off64_t; + +// These systems have declarations mismatching those in libio.h by +// omitting throw qualifiers. Cleanest way out is to not provide +// throw-qualifiers at all. Defining it as empty here will make libio.h +// not define it. +#undef __THROW +#define __THROW + +#endif /* not glibc 2.1 or higher. */ + # if defined __GLIBC__ && __GLIBC__ >= 2 // We must not see the optimized string functions GNU libc defines. # define __NO_STRING_INLINES diff --git a/libstdc++-v3/libio/libio.h b/libstdc++-v3/libio/libio.h index 6e5a383..68525a7 100644 --- a/libstdc++-v3/libio/libio.h +++ b/libstdc++-v3/libio/libio.h @@ -55,15 +55,21 @@ # endif /* __GNUC_VA_LIST */ #endif -#ifndef __P +#ifndef __THROW # ifdef __cplusplus # define __THROW throw () # else # define __THROW # endif +#endif /* not __THROW */ + +#ifndef __P # define __P(p) p __THROW +#endif /* not __P */ + +#ifndef __PMT # define __PMT(p) p -#endif /*!__P*/ +#endif /* not __PMT */ /* For backward compatibility */ #ifndef _PARAMS |