aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1996-05-26 19:19:51 +0000
committerRoland McGrath <roland@gnu.org>1996-05-26 19:19:51 +0000
commit59dd864187ee61b6f0bfd7abc85e2fea4b479cb7 (patch)
treee935d6f39bffe914520946c22a89e11180ba4745
parent27a110706b570569049e6702f99670e3064e53c1 (diff)
downloadglibc-59dd864187ee61b6f0bfd7abc85e2fea4b479cb7.tar.xz
glibc-59dd864187ee61b6f0bfd7abc85e2fea4b479cb7.zip
Sun May 26 15:15:08 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
* stdlib/ldiv.c: Deansideclized. Sun May 26 19:39:53 1996 Ulrich Drepper <drepper@cygnus.com> * intl/loadmsgcat.c (_nl_load_domain): Test correct variable after malloc. * string/Makefile (tester-ENV): New variable to suppress message translation in test. * string/tester.c: Add tests for strtok_r and strsep. * sysdeps/i386/i486/strcat.S: Correct some more 8bit operation <-> 32 bit operand conflicts. * sysdeps/i386/strsep.S: Wrapper around <sysdeps/i386/strtok.S> to produce strsep function. * sysdeps/i386/strtok.S: Optimized implementation of strtok function. * sysdeps/i386/strtok_r.S: Wrapper around <sysdeps/i386/strtok.S> to produce strtok_r function. * sysdeps/generic/strtok.c: Moved here from string/strtok.c. Corrected example in comment. * string/Makefile (routines): Add strtok_r. * sysdeps/generic/strtok_r.c: New file. Implement reentrant version of strtok_r. * string/string.h: Add prototype for strtok_r. * wcsmbs/wcstok.c: Handle illegal SAVE_PTR argument the same as in strtok_r. Sun May 26 13:28:23 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu> * time/tzset.c (__tzset): Ignore leading : in $TZ; always try tzfile first and fall back to 1003.1 syntax only if it fails. * time/Makefile (install-others): Also install posix/ZONE and right/ZONE for each ZONE in $(zonenames). (z.% rule): Generate rules for right/ZONE and posix/ZONE targets too, the difference begin leapseconds vs /dev/null as 3rd dep. For original ZONE targets use $(leapseconds), to be set in Makeconfig. (target-zone-flavor): New variable. (tzcompile): Use it to get the right -d for posix/ and right/ flavors. * Makeconfig (leapseconds): New variable. * mach/Machrules (%.udeps rule): Depend on Machrules. Emit deps for .uh and .__h files. (%.uh, %.__h rules): Don't depend on %.defs; use #include <$*.defs> instead. Sun May 26 01:06:47 1996 Ulrich Drepper <drepper@cygnus.com> * stdlib/Makefile (routines): Add llabs, lldiv. * stdlib/llabs.c: New file. Implementation of return absolute value of long long argument. * stdlib/lldiv.c: New file. Implementation of division with remainder of long long argument. * stdlib/stdlib.h [__USE_GNU] (lldiv_t): New type for lldiv function. Define prototypes for lldiv and llabs functions. * locale/C-collate.c: Initialize _NL_COLLATE_NRULES element. * stdlib/strtod.c: Replace wchar_t with wint_t. The later is really the type for a single wide character. * string/strxfrm.c (print_val): Define separate version for use as wcsxfrm. Here we don't need UTF8 encoding. * wcsmbs/wchar.h: gcc-2.7.2-960517 finally introduces wint_t in <stddef.h>. Use this value and only for older gcc version define in place. (uwchar_t): Remove definition. * wcsmbs/wcscmp.c, wcsmbs/wcscoll.c, wcsmbs/wcsncmp.c, wcsmbs/wcsxfrm.c, wcsmbs/wmemcmp.c: : Don't use uwchar_t as unsigned type. wint_t is intended for this. Sat May 25 14:10:19 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu> * sysdeps/unix/bsd/direntry.h: Use [1] instead of [0] for d_name to quiet -ansi -pedantic. * sysdeps/unix/common/direntry.h: Likewise. * login/Makefile (headers): Add lastlog.h. * login/lastlog.h: New file. * login/Makefile (CFLAGS): Don't append -D_THREAD_SAFE. * login/utmp.h [_REENTRANT || _THREAD_SAFE]: Replace this conditional with #ifdef __USE_REENTRANT. * features.h (__GNU_LIBRARY__): Set to 6. [_GNU_SOURCE] (_POSIX_SOURCE, _POSIX_C_SOURCE, _BSD_SOURCE, _SVID_SOURCE): Make sure they are all defined. * sysdeps/unix/sysv/linux/gnu/types.h: Instead of including <linux/posix_types.h>, define _LINUX_TYPES_DONT_EXPORT and then include <linux/types.h>. * resource/sys/resource.h: Remove trailing commas from enums. * sysdeps/generic/netinet/in.h: Remove trailing commas from enums. * sysdeps/unix/sysv/linux/netinet/in.h: Likewise.
-rw-r--r--ChangeLog107
-rw-r--r--Makeconfig10
-rwxr-xr-xconfig.guess4
-rw-r--r--features.h31
-rw-r--r--intl/loadmsgcat.c2
-rw-r--r--locale/C-collate.c5
-rw-r--r--login/Makefile4
-rw-r--r--login/lastlog.h4
-rw-r--r--login/utmp.h4
-rw-r--r--mach/Machrules15
-rw-r--r--resource/sys/resource.h6
-rw-r--r--stdlib/Makefile4
-rw-r--r--stdlib/llabs.c31
-rw-r--r--stdlib/lldiv.c57
-rw-r--r--stdlib/stdlib.h17
-rw-r--r--stdlib/strtod.c13
-rw-r--r--string/Makefile4
-rw-r--r--string/string.h5
-rw-r--r--string/strtok.c20
-rw-r--r--string/strxfrm.c54
-rw-r--r--string/tester.c96
-rw-r--r--sysdeps/generic/netinet/in.h6
-rw-r--r--sysdeps/generic/strtok.c73
-rw-r--r--sysdeps/generic/strtok_r.c74
-rw-r--r--sysdeps/i386/i486/strcat.S20
-rw-r--r--sysdeps/i386/strsep.S3
-rw-r--r--sysdeps/i386/strtok.S329
-rw-r--r--sysdeps/i386/strtok_r.S3
-rw-r--r--sysdeps/unix/bsd/direntry.h2
-rw-r--r--sysdeps/unix/common/direntry.h2
-rw-r--r--sysdeps/unix/sysv/linux/gnu/types.h6
-rw-r--r--sysdeps/unix/sysv/linux/netinet/in.h6
-rw-r--r--time/Makefile21
-rw-r--r--time/tzset.c15
-rw-r--r--wcsmbs/wchar.h25
-rw-r--r--wcsmbs/wcscmp.c14
-rw-r--r--wcsmbs/wcscoll.c2
-rw-r--r--wcsmbs/wcsncmp.c32
-rw-r--r--wcsmbs/wcstok.c30
-rw-r--r--wcsmbs/wcsxfrm.c4
-rw-r--r--wcsmbs/wmemcmp.c34
41 files changed, 1042 insertions, 152 deletions
diff --git a/ChangeLog b/ChangeLog
index 8aa5f1f171..99b53b65f0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,112 @@
+Sun May 26 15:15:08 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
+
+ * stdlib/ldiv.c: Deansideclized.
+
+Sun May 26 19:39:53 1996 Ulrich Drepper <drepper@cygnus.com>
+
+ * intl/loadmsgcat.c (_nl_load_domain): Test correct variable
+ after malloc.
+
+ * string/Makefile (tester-ENV): New variable to suppress message
+ translation in test.
+
+ * string/tester.c: Add tests for strtok_r and strsep.
+
+ * sysdeps/i386/i486/strcat.S: Correct some more 8bit operation
+ <-> 32 bit operand conflicts.
+
+ * sysdeps/i386/strsep.S: Wrapper around <sysdeps/i386/strtok.S>
+ to produce strsep function.
+ * sysdeps/i386/strtok.S: Optimized implementation of strtok
+ function.
+ * sysdeps/i386/strtok_r.S: Wrapper around <sysdeps/i386/strtok.S>
+ to produce strtok_r function.
+
+ * sysdeps/generic/strtok.c: Moved here from string/strtok.c.
+ Corrected example in comment.
+
+ * string/Makefile (routines): Add strtok_r.
+ * sysdeps/generic/strtok_r.c: New file. Implement reentrant version
+ of strtok_r.
+ * string/string.h: Add prototype for strtok_r.
+ * wcsmbs/wcstok.c: Handle illegal SAVE_PTR argument the same
+ as in strtok_r.
+
+Sun May 26 13:28:23 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
+
+ * time/tzset.c (__tzset): Ignore leading : in $TZ; always try tzfile
+ first and fall back to 1003.1 syntax only if it fails.
+
+ * time/Makefile (install-others): Also install posix/ZONE and
+ right/ZONE for each ZONE in $(zonenames).
+ (z.% rule): Generate rules for right/ZONE and posix/ZONE targets too,
+ the difference begin leapseconds vs /dev/null as 3rd dep. For
+ original ZONE targets use $(leapseconds), to be set in Makeconfig.
+ (target-zone-flavor): New variable.
+ (tzcompile): Use it to get the right -d for posix/ and right/ flavors.
+ * Makeconfig (leapseconds): New variable.
+
+ * mach/Machrules (%.udeps rule): Depend on Machrules.
+ Emit deps for .uh and .__h files.
+ (%.uh, %.__h rules): Don't depend on %.defs; use #include <$*.defs>
+ instead.
+
+Sun May 26 01:06:47 1996 Ulrich Drepper <drepper@cygnus.com>
+
+ * stdlib/Makefile (routines): Add llabs, lldiv.
+ * stdlib/llabs.c: New file. Implementation of return
+ absolute value of long long argument.
+ * stdlib/lldiv.c: New file. Implementation of division with remainder
+ of long long argument.
+ * stdlib/stdlib.h [__USE_GNU] (lldiv_t): New type for lldiv
+ function.
+ Define prototypes for lldiv and llabs functions.
+
+ * locale/C-collate.c: Initialize _NL_COLLATE_NRULES element.
+
+ * stdlib/strtod.c: Replace wchar_t with wint_t. The later is
+ really the type for a single wide character.
+
+ * string/strxfrm.c (print_val): Define separate version for
+ use as wcsxfrm. Here we don't need UTF8 encoding.
+
+ * wcsmbs/wchar.h: gcc-2.7.2-960517 finally introduces wint_t
+ in <stddef.h>. Use this value and only for older gcc version
+ define in place.
+ (uwchar_t): Remove definition.
+
+ * wcsmbs/wcscmp.c, wcsmbs/wcscoll.c, wcsmbs/wcsncmp.c,
+ wcsmbs/wcsxfrm.c, wcsmbs/wmemcmp.c: : Don't use uwchar_t as unsigned
+ type. wint_t is intended for this.
+
+Sat May 25 14:10:19 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
+
+ * sysdeps/unix/bsd/direntry.h: Use [1] instead of [0] for d_name to
+ quiet -ansi -pedantic.
+ * sysdeps/unix/common/direntry.h: Likewise.
+
+ * login/Makefile (headers): Add lastlog.h.
+ * login/lastlog.h: New file.
+
+ * login/Makefile (CFLAGS): Don't append -D_THREAD_SAFE.
+ * login/utmp.h [_REENTRANT || _THREAD_SAFE]: Replace this conditional
+ with #ifdef __USE_REENTRANT.
+
+ * features.h (__GNU_LIBRARY__): Set to 6.
+ [_GNU_SOURCE] (_POSIX_SOURCE, _POSIX_C_SOURCE, _BSD_SOURCE,
+ _SVID_SOURCE): Make sure they are all defined.
+
+ * sysdeps/unix/sysv/linux/gnu/types.h: Instead of including
+ <linux/posix_types.h>, define _LINUX_TYPES_DONT_EXPORT and then
+ include <linux/types.h>.
+
+ * resource/sys/resource.h: Remove trailing commas from enums.
+
Fri May 24 17:30:50 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu>
+ * sysdeps/generic/netinet/in.h: Remove trailing commas from enums.
+ * sysdeps/unix/sysv/linux/netinet/in.h: Likewise.
+
* login/getutline_r.c: Include string.h.
* Rules (static-only-routines): Restore the rule to make these .so's
diff --git a/Makeconfig b/Makeconfig
index d871789e28..d2bbbb2517 100644
--- a/Makeconfig
+++ b/Makeconfig
@@ -221,6 +221,16 @@ ifndef localtime-file
localtime-file = $(sysconfdir)/localtime
endif
+# What to use for leap second specifications in compiling the default
+# timezone files. Set this to `/dev/null' for no leap second handling as
+# 1003.1 requires, or to `leapseconds' for proper leap second handling.
+# Both zone flavors are always available as `posix/ZONE' and `right/ZONE'.
+# This variable determines the default: if it's `/dev/null',
+# ZONE==posix/ZONE; if it's `leapseconds', ZONE==right/ZONE.
+ifndef leapseconds
+leapseconds = /dev/null
+endif
+
# What timezone's DST rules should be used when a POSIX-style TZ
# environment variable doesn't specify any rules. For 1003.1 compliance
# this timezone must use rules that are as U.S. federal law defines DST.
diff --git a/config.guess b/config.guess
index d8c24708af..ab53d14633 100755
--- a/config.guess
+++ b/config.guess
@@ -137,7 +137,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
AViiON:dgux:*:*)
# DG/UX returns AViiON for all architectures
UNAME_PROCESSOR=`/usr/bin/uname -p`
- if [ $UNAME_PROCESSOR = mc88100 -o $UNAME_PROCESSOR = mc88100 ] ; then
+ if [ $UNAME_PROCESSOR = mc88100 -o $UNAME_PROCESSOR = mc88110 ] ; then
if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx \
-o ${TARGET_BINARY_INTERFACE}x = x ] ; then
echo m88k-dg-dgux${UNAME_RELEASE}
@@ -211,7 +211,7 @@ EOF
echo romp-ibm-bsd4.4
exit 0 ;;
ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC NetBSD and
- echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to
+ echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to
exit 0 ;; # report: romp-ibm BSD 4.3
*:BOSX:*:*)
echo rs6000-bull-bosx
diff --git a/features.h b/features.h
index de1fe008a2..4b50bea75a 100644
--- a/features.h
+++ b/features.h
@@ -50,7 +50,6 @@ Cambridge, MA 02139, USA. */
The macro `__GNU_LIBRARY__' is defined by this file unconditionally.
- All macros defined by this file are defined as 1.
All macros listed above as possibly being defined by this file are
explicitly undefined if they are not explicitly defined.
Feature-test macros that are not defined by the user or compiler
@@ -80,32 +79,42 @@ Cambridge, MA 02139, USA. */
#define __FAVOR_BSD 1
#endif
+/* If _GNU_SOURCE was defined by the user, turn on all the other features. */
+#ifdef _GNU_SOURCE
+/* If the user specifies some of the following without _GNU_SOURCE,
+ they are mutually exclusive. But they all default below to on,
+ so undefine them to get all the features turned on for _GNU_SOURCE. */
+#undef _POSIX_SOURCE
+#undef _POSIX_C_SOURCE
+#undef _BSD_SOURCE
+#undef _SVID_SOURCE
+#endif
/* If nothing (other than _GNU_SOURCE) is defined,
define _BSD_SOURCE and _SVID_SOURCE. */
-#if (!defined(__STRICT_ANSI__) && !defined(_POSIX_SOURCE) && \
- !defined(_POSIX_C_SOURCE) && !defined(_BSD_SOURCE) && \
- !defined(_SVID_SOURCE))
+#if (!defined (__STRICT_ANSI__) && !defined (_POSIX_SOURCE) && \
+ !defined (_POSIX_C_SOURCE) && !defined (_BSD_SOURCE) && \
+ !defined (_SVID_SOURCE))
#define _BSD_SOURCE 1
#define _SVID_SOURCE 1
#endif
/* If none of the ANSI/POSIX macros are defined, use POSIX.1 and POSIX.2. */
-#if (!defined(__STRICT_ANSI__) && !defined(_POSIX_SOURCE) && \
- !defined(_POSIX_C_SOURCE))
+#if (!defined (__STRICT_ANSI__) && !defined (_POSIX_SOURCE) && \
+ !defined (_POSIX_C_SOURCE))
#define _POSIX_SOURCE 1
#define _POSIX_C_SOURCE 2
#endif
-#if defined(_POSIX_SOURCE) || _POSIX_C_SOURCE >= 1
+#if defined (_POSIX_SOURCE) || _POSIX_C_SOURCE >= 1
#define __USE_POSIX 1
#endif
-#if defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE >= 2
+#if defined (_POSIX_C_SOURCE) && _POSIX_C_SOURCE >= 2
#define __USE_POSIX2 1
#endif
-#if defined(_BSD_SOURCE) || defined(_SVID_SOURCE)
+#if defined (_BSD_SOURCE) || defined (_SVID_SOURCE)
#define __USE_MISC 1
#endif
@@ -133,10 +142,10 @@ Cambridge, MA 02139, USA. */
the shared C library corresponding to this set of header files. */
#undef __GNU_LIBRARY__
-#define __GNU_LIBRARY__ 5
+#define __GNU_LIBRARY__ 6
-#if !defined(__GNUC__) || __GNUC__ < 2
+#if !defined (__GNUC__) || __GNUC__ < 2
/* In GCC version 2, (__extension__ EXPR) will not complain
about GCC extensions used in EXPR under -ansi or -pedantic. */
#define __extension__
diff --git a/intl/loadmsgcat.c b/intl/loadmsgcat.c
index 1daf72a09f..90eed87fd9 100644
--- a/intl/loadmsgcat.c
+++ b/intl/loadmsgcat.c
@@ -161,7 +161,7 @@ _nl_load_domain (domain_file)
domain_file->data
= (struct loaded_domain *) malloc (sizeof (struct loaded_domain *));
- if (domain->data == NULL)
+ if (domain_file->data == NULL)
return;
domain = (struct loaded_domain *) domain_file->data;
diff --git a/locale/C-collate.c b/locale/C-collate.c
index 3b89e4fbe8..9535d4faa1 100644
--- a/locale/C-collate.c
+++ b/locale/C-collate.c
@@ -23,5 +23,8 @@ const struct locale_data _nl_C_LC_COLLATE =
{
_nl_C_name,
NULL, 0, /* no file mapped */
- 0,
+ 1,
+ {
+ { word: 0 }
+ }
};
diff --git a/login/Makefile b/login/Makefile
index d3e6ac8aa5..99687433a0 100644
--- a/login/Makefile
+++ b/login/Makefile
@@ -22,7 +22,7 @@
subdir := login
-headers := utmp.h utmpbits.h
+headers := utmp.h utmpbits.h lastlog.h
routines := setutent endutent getutent getutid getutline pututline \
setutent_r endutent_r getutent_r getutid_r getutline_r \
@@ -34,5 +34,3 @@ libutil-routines:= login login_tty logout logwtmp pty
include ../Rules
-
-override CFLAGS += -D_THREAD_SAFE
diff --git a/login/lastlog.h b/login/lastlog.h
new file mode 100644
index 0000000000..f2443eb702
--- /dev/null
+++ b/login/lastlog.h
@@ -0,0 +1,4 @@
+/* This header file is used in 4.3BSD to define `struct lastlog',
+ which we define in <utmpbits.h>. */
+
+#include <utmp.h>
diff --git a/login/utmp.h b/login/utmp.h
index 2ba3da8e0b..b53e13a9e0 100644
--- a/login/utmp.h
+++ b/login/utmp.h
@@ -62,7 +62,7 @@ extern struct utmp *getutline __P ((__const struct utmp *__line));
extern struct utmp *pututline __P ((__const struct utmp *__utmp_ptr));
-#if defined(_REENTRANT) || defined(_THREAD_SAFE)
+#ifdef __USE_REENTRANT
/* Define the data structure needed for the reentrent version. */
struct utmp_data
{
@@ -89,7 +89,7 @@ extern int getutline_r __P ((__const struct utmp *__line, struct utmp **__utmp,
extern int pututline_r __P ((__const struct utmp *__utmp_ptr,
struct utmp_data *__utmp_data));
-#endif /* _REENTRENT || _THREAD_SAFE */
+#endif /* Use reentrant. */
__END_DECLS
diff --git a/mach/Machrules b/mach/Machrules
index 6f1c1948c5..bc0ee3783b 100644
--- a/mach/Machrules
+++ b/mach/Machrules
@@ -115,11 +115,12 @@ $(patsubst %,$(objpfx)%.ustamp,$(user-interfaces)): $(objpfx)%.ustamp