* locale/loadlocale.c (_nl_load_locale): Use MAP_INHERIT flag in
authorRoland McGrath <roland@gnu.org>
Sat, 8 Apr 1995 19:09:39 +0000 (19:09 +0000)
committerRoland McGrath <roland@gnu.org>
Sat, 8 Apr 1995 19:09:39 +0000 (19:09 +0000)
  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.

ChangeLog
Makeconfig
configure.in
locale/Makefile
locale/lc-collate.c [new file with mode: 0644]
locale/loadlocale.c
sysdeps/unix/sysv/tcsetattr.c

index e347722..8111bc6 100644 (file)
--- 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.
index 8cee8c0..1080646 100644 (file)
@@ -260,7 +260,7 @@ endif
 ifdef objpfx
 csu-objpfx = $(objpfx)
 else
-csu-objpfx = $(..)csu
+csu-objpfx = $(..)csu/
 endif
 
 ifndef LD
index 4ebe404..7badd61 100644 (file)
@@ -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 ;;
index ec80014..87a6706 100644 (file)
@@ -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 (file)
index 0000000..8684f23
--- /dev/null
@@ -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);
index f3e8e4a..bc9102b 100644 (file)
@@ -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)
index 30e1b0b..230a258 100644 (file)
@@ -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)