aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1995-04-08 19:09:39 +0000
committerRoland McGrath <roland@gnu.org>1995-04-08 19:09:39 +0000
commit883bc19b7c819edce146ca43b77991f7dcf0608b (patch)
tree33786f9e6d51680425f70d294b35237aa03f71da
parent8ab69eb33086a5cb11846414487fe22da5b93154 (diff)
downloadglibc-883bc19b7c819edce146ca43b77991f7dcf0608b.zip
glibc-883bc19b7c819edce146ca43b77991f7dcf0608b.tar.gz
glibc-883bc19b7c819edce146ca43b77991f7dcf0608b.tar.bz2
* locale/loadlocale.c (_nl_load_locale): Use MAP_INHERIT flag in
mmap call. * configure.in (os=freebsd*|bsdi*): Set base_os=unix/bsd/bsd4.4 for these too. * sysdeps/unix/sysv/tcsetattr.c: Use |= instead of = to properly set c_oflag value. * Makeconfig [! objpfx] (csu-objpfx): Add trailing slash. * locale/Makefile (categories): Uncomment collate. * locale/lc-collate.c: New file.
-rw-r--r--ChangeLog14
-rw-r--r--Makeconfig2
-rw-r--r--configure.in2
-rw-r--r--locale/Makefile2
-rw-r--r--locale/lc-collate.c22
-rw-r--r--locale/loadlocale.c7
-rw-r--r--sysdeps/unix/sysv/tcsetattr.c6
7 files changed, 48 insertions, 7 deletions
diff --git a/ChangeLog b/ChangeLog
index e347722..8111bc6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,19 @@
Sat Apr 8 00:40:59 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
+ * locale/loadlocale.c (_nl_load_locale): Use MAP_INHERIT flag in
+ mmap call.
+
+ * configure.in (os=freebsd*|bsdi*): Set base_os=unix/bsd/bsd4.4
+ for these too.
+
+ * sysdeps/unix/sysv/tcsetattr.c: Use |= instead of = to properly
+ set c_oflag value.
+
+ * Makeconfig [! objpfx] (csu-objpfx): Add trailing slash.
+
+ * locale/Makefile (categories): Uncomment collate.
+ * locale/lc-collate.c: New file.
+
* malloc/free.c (__malloc_safe_bcopy, memmove): Don't define
#ifdef emacs.
* malloc/realloc.c: Likewise.
diff --git a/Makeconfig b/Makeconfig
index 8cee8c0..1080646 100644
--- a/Makeconfig
+++ b/Makeconfig
@@ -260,7 +260,7 @@ endif
ifdef objpfx
csu-objpfx = $(objpfx)
else
-csu-objpfx = $(..)csu
+csu-objpfx = $(..)csu/
endif
ifndef LD
diff --git a/configure.in b/configure.in
index 4ebe404..7badd61 100644
--- a/configure.in
+++ b/configure.in
@@ -91,7 +91,7 @@ os="`echo $os | sed 's/\([0-9A-Z]\)[v_]\([0-9A-Z]\)/\1.\2/g'`"
case "$os" in
gnu*)
base_os=mach/hurd ;;
-netbsd* | 386bsd*)
+netbsd* | 386bsd* | freebsd* | bsdi*)
base_os=unix/bsd/bsd4.4 ;;
osf* | sunos* | ultrix* | newsos* | dynix* | *bsd*)
base_os=unix/bsd ;;
diff --git a/locale/Makefile b/locale/Makefile
index ec80014..87a6706 100644
--- a/locale/Makefile
+++ b/locale/Makefile
@@ -24,7 +24,7 @@ subdir := locale
headers := locale.h
distribute := localeinfo.h categories.def
routines := setlocale loadlocale localeconv
-categories := ctype messages monetary numeric time # collate
+categories := ctype messages monetary numeric time collate
aux = $(categories:%=lc-%) $(categories:%=C-%)
include ../Rules
diff --git a/locale/lc-collate.c b/locale/lc-collate.c
new file mode 100644
index 0000000..8684f23
--- /dev/null
+++ b/locale/lc-collate.c
@@ -0,0 +1,22 @@
+/* Define current locale data for LC_COLLATE category.
+Copyright (C) 1995 Free Software Foundation, Inc.
+This file is part of the GNU C Library.
+
+The GNU C Library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Library General Public License as
+published by the Free Software Foundation; either version 2 of the
+License, or (at your option) any later version.
+
+The GNU C Library is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+Library General Public License for more details.
+
+You should have received a copy of the GNU Library General Public
+License along with the GNU C Library; see the file COPYING.LIB. If
+not, write to the Free Software Foundation, Inc., 675 Mass Ave,
+Cambridge, MA 02139, USA. */
+
+#include "localeinfo.h"
+
+_NL_CURRENT_DEFINE (LC_COLLATE);
diff --git a/locale/loadlocale.c b/locale/loadlocale.c
index f3e8e4a..bc9102b 100644
--- a/locale/loadlocale.c
+++ b/locale/loadlocale.c
@@ -106,8 +106,13 @@ _nl_load_locale (int category, char **name)
/* Some systems do not have this flag; it is superfluous. */
#define MAP_FILE 0
#endif
+#ifndef MAP_INHERIT
+ /* Some systems might lack this; they lose. */
+#define MAP_INHERIT 0
+#endif
filedata = (void *) __mmap ((caddr_t) 0, st.st_size,
- PROT_READ, MAP_FILE|MAP_COPY, fd, 0);
+ PROT_READ, MAP_FILE|MAP_COPY|MAP_INHERIT,
+ fd, 0);
if (filedata == (void *) -1)
{
if (errno == ENOSYS)
diff --git a/sysdeps/unix/sysv/tcsetattr.c b/sysdeps/unix/sysv/tcsetattr.c
index 30e1b0b..230a258 100644
--- a/sysdeps/unix/sysv/tcsetattr.c
+++ b/sysdeps/unix/sysv/tcsetattr.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1992 Free Software Foundation, Inc.
+/* Copyright (C) 1992, 1995 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -123,9 +123,9 @@ DEFUN(tcsetattr, (fd, optional_actions, termios_p),
buf.c_oflag = 0;
if (termios_p->c_oflag & OPOST)
- buf.c_oflag = _SYSV_OPOST;
+ buf.c_oflag |= _SYSV_OPOST;
if (termios_p->c_oflag & ONLCR)
- buf.c_oflag = _SYSV_ONLCR;
+ buf.c_oflag |= _SYSV_ONLCR;
/* So far, buf.c_cflag contains the speed in CBAUD. */
if (termios_p->c_cflag & CSTOPB)