update from main archvie 961013
Sun Oct 13 22:52:56 1996 Ulrich Drepper <drepper@cygnus.com> * shlib-versions: Add version number/name for ld.so. * Makeconfig: Move definition of rtld-installed-name after inclusion of soversions.mk. Don't add . before version number from shlib-versions file when when name does not start with digit. This is needed for ld.so. Sat Oct 12 20:31:58 1996 Richard Henderson <rth@tamu.edu> * libio/iogets.c: Warn when gets used. * stdio/gets.c: Strengthen the warning. Sat Oct 12 23:10:43 1996 Ulrich Drepper <drepper@cygnus.com> * libio/Makefile [_LIBC_REENTRANT] (routines): Add peekc. * libio/libio.h: Add prototypes for _IO_getc, _IO_putc, _IO_feof, _IO_ferror, _IO_peekc_locked, and _IO_ftrylockfile. Remove prototypes for _IO_getc_locked and _IO_putc_locked. [_IO_MTSAFE_IO]: Add weak aliases for _IO_flockfile and _IO_funlockfile. [! _IO_MTSAFE_IO]: Define _IO_ftrylockfile as empty. Define _IO_getc, _IO_peekc, _IO_putc, _IO_feof, _IO_ferror to appropriate values according to __USE_REENTRANT. * libio/stdio.h: Add prototype for ftrylockfile. [!_LIBC]: Define getc_locked, getchar_locked, putchar_locked, getc, getchar, putc, and putchar using _IO_* names. * libio/feof.c: Rename to _IO_feof and make feof weak alias. * libio/ferror.c: Rename to _IO_ferror and make ferror weak alias. * libio/getc.c: Rename to _IO_getc and make getc weak alias. * libio/putc.c: Rename to _IO_putc and make putc weak alias. * libio/putc_u.c: Don't define alias _IO_putc_unlocked. * libio/peekc.c: New file. * stdio-common/vfprintf.c (vfprintf): Unconditionally call __flockfile. * sysdeps/stub/locfile.c [USE_IN_LIBIO]: Also define _IO_* names. * crypt/Makefile (tests): Add md5test and md5c-test. * crypt/md5-crypt.c: Correct various error. Now md5_process_bytes is called, the buffer limit is honoured and a loop in a inner loop is corrected. * crypt/md5.h (struct md5_ctx): Add new fields. Add prototypes for new functions. * crypt/md5.c (md5_init_ctx): Initialize new fields. (md5_finish_ctx): New function. Like md5_read_ctx but before perform correct finalization. (md5_process_bytes): New function. Similar to md5_proces_block, but does not require input size to be multiple of 64. (md5_stream): Rewrite using md5_process_bytes and md5_finish_ctx. (md5_buffer): Likewise. (md5_process_block): Count number of bytes. * crypt/md5test.c: New file. Test program for MD5 functions. * crypt/md5c-test.c: New file: Test program for MD5 crypt function. * po/fr.po: Update. * time/strptime.c: Recognize %s, %u, %g, and %G format. * posix/getopt.c: Add some more casts and initializations to prevent warnings. Sat Oct 12 16:15:29 1996 Ulrich Drepper <drepper@cygnus.com> * sysdeps/unix/sysv/linux/speed.c (speeds): Removed. We provide an extra function to provide this functionality. (cfgetospeed): Simply return masked value. (cfsetospeed): Don't use speeds array and so we can simply test the value of SPEED for illegal values. * termios/cfsetspeed.c: Rewrite. We convert here between the real values and the B* constants. Changes suggested by Uwe Ohse <uwe@tirka.gun.de>. Fri Oct 11 21:45:34 1996 Andreas Jaeger <aj@arthur.pfalz.de> * locale/programs/xstrdup.c: Define prototypes. * locale/programs/xmalloc.c: Likewise. * stdio-common/xbug.c (main): Change definition to avoid warning. Fri Oct 11 23:36:31 1996 Miles Bader <miles@gnu.ai.mit.edu> * db/hash/hash.c (__hash_open): Correctly test for a read-write db.
This commit is contained in:
parent
31c95122ee
commit
d41c6f6161
86
ChangeLog
86
ChangeLog
|
@ -1,3 +1,89 @@
|
||||||
|
Sun Oct 13 22:52:56 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* shlib-versions: Add version number/name for ld.so.
|
||||||
|
* Makeconfig: Move definition of rtld-installed-name after
|
||||||
|
inclusion of soversions.mk.
|
||||||
|
Don't add . before version number from shlib-versions file when
|
||||||
|
when name does not start with digit. This is needed for ld.so.
|
||||||
|
|
||||||
|
Sat Oct 12 20:31:58 1996 Richard Henderson <rth@tamu.edu>
|
||||||
|
|
||||||
|
* libio/iogets.c: Warn when gets used.
|
||||||
|
* stdio/gets.c: Strengthen the warning.
|
||||||
|
|
||||||
|
Sat Oct 12 23:10:43 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* libio/Makefile [_LIBC_REENTRANT] (routines): Add peekc.
|
||||||
|
* libio/libio.h: Add prototypes for _IO_getc, _IO_putc, _IO_feof,
|
||||||
|
_IO_ferror, _IO_peekc_locked, and _IO_ftrylockfile.
|
||||||
|
Remove prototypes for _IO_getc_locked and _IO_putc_locked.
|
||||||
|
[_IO_MTSAFE_IO]: Add weak aliases for _IO_flockfile and
|
||||||
|
_IO_funlockfile.
|
||||||
|
[! _IO_MTSAFE_IO]: Define _IO_ftrylockfile as empty.
|
||||||
|
Define _IO_getc, _IO_peekc, _IO_putc, _IO_feof, _IO_ferror to
|
||||||
|
appropriate values according to __USE_REENTRANT.
|
||||||
|
* libio/stdio.h: Add prototype for ftrylockfile.
|
||||||
|
[!_LIBC]: Define getc_locked, getchar_locked, putchar_locked,
|
||||||
|
getc, getchar, putc, and putchar using _IO_* names.
|
||||||
|
* libio/feof.c: Rename to _IO_feof and make feof weak alias.
|
||||||
|
* libio/ferror.c: Rename to _IO_ferror and make ferror weak alias.
|
||||||
|
* libio/getc.c: Rename to _IO_getc and make getc weak alias.
|
||||||
|
* libio/putc.c: Rename to _IO_putc and make putc weak alias.
|
||||||
|
* libio/putc_u.c: Don't define alias _IO_putc_unlocked.
|
||||||
|
* libio/peekc.c: New file.
|
||||||
|
|
||||||
|
* stdio-common/vfprintf.c (vfprintf): Unconditionally call
|
||||||
|
__flockfile.
|
||||||
|
|
||||||
|
* sysdeps/stub/locfile.c [USE_IN_LIBIO]: Also define _IO_* names.
|
||||||
|
|
||||||
|
* crypt/Makefile (tests): Add md5test and md5c-test.
|
||||||
|
* crypt/md5-crypt.c: Correct various error. Now md5_process_bytes
|
||||||
|
is called, the buffer limit is honoured and a loop in a inner
|
||||||
|
loop is corrected.
|
||||||
|
* crypt/md5.h (struct md5_ctx): Add new fields.
|
||||||
|
Add prototypes for new functions.
|
||||||
|
* crypt/md5.c (md5_init_ctx): Initialize new fields.
|
||||||
|
(md5_finish_ctx): New function. Like md5_read_ctx but before
|
||||||
|
perform correct finalization.
|
||||||
|
(md5_process_bytes): New function. Similar to md5_proces_block,
|
||||||
|
but does not require input size to be multiple of 64.
|
||||||
|
(md5_stream): Rewrite using md5_process_bytes and md5_finish_ctx.
|
||||||
|
(md5_buffer): Likewise.
|
||||||
|
(md5_process_block): Count number of bytes.
|
||||||
|
* crypt/md5test.c: New file. Test program for MD5 functions.
|
||||||
|
* crypt/md5c-test.c: New file: Test program for MD5 crypt
|
||||||
|
function.
|
||||||
|
|
||||||
|
* po/fr.po: Update.
|
||||||
|
|
||||||
|
* time/strptime.c: Recognize %s, %u, %g, and %G format.
|
||||||
|
|
||||||
|
* posix/getopt.c: Add some more casts and initializations to
|
||||||
|
prevent warnings.
|
||||||
|
|
||||||
|
Sat Oct 12 16:15:29 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* sysdeps/unix/sysv/linux/speed.c (speeds): Removed. We provide
|
||||||
|
an extra function to provide this functionality.
|
||||||
|
(cfgetospeed): Simply return masked value.
|
||||||
|
(cfsetospeed): Don't use speeds array and so we can simply test
|
||||||
|
the value of SPEED for illegal values.
|
||||||
|
* termios/cfsetspeed.c: Rewrite. We convert here between the
|
||||||
|
real values and the B* constants.
|
||||||
|
Changes suggested by Uwe Ohse <uwe@tirka.gun.de>.
|
||||||
|
|
||||||
|
Fri Oct 11 21:45:34 1996 Andreas Jaeger <aj@arthur.pfalz.de>
|
||||||
|
|
||||||
|
* locale/programs/xstrdup.c: Define prototypes.
|
||||||
|
* locale/programs/xmalloc.c: Likewise.
|
||||||
|
|
||||||
|
* stdio-common/xbug.c (main): Change definition to avoid warning.
|
||||||
|
|
||||||
|
Fri Oct 11 23:36:31 1996 Miles Bader <miles@gnu.ai.mit.edu>
|
||||||
|
|
||||||
|
* db/hash/hash.c (__hash_open): Correctly test for a read-write db.
|
||||||
|
|
||||||
Fri Oct 11 19:13:34 1996 Ulrich Drepper <drepper@cygnus.com>
|
Fri Oct 11 19:13:34 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
* locale/Makefile (CPPFLAGS): Set CHARMAP_PATH to
|
* locale/Makefile (CPPFLAGS): Set CHARMAP_PATH to
|
||||||
|
|
27
Makeconfig
27
Makeconfig
|
@ -353,15 +353,6 @@ csu-objpfx = $(common-objpfx)csu/
|
||||||
elf-objpfx = $(common-objpfx)elf/
|
elf-objpfx = $(common-objpfx)elf/
|
||||||
db-objpfx = $(common-objpfx)db/
|
db-objpfx = $(common-objpfx)db/
|
||||||
|
|
||||||
ifeq (yes,$(build-shared))
|
|
||||||
# The name under which the run-time dynamic linker is installed.
|
|
||||||
# We are currently going for the convention that `/lib/ld.so.1'
|
|
||||||
# names the SVR4/ELF ABI-compliant dynamic linker.
|
|
||||||
ifndef rtld-installed-name
|
|
||||||
rtld-installed-name = ld.so.1
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
# How to run a program we just linked with our library.
|
# How to run a program we just linked with our library.
|
||||||
# The program binary is assumed to be $(word 2,$^).
|
# The program binary is assumed to be $(word 2,$^).
|
||||||
built-program-file = $(dir $(word 2,$^))$(notdir $(word 2,$^))
|
built-program-file = $(dir $(word 2,$^))$(notdir $(word 2,$^))
|
||||||
|
@ -539,7 +530,11 @@ $(common-objpfx)soversions.mk: $(..)shlib-versions $(..)Makeconfig \
|
||||||
lib=`echo $$v | sed 's/=.*$$//'`; \
|
lib=`echo $$v | sed 's/=.*$$//'`; \
|
||||||
if eval "test -z \"\$$vers_lib$$lib\""; then \
|
if eval "test -z \"\$$vers_lib$$lib\""; then \
|
||||||
eval vers_lib$${lib}=yes; \
|
eval vers_lib$${lib}=yes; \
|
||||||
echo $$v | sed "s/^.*=/$$lib.so-version=./"; \
|
number=`echo $$v | sed "s/^.*=//"`; \
|
||||||
|
case $$number in \
|
||||||
|
[0-9]*) echo "$$lib.so-version=.$$number";; \
|
||||||
|
*) echo "$$lib.so-version=$$number";; \
|
||||||
|
esac; \
|
||||||
fi; \
|
fi; \
|
||||||
done ;; esac; done; \
|
done ;; esac; done; \
|
||||||
done;) > $@T; exit 0
|
done;) > $@T; exit 0
|
||||||
|
@ -548,6 +543,18 @@ $(common-objpfx)soversions.mk: $(..)shlib-versions $(..)Makeconfig \
|
||||||
# Get $(version) defined with the release version number.
|
# Get $(version) defined with the release version number.
|
||||||
-include $(common-objpfx)version.mk
|
-include $(common-objpfx)version.mk
|
||||||
|
|
||||||
|
|
||||||
|
# The name under which the run-time dynamic linker is installed.
|
||||||
|
# We are currently going for the convention that `/lib/ld.so.1'
|
||||||
|
# names the SVR4/ELF ABI-compliant dynamic linker.
|
||||||
|
ifndef rtld-installed-name
|
||||||
|
ifdef ld.so-version
|
||||||
|
rtld-installed-name = $(ld.so-version)
|
||||||
|
else
|
||||||
|
rtld-installed-name = ld.so.1
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
endif # build-shared
|
endif # build-shared
|
||||||
|
|
||||||
endif # Makeconfig not yet included
|
endif # Makeconfig not yet included
|
||||||
|
|
24
PROJECTS
24
PROJECTS
|
@ -1,6 +1,6 @@
|
||||||
Open jobs for finishing GNU libc:
|
Open jobs for finishing GNU libc:
|
||||||
---------------------------------
|
---------------------------------
|
||||||
Status: August 1996
|
Status: October 1996
|
||||||
|
|
||||||
If you have time and talent to take over any of the jobs below please
|
If you have time and talent to take over any of the jobs below please
|
||||||
contact <bug-glibc@prep.ai.mit.edu>
|
contact <bug-glibc@prep.ai.mit.edu>
|
||||||
|
@ -26,7 +26,7 @@ contact <bug-glibc@prep.ai.mit.edu>
|
||||||
for the current status (of course better use a mirror of prep).
|
for the current status (of course better use a mirror of prep).
|
||||||
|
|
||||||
|
|
||||||
[ 4] Write wordexp() function; this is described in POSIX.2, The
|
[ 4] Write wordexp() function; this is described in POSIX.2, the
|
||||||
header <wordexp.h> already exists.
|
header <wordexp.h> already exists.
|
||||||
|
|
||||||
Implementation idea: use some functions from bash.
|
Implementation idea: use some functions from bash.
|
||||||
|
@ -51,9 +51,9 @@ contact <bug-glibc@prep.ai.mit.edu>
|
||||||
Henry Spencer, University of Toronto
|
Henry Spencer, University of Toronto
|
||||||
Usenix Winter '92, pp. 419--428
|
Usenix Winter '92, pp. 419--428
|
||||||
|
|
||||||
or just ask. Currently mostly i?86 optimized versions exist.
|
or just ask. Currently mostly i?86 and Alpha optimized versions
|
||||||
Alpha versions are on their way, so please ask before working
|
exist. Please ask before working on this to avoid duplicate
|
||||||
on this.
|
work.
|
||||||
|
|
||||||
|
|
||||||
[ 7] Write nftw() function. Perhaps it might be good to reimplement the
|
[ 7] Write nftw() function. Perhaps it might be good to reimplement the
|
||||||
|
@ -67,7 +67,11 @@ contact <bug-glibc@prep.ai.mit.edu>
|
||||||
There is a public domain version but using this would cause problems
|
There is a public domain version but using this would cause problems
|
||||||
with the assignment.
|
with the assignment.
|
||||||
|
|
||||||
[ 9] Extend regex and/or rx to work with wide characters.
|
|
||||||
|
[ 9] Extend regex and/or rx to work with wide characters and complete
|
||||||
|
implementation of character class and collation class handling.
|
||||||
|
|
||||||
|
It is planed to do a complete rewrite.
|
||||||
|
|
||||||
|
|
||||||
[10] Add mmap() support to malloc().
|
[10] Add mmap() support to malloc().
|
||||||
|
@ -82,7 +86,15 @@ contact <bug-glibc@prep.ai.mit.edu>
|
||||||
Please contact bug-glibc@prep.ai.mit.edu before starting to avoid
|
Please contact bug-glibc@prep.ai.mit.edu before starting to avoid
|
||||||
duplicated work.
|
duplicated work.
|
||||||
|
|
||||||
|
|
||||||
[11] Write access function for netmasks, bootparams, publickey, automount,
|
[11] Write access function for netmasks, bootparams, publickey, automount,
|
||||||
and aliases databases for nss_files and nss_db module.
|
and aliases databases for nss_files and nss_db module.
|
||||||
The functions should be embedded in the nss scheme. This is not
|
The functions should be embedded in the nss scheme. This is not
|
||||||
hard and not all services must be supported at once.
|
hard and not all services must be supported at once.
|
||||||
|
|
||||||
|
|
||||||
|
[12] Rewrite utmp/wtmp functions to use database functions. This is much
|
||||||
|
better than the normal flat file format.
|
||||||
|
|
||||||
|
Please contact bug-glibc@prep.ai.mit.edu before starting to avoid
|
||||||
|
duplicated work.
|
||||||
|
|
|
@ -42,7 +42,7 @@ include ../Makeconfig
|
||||||
|
|
||||||
ifneq (,$(filter %REENTRANT, $(defines)))
|
ifneq (,$(filter %REENTRANT, $(defines)))
|
||||||
routines += clearerr_u feof_u ferror_u fputc_u getc_u getchar_u \
|
routines += clearerr_u feof_u ferror_u fputc_u getc_u getchar_u \
|
||||||
iofflush_u putc_u putchar_u
|
iofflush_u putc_u putchar_u peekc
|
||||||
|
|
||||||
CPPFLAGS += -D_IO_MTSAFE_IO
|
CPPFLAGS += -D_IO_MTSAFE_IO
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -25,7 +25,7 @@ the executable file might be covered by the GNU General Public License. */
|
||||||
#include "stdio.h"
|
#include "stdio.h"
|
||||||
|
|
||||||
int
|
int
|
||||||
feof (fp)
|
_IO_feof (fp)
|
||||||
_IO_FILE* fp;
|
_IO_FILE* fp;
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
|
@ -35,11 +35,12 @@ feof (fp)
|
||||||
_IO_funlockfile (fp);
|
_IO_funlockfile (fp);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
weak_alias (_IO_feof, feof)
|
||||||
|
|
||||||
#ifdef _IO_MTSAFE_IO
|
#ifdef _IO_MTSAFE_IO
|
||||||
/* The feof implementation for libio does not require locking because
|
/* The feof implementation for libio does not require locking because
|
||||||
it only accesses once a single variable and this is already atomic
|
it only accesses once a single variable and this is already atomic
|
||||||
(at least at thread level). */
|
(at least at thread level). */
|
||||||
|
|
||||||
weak_alias (feof, feof_locked)
|
weak_alias (_IO_feof, feof_locked)
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -25,7 +25,7 @@ the executable file might be covered by the GNU General Public License. */
|
||||||
#include "stdio.h"
|
#include "stdio.h"
|
||||||
|
|
||||||
int
|
int
|
||||||
ferror (fp)
|
_IO_ferror (fp)
|
||||||
_IO_FILE* fp;
|
_IO_FILE* fp;
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
|
@ -35,6 +35,7 @@ ferror (fp)
|
||||||
_IO_funlockfile (fp);
|
_IO_funlockfile (fp);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
weak_alias (_IO_ferror, ferror)
|
||||||
|
|
||||||
#ifdef _IO_MTSAFE_IO
|
#ifdef _IO_MTSAFE_IO
|
||||||
|
|
||||||
|
|
|
@ -25,10 +25,10 @@ the executable file might be covered by the GNU General Public License. */
|
||||||
#include "libioP.h"
|
#include "libioP.h"
|
||||||
#include "stdio.h"
|
#include "stdio.h"
|
||||||
|
|
||||||
#undef getc
|
#undef _IO_getc
|
||||||
|
|
||||||
int
|
int
|
||||||
getc (fp)
|
_IO_getc (fp)
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
|
@ -39,6 +39,8 @@ getc (fp)
|
||||||
__libc_cleanup_region_end (1);
|
__libc_cleanup_region_end (1);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
#undef getc
|
||||||
|
weak_alias (_IO_getc, getc)
|
||||||
|
|
||||||
#ifdef _IO_MTSAFE_IO
|
#ifdef _IO_MTSAFE_IO
|
||||||
# undef getc_locked
|
# undef getc_locked
|
||||||
|
|
|
@ -53,3 +53,5 @@ _IO_gets (buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
weak_alias (_IO_gets, gets)
|
weak_alias (_IO_gets, gets)
|
||||||
|
|
||||||
|
link_warning (gets, "the `gets' function is dangerous and should not be used.")
|
||||||
|
|
|
@ -26,6 +26,7 @@ the executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
#ifndef _IO_STDIO_H
|
#ifndef _IO_STDIO_H
|
||||||
#define _IO_STDIO_H
|
#define _IO_STDIO_H
|
||||||
|
#include <features.h>
|
||||||
|
|
||||||
#include <_G_config.h>
|
#include <_G_config.h>
|
||||||
#define _IO_pos_t _G_fpos_t /* obsolete */
|
#define _IO_pos_t _G_fpos_t /* obsolete */
|
||||||
|
@ -262,21 +263,43 @@ extern int __overflow __P((_IO_FILE*, int));
|
||||||
#define _IO_feof_unlocked(__fp) (((__fp)->_flags & _IO_EOF_SEEN) != 0)
|
#define _IO_feof_unlocked(__fp) (((__fp)->_flags & _IO_EOF_SEEN) != 0)
|
||||||
#define _IO_ferror_unlocked(__fp) (((__fp)->_flags & _IO_ERR_SEEN) != 0)
|
#define _IO_ferror_unlocked(__fp) (((__fp)->_flags & _IO_ERR_SEEN) != 0)
|
||||||
|
|
||||||
|
extern int _IO_getc __P ((_IO_FILE *__fp));
|
||||||
|
extern int _IO_putc __P ((int __c, _IO_FILE *__fp));
|
||||||
|
extern int _IO_feof __P ((_IO_FILE *__fp));
|
||||||
|
extern int _IO_ferror __P ((_IO_FILE *__fp));
|
||||||
|
|
||||||
|
extern int _IO_peekc_locked __P ((_IO_FILE *__fp));
|
||||||
|
|
||||||
/* This one is for Emacs. */
|
/* This one is for Emacs. */
|
||||||
#define _IO_PENDING_OUTPUT_COUNT(_fp) \
|
#define _IO_PENDING_OUTPUT_COUNT(_fp) \
|
||||||
((_fp)->_IO_write_ptr - (_fp)->_IO_write_base)
|
((_fp)->_IO_write_ptr - (_fp)->_IO_write_base)
|
||||||
|
|
||||||
extern int _IO_getc_locked __P ((_IO_FILE *));
|
|
||||||
extern int _IO_putc_locked __P ((int, _IO_FILE *));
|
|
||||||
|
|
||||||
extern void _IO_flockfile __P ((_IO_FILE *));
|
extern void _IO_flockfile __P ((_IO_FILE *));
|
||||||
extern void _IO_funlockfile __P ((_IO_FILE *));
|
extern void _IO_funlockfile __P ((_IO_FILE *));
|
||||||
|
extern int _IO_ftrylockfile __P ((_IO_FILE *));
|
||||||
|
|
||||||
#ifndef _IO_MTSAFE_IO
|
#ifdef _IO_MTSAFE_IO
|
||||||
# define _IO_flockfile(FILE) /**/
|
weak_extern (_IO_flockfile)
|
||||||
# define _IO_funlockfile(FILE) /**/
|
weak_extern (_IO_funlockfile)
|
||||||
|
#else
|
||||||
|
# define _IO_flockfile(_fp) /**/
|
||||||
|
# define _IO_funlockfile(_fp) /**/
|
||||||
|
# define _IO_ftrylockfile(_fp) /**/
|
||||||
#endif /* !_IO_MTSAFE_IO */
|
#endif /* !_IO_MTSAFE_IO */
|
||||||
|
|
||||||
|
#ifdef __USE_REENTRANT
|
||||||
|
# define _IO_getc(_fp) _IO_getc (_fp)
|
||||||
|
# define _IO_peekc(_fp) _IO_peekc_locked (_fp)
|
||||||
|
# define _IO_putc(_ch, _fp) _IO_putc (_ch, _fp)
|
||||||
|
# define _IO_feof(_fp) _IO_feof (_fp)
|
||||||
|
# define _IO_ferror(_fp) _IO_ferror (_fp)
|
||||||
|
#else
|
||||||
|
# define _IO_getc(_fp) _IO_getc_unlocked (_fp)
|
||||||
|
# define _IO_peekc(_fp) _IO_peekc_unlocked (_fp)
|
||||||
|
# define _IO_putc(_ch, _fp) _IO_putc_unlocked (_ch, _fp)
|
||||||
|
# define _IO_feof(_fp) _IO_feof_unlocked (_fp)
|
||||||
|
# define _IO_ferror(_fp) _IO_ferror_unlocked (_fp)
|
||||||
|
#endif
|
||||||
|
|
||||||
extern int _IO_vfscanf __P((_IO_FILE*, const char*, _IO_va_list, int*));
|
extern int _IO_vfscanf __P((_IO_FILE*, const char*, _IO_va_list, int*));
|
||||||
extern int _IO_vfprintf __P((_IO_FILE*, const char*, _IO_va_list));
|
extern int _IO_vfprintf __P((_IO_FILE*, const char*, _IO_va_list));
|
||||||
|
|
41
libio/peekc.c
Normal file
41
libio/peekc.c
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
Copyright (C) 1993, 1995, 1996 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This file is part of the GNU IO Library. This library is free
|
||||||
|
software; you can redistribute it and/or modify it under the
|
||||||
|
terms of the GNU General Public License as published by the
|
||||||
|
Free Software Foundation; either version 2, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
This 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 General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this library; see the file COPYING. If not, write to the Free
|
||||||
|
Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
|
As a special exception, if you link this library with files
|
||||||
|
compiled with a GNU compiler to produce an executable, this does not cause
|
||||||
|
the resulting executable to be covered by the GNU General Public License.
|
||||||
|
This exception does not however invalidate any other reasons why
|
||||||
|
the executable file might be covered by the GNU General Public License. */
|
||||||
|
|
||||||
|
#include "libioP.h"
|
||||||
|
#include "stdio.h"
|
||||||
|
|
||||||
|
#undef _IO_peekc
|
||||||
|
|
||||||
|
int
|
||||||
|
_IO_peekc_locked (fp)
|
||||||
|
FILE *fp;
|
||||||
|
{
|
||||||
|
int result;
|
||||||
|
CHECK_FILE (fp, EOF);
|
||||||
|
__libc_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp);
|
||||||
|
_IO_flockfile (fp);
|
||||||
|
result = _IO_peekc_unlocked (fp);
|
||||||
|
__libc_cleanup_region_end (1);
|
||||||
|
return result;
|
||||||
|
}
|
|
@ -19,10 +19,10 @@ Cambridge, MA 02139, USA. */
|
||||||
#include "libioP.h"
|
#include "libioP.h"
|
||||||
#include "stdio.h"
|
#include "stdio.h"
|
||||||
|
|
||||||
#undef putc
|
#undef _IO_putc
|
||||||
|
|
||||||
int
|
int
|
||||||
putc (c, fp)
|
_IO_putc (c, fp)
|
||||||
int c;
|
int c;
|
||||||
_IO_FILE *fp;
|
_IO_FILE *fp;
|
||||||
{
|
{
|
||||||
|
@ -34,6 +34,8 @@ putc (c, fp)
|
||||||
__libc_cleanup_region_end (1);
|
__libc_cleanup_region_end (1);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
#undef putc
|
||||||
|
weak_alias (_IO_putc, putc)
|
||||||
|
|
||||||
#ifdef _IO_MTSAFE_IO
|
#ifdef _IO_MTSAFE_IO
|
||||||
# undef putc_locked
|
# undef putc_locked
|
||||||
|
|
|
@ -29,7 +29,3 @@ putc_unlocked (c, fp)
|
||||||
CHECK_FILE (fp, EOF);
|
CHECK_FILE (fp, EOF);
|
||||||
return _IO_putc_unlocked (c, fp);
|
return _IO_putc_unlocked (c, fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef _LIBC_REENTRANT
|
|
||||||
weak_alias (putc_unlocked, _IO_putc_unlocked)
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -221,6 +221,7 @@ extern int fileno_locked __P ((FILE *));
|
||||||
extern int fileno_unlocked __P ((FILE *));
|
extern int fileno_unlocked __P ((FILE *));
|
||||||
extern void flockfile __P ((FILE *));
|
extern void flockfile __P ((FILE *));
|
||||||
extern void funlockfile __P ((FILE *));
|
extern void funlockfile __P ((FILE *));
|
||||||
|
extern int ftrylockfile __P ((FILE *));
|
||||||
extern int fclose_unlocked __P ((FILE *));
|
extern int fclose_unlocked __P ((FILE *));
|
||||||
extern int fflush_locked __P ((FILE *));
|
extern int fflush_locked __P ((FILE *));
|
||||||
extern int fflush_unlocked __P ((FILE *));
|
extern int fflush_unlocked __P ((FILE *));
|
||||||
|
@ -240,17 +241,19 @@ extern int putchar_unlocked __P ((int));
|
||||||
|
|
||||||
# ifndef _LIBC
|
# ifndef _LIBC
|
||||||
# define getc_unlocked(fp) _IO_getc_unlocked (fp)
|
# define getc_unlocked(fp) _IO_getc_unlocked (fp)
|
||||||
# define getc_locked(fp) fgetc (fp)
|
# define getc_locked(fp) _IO_getc (fp)
|
||||||
# define getchar_unlocked() _IO_getc_unlocked (stdin)
|
# define getchar_unlocked() _IO_getc_unlocked (stdin)
|
||||||
# define getchar_locked() getc (stdin)
|
# define getchar_locked() _IO_getc (stdin)
|
||||||
# define putchar_unlocked(c) _IO_putc_unlocked (c, stdout)
|
# define putchar_unlocked(c) _IO_putc_unlocked (c, stdout)
|
||||||
# define putchar_locked(c) putc (c, stdout)
|
# define putchar_locked(c) _IO_putc (c, stdout)
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
#endif /* __USE_REENTRANT */
|
#endif /* __USE_REENTRANT */
|
||||||
|
|
||||||
#define putchar(c) putc (c, stdout)
|
#define getc(_fp) _IO_getc (_fp)
|
||||||
#define getchar() getc (stdin)
|
#define putc(_ch, _fp) _IO_putc (_ch, _fp)
|
||||||
|
#define putchar(_ch) _IO_putc (_ch, stdout)
|
||||||
|
#define getchar() _IO_getc (stdin)
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -30,6 +30,9 @@
|
||||||
#if STDC_HEADERS || _LIBC
|
#if STDC_HEADERS || _LIBC
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
static VOID *fixup_null_alloc __P ((size_t n));
|
static VOID *fixup_null_alloc __P ((size_t n));
|
||||||
|
VOID *xmalloc __P ((size_t n));
|
||||||
|
VOID *xcalloc __P ((size_t n, size_t s));
|
||||||
|
VOID *xrealloc __P ((VOID *p, size_t n));
|
||||||
#else
|
#else
|
||||||
VOID *calloc ();
|
VOID *calloc ();
|
||||||
VOID *malloc ();
|
VOID *malloc ();
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/* xstrdup.c -- copy a string with out of memory checking
|
/* xstrdup.c -- copy a string with out of memory checking
|
||||||
Copyright (C) 1990 Free Software Foundation, Inc.
|
Copyright (C) 1990, 1996 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
|
@ -24,7 +24,8 @@
|
||||||
#else
|
#else
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#endif
|
#endif
|
||||||
char *xmalloc ();
|
void *xmalloc __P ((size_t n));
|
||||||
|
char *xstrdup __P ((char *string));
|
||||||
|
|
||||||
/* Return a newly allocated copy of STRING. */
|
/* Return a newly allocated copy of STRING. */
|
||||||
|
|
||||||
|
|
4
po/fr.po
4
po/fr.po
|
@ -1,4 +1,4 @@
|
||||||
# Messages frangais pour GNU concernant gcal.
|
# Messages français pour GNU concernant libc.
|
||||||
# Copyright (C) 1996 Free Software Foundation, Inc.
|
# Copyright (C) 1996 Free Software Foundation, Inc.
|
||||||
# Michel Robitaille <robitail@IRO.UMontreal.CA>, 1996.
|
# Michel Robitaille <robitail@IRO.UMontreal.CA>, 1996.
|
||||||
#
|
#
|
||||||
|
@ -6,7 +6,7 @@ msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: GNU libc 1.94\n"
|
"Project-Id-Version: GNU libc 1.94\n"
|
||||||
"POT-Creation-Date: 1996-09-08 03:45 -0400\n"
|
"POT-Creation-Date: 1996-09-08 03:45 -0400\n"
|
||||||
"PO-Revision-Date: 1996-09-29 14:50 -0400\n"
|
"PO-Revision-Date: 1996-10-10 19:03 -0400\n"
|
||||||
"Last-Translator: Michel Robitaille <robitail@IRO.UMontreal.CA>\n"
|
"Last-Translator: Michel Robitaille <robitail@IRO.UMontreal.CA>\n"
|
||||||
"Language-Team: French <fr@li.org>\n"
|
"Language-Team: French <fr@li.org>\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
|
|
|
@ -701,7 +701,7 @@ _getopt_internal (argc, argv, optstring, longopts, longind, long_only)
|
||||||
const struct option *pfound = NULL;
|
const struct option *pfound = NULL;
|
||||||
int exact = 0;
|
int exact = 0;
|
||||||
int ambig = 0;
|
int ambig = 0;
|
||||||
int indfound;
|
int indfound = 0;
|
||||||
int option_index;
|
int option_index;
|
||||||
|
|
||||||
/* This is an option that requires an argument. */
|
/* This is an option that requires an argument. */
|
||||||
|
@ -743,7 +743,7 @@ _getopt_internal (argc, argv, optstring, longopts, longind, long_only)
|
||||||
for (p = longopts, option_index = 0; p->name; p++, option_index++)
|
for (p = longopts, option_index = 0; p->name; p++, option_index++)
|
||||||
if (!strncmp (p->name, nextchar, nameend - nextchar))
|
if (!strncmp (p->name, nextchar, nameend - nextchar))
|
||||||
{
|
{
|
||||||
if (nameend - nextchar == strlen (p->name))
|
if ((unsigned int) (nameend - nextchar) == strlen (p->name))
|
||||||
{
|
{
|
||||||
/* Exact match found. */
|
/* Exact match found. */
|
||||||
pfound = p;
|
pfound = p;
|
||||||
|
|
|
@ -27,6 +27,11 @@ alpha-*-linux* libc=6
|
||||||
# libc.so.0.2 is for the Hurd alpha release 0.2.
|
# libc.so.0.2 is for the Hurd alpha release 0.2.
|
||||||
*-*-gnu* libc=0.2
|
*-*-gnu* libc=0.2
|
||||||
|
|
||||||
|
# The dynamic loader also requires different names.
|
||||||
|
i?86-*-linux* ld=ld-linux.so.2
|
||||||
|
# We use the ELF ABI standard name for the default.
|
||||||
|
*-*-* ld=ld.so.1
|
||||||
|
|
||||||
# The -ldl interface (see <dlfcn.h>) is the same on all platforms.
|
# The -ldl interface (see <dlfcn.h>) is the same on all platforms.
|
||||||
*-*-* libdl=2
|
*-*-* libdl=2
|
||||||
|
|
||||||
|
@ -34,7 +39,7 @@ alpha-*-linux* libc=6
|
||||||
# `struct utmp' format, which depends on libc.
|
# `struct utmp' format, which depends on libc.
|
||||||
*-*-* libutil=1
|
*-*-* libutil=1
|
||||||
|
|
||||||
# Version number 2 is used on other systems for the BIND 4.9.4 resolver
|
# Version number 2 is used on other systems for the BIND 4.9.5 resolver
|
||||||
# interface.
|
# interface.
|
||||||
*-*-* libresolv=2
|
*-*-* libresolv=2
|
||||||
|
|
||||||
|
|
|
@ -850,9 +850,7 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||||
|
|
||||||
/* Lock stream. */
|
/* Lock stream. */
|
||||||
__libc_cleanup_region_start ((void (*) (void *)) &__funlockfile, s);
|
__libc_cleanup_region_start ((void (*) (void *)) &__funlockfile, s);
|
||||||
|
__flockfile (s);
|
||||||
if (__flockfile != NULL)
|
|
||||||
__flockfile (s);
|
|
||||||
|
|
||||||
/* Write the literal text before the first format. */
|
/* Write the literal text before the first format. */
|
||||||
outstring ((const UCHAR_T *) format,
|
outstring ((const UCHAR_T *) format,
|
||||||
|
|
|
@ -54,7 +54,7 @@ void ReadFile(buffer, input)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
char * filename = "xbug.c";
|
char filename[] = "xbug.c";
|
||||||
FILE *input;
|
FILE *input;
|
||||||
Buffer buffer;
|
Buffer buffer;
|
||||||
|
|
||||||
|
|
|
@ -20,8 +20,7 @@ Cambridge, MA 02139, USA. */
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
link_warning (gets,
|
link_warning (gets, "the `gets' function is dangerous and should not be used.")
|
||||||
"the `gets' function is unreliable and should not be used.")
|
|
||||||
|
|
||||||
/* Read a newline-terminated string from stdin into S,
|
/* Read a newline-terminated string from stdin into S,
|
||||||
removing the trailing newline. Return S or NULL. */
|
removing the trailing newline. Return S or NULL. */
|
||||||
|
|
11
sysdeps/stub/e_fmodl.c
Normal file
11
sysdeps/stub/e_fmodl.c
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
#include <math.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
long double
|
||||||
|
__ieee754_fmodl (long double x, long double y)
|
||||||
|
{
|
||||||
|
fputs ("__ieee754_fmodl not implemented\n", stderr);
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
stub_warning (__ieee754_fmodl)
|
|
@ -17,7 +17,7 @@ License along with the GNU C Library; see the file COPYING.LIB. If
|
||||||
not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||||
Boston, MA 02111-1307, USA. */
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
#include <stdio.h>
|
typedef FILE;
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -25,6 +25,9 @@ __flockfile (FILE *stream)
|
||||||
{
|
{
|
||||||
/* Do nothing. Using this version does not do any locking. */
|
/* Do nothing. Using this version does not do any locking. */
|
||||||
}
|
}
|
||||||
|
#ifdef USE_IN_LIBIO
|
||||||
|
strong_alias (__flockfile, _IO_flockfile)
|
||||||
|
#endif
|
||||||
weak_alias (__flockfile, flockfile);
|
weak_alias (__flockfile, flockfile);
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,6 +36,9 @@ __funlockfile (FILE *stream)
|
||||||
{
|
{
|
||||||
/* Do nothing. Using this version does not do any locking. */
|
/* Do nothing. Using this version does not do any locking. */
|
||||||
}
|
}
|
||||||
|
#ifdef USE_IN_LIBIO
|
||||||
|
strong_alias (__funlockfile, _IO_funlockfile)
|
||||||
|
#endif
|
||||||
weak_alias (__funlockfile, funlockfile);
|
weak_alias (__funlockfile, funlockfile);
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,4 +48,7 @@ __ftrylockfile (FILE *stream)
|
||||||
/* Do nothing. Using this version does not do any locking. */
|
/* Do nothing. Using this version does not do any locking. */
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
#ifdef USE_IN_LIBIO
|
||||||
|
strong_alias (__ftrylockfile, _IO_ftrylockfile)
|
||||||
|
#endif
|
||||||
weak_alias (__ftrylockfile, ftrylockfile);
|
weak_alias (__ftrylockfile, ftrylockfile);
|
||||||
|
|
|
@ -21,48 +21,13 @@ Cambridge, MA 02139, USA. */
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <termios.h>
|
#include <termios.h>
|
||||||
|
|
||||||
static const speed_t speeds[] =
|
|
||||||
{
|
|
||||||
0,
|
|
||||||
50,
|
|
||||||
75,
|
|
||||||
110,
|
|
||||||
134,
|
|
||||||
150,
|
|
||||||
200,
|
|
||||||
300,
|
|
||||||
600,
|
|
||||||
1200,
|
|
||||||
1800,
|
|
||||||
2400,
|
|
||||||
4800,
|
|
||||||
9600,
|
|
||||||
19200,
|
|
||||||
38400,
|
|
||||||
#ifndef __alpha__
|
|
||||||
38400, /* Mention this twice here is a trick. */
|
|
||||||
#endif
|
|
||||||
57600,
|
|
||||||
115200,
|
|
||||||
230400,
|
|
||||||
460800,
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/* Return the output baud rate stored in *TERMIOS_P. */
|
/* Return the output baud rate stored in *TERMIOS_P. */
|
||||||
speed_t
|
speed_t
|
||||||
cfgetospeed (termios_p)
|
cfgetospeed (termios_p)
|
||||||
const struct termios *termios_p;
|
const struct termios *termios_p;
|
||||||
{
|
{
|
||||||
speed_t retval = termios_p->c_cflag & (CBAUD | CBAUDEX);
|
return termios_p->c_cflag & (CBAUD | CBAUDEX);
|
||||||
|
|
||||||
if (retval & CBAUDEX)
|
|
||||||
{
|
|
||||||
retval &= ~CBAUDEX;
|
|
||||||
retval |= CBAUD + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Return the input baud rate stored in *TERMIOS_P.
|
/* Return the input baud rate stored in *TERMIOS_P.
|
||||||
|
@ -75,30 +40,17 @@ cfsetospeed (termios_p, speed)
|
||||||
struct termios *termios_p;
|
struct termios *termios_p;
|
||||||
speed_t speed;
|
speed_t speed;
|
||||||
{
|
{
|
||||||
register unsigned int i;
|
if ((speed & ~CBAUD) != 0
|
||||||
|
&& (speed < B57600 || speed > B460800))
|
||||||
if (termios_p == NULL)
|
|
||||||
{
|
{
|
||||||
__set_errno (EINVAL);
|
__set_errno (EINVAL);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This allows either B1200 or 1200 to work. XXX
|
termios_p->c_cflag &= ~(CBAUD | CBAUDEX);
|
||||||
Do we really want to try to support this, given that
|
termios_p->c_cflag |= speed;
|
||||||
fetching the speed must return one or the other? */
|
|
||||||
|
|
||||||
for (i = 0; i < sizeof (speeds) / sizeof (speeds[0]); ++i)
|
return 0;
|
||||||
if (i == speed || speeds[i] == speed)
|
|
||||||
{
|
|
||||||
termios_p->c_cflag &= ~(CBAUD | CBAUDEX);
|
|
||||||
termios_p->c_cflag |= (i & CBAUD);
|
|
||||||
if (i & ~CBAUD)
|
|
||||||
termios_p->c_cflag |= CBAUDEX;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
__set_errno (EINVAL);
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set the input baud rate stored in *TERMIOS_P to SPEED.
|
/* Set the input baud rate stored in *TERMIOS_P to SPEED.
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* Copyright (C) 1992, 1993 Free Software Foundation, Inc.
|
/* Copyright (C) 1992, 1993, 1996 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
@ -16,16 +16,104 @@ License along with the GNU C Library; see the file COPYING.LIB. If
|
||||||
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
|
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
|
||||||
Cambridge, MA 02139, USA. */
|
Cambridge, MA 02139, USA. */
|
||||||
|
|
||||||
#include <ansidecl.h>
|
|
||||||
#include <termios.h>
|
#include <termios.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
|
static struct speed_struct
|
||||||
|
{
|
||||||
|
speed_t value;
|
||||||
|
speed_t internal;
|
||||||
|
} speeds[] =
|
||||||
|
{
|
||||||
|
#ifdef B0
|
||||||
|
{ 0, B0 },
|
||||||
|
#endif
|
||||||
|
#ifdef B50
|
||||||
|
{ 50, B50 },
|
||||||
|
#endif
|
||||||
|
#ifdef B75
|
||||||
|
{ 75, B75 },
|
||||||
|
#endif
|
||||||
|
#ifdef B110
|
||||||
|
{ 110, B110 },
|
||||||
|
#endif
|
||||||
|
#ifdef B134
|
||||||
|
{ 134, B134 },
|
||||||
|
#endif
|
||||||
|
#ifdef B150
|
||||||
|
{ 150, B150 },
|
||||||
|
#endif
|
||||||
|
#ifdef B200
|
||||||
|
{ 200, B200 },
|
||||||
|
#endif
|
||||||
|
#ifdef B300
|
||||||
|
{ 300, B300 },
|
||||||
|
#endif
|
||||||
|
#ifdef B600
|
||||||
|
{ 600, B600 },
|
||||||
|
#endif
|
||||||
|
#ifdef B1200
|
||||||
|
{ 1200, B1200 },
|
||||||
|
#endif
|
||||||
|
#ifdef B1200
|
||||||
|
{ 1200, B1200 },
|
||||||
|
#endif
|
||||||
|
#ifdef B1800
|
||||||
|
{ 1800, B1800 },
|
||||||
|
#endif
|
||||||
|
#ifdef B2400
|
||||||
|
{ 2400, B2400 },
|
||||||
|
#endif
|
||||||
|
#ifdef B4800
|
||||||
|
{ 4800, B4800 },
|
||||||
|
#endif
|
||||||
|
#ifdef B9600
|
||||||
|
{ 9600, B9600 },
|
||||||
|
#endif
|
||||||
|
#ifdef B19200
|
||||||
|
{ 19200, B19200 },
|
||||||
|
#endif
|
||||||
|
#ifdef B38400
|
||||||
|
{ 38400, B38400 },
|
||||||
|
#endif
|
||||||
|
#ifdef B57600
|
||||||
|
{ 57600, B57600 },
|
||||||
|
#endif
|
||||||
|
#ifdef B76800
|
||||||
|
{ 76800, B76800 },
|
||||||
|
#endif
|
||||||
|
#ifdef B115200
|
||||||
|
{ 115200, B115200 },
|
||||||
|
#endif
|
||||||
|
#ifdef B153600
|
||||||
|
{ 153600, B153600 },
|
||||||
|
#endif
|
||||||
|
#ifdef B230400
|
||||||
|
{ 230400, B230400 },
|
||||||
|
#endif
|
||||||
|
#ifdef B307200
|
||||||
|
{ 307200, B307200 },
|
||||||
|
#endif
|
||||||
|
#ifdef B460800
|
||||||
|
{ 460800, B460800 },
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/* Set both the input and output baud rates stored in *TERMIOS_P to SPEED. */
|
/* Set both the input and output baud rates stored in *TERMIOS_P to SPEED. */
|
||||||
void
|
void
|
||||||
DEFUN(cfsetspeed, (termios_p, speed),
|
cfsetspeed (struct termios *termios_p, speed_t speed)
|
||||||
struct termios *termios_p AND speed_t speed)
|
|
||||||
{
|
{
|
||||||
cfsetispeed (termios_p, speed);
|
size_t cnt;
|
||||||
cfsetospeed (termios_p, speed);
|
|
||||||
|
for (cnt = 0; cnt < sizeof (speeds); ++cnt)
|
||||||
|
if (speed == speeds[cnt].value)
|
||||||
|
{
|
||||||
|
cfsetispeed (termios_p, speed);
|
||||||
|
cfsetospeed (termios_p, speed);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
__set_errno (EINVAL);
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,7 +70,7 @@ Boston, MA 02111-1307, USA. */
|
||||||
if (rp == NULL) \
|
if (rp == NULL) \
|
||||||
return NULL; \
|
return NULL; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
|
||||||
char *
|
char *
|
||||||
strptime (const char *buf, const char *format, struct tm *tm)
|
strptime (const char *buf, const char *format, struct tm *tm)
|
||||||
|
@ -211,6 +211,29 @@ strptime (const char *buf, const char *format, struct tm *tm)
|
||||||
case 'R':
|
case 'R':
|
||||||
recursive ("%H:%M");
|
recursive ("%H:%M");
|
||||||
break;
|
break;
|
||||||
|
case 's':
|
||||||
|
{
|
||||||
|
/* The number of seconds may be very high so we cannot use
|
||||||
|
the `get_number' macro. Instead read the number
|
||||||
|
character for character and construct the result while
|
||||||
|
doing this. */
|
||||||
|
time_t secs;
|
||||||
|
if (*rp < '0' || *rp > '9')
|
||||||
|
/* We need at least one digit. */
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
secs *= 10;
|
||||||
|
secs += *rp++ - '0';
|
||||||
|
}
|
||||||
|
while (*rp >= '0' && *rp <= '9');
|
||||||
|
|
||||||
|
if (__localtime_r (&secs, tm) == NULL)
|
||||||
|
/* Error in function. */
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
break;
|
||||||
case 'S':
|
case 'S':
|
||||||
get_number (0, 61);
|
get_number (0, 61);
|
||||||
tm->tm_sec = val;
|
tm->tm_sec = val;
|
||||||
|
@ -218,6 +241,23 @@ strptime (const char *buf, const char *format, struct tm *tm)
|
||||||
case 'T':
|
case 'T':
|
||||||
recursive ("%H:%M:%S");
|
recursive ("%H:%M:%S");
|
||||||
break;
|
break;
|
||||||
|
case 'u':
|
||||||
|
get_number (1, 7);
|
||||||
|
tm->tm_wday = val % 7;
|
||||||
|
break;
|
||||||
|
case 'g':
|
||||||
|
get_number (0, 99);
|
||||||
|
/* XXX This cannot determine any field in TM. */
|
||||||
|
break;
|
||||||
|
case 'G':
|
||||||
|
if (*rp < '0' || *rp > '9')
|
||||||
|
return NULL;
|
||||||
|
/* XXX Ignore the number since we would need some more
|
||||||
|
information to compute a real date. */
|
||||||
|
do
|
||||||
|
++rp;
|
||||||
|
while (*rp >= '0' && *rp <= '9');
|
||||||
|
break;
|
||||||
case 'U':
|
case 'U':
|
||||||
case 'V':
|
case 'V':
|
||||||
case 'W':
|
case 'W':
|
||||||
|
@ -339,6 +379,6 @@ strptime (const char *buf, const char *format, struct tm *tm)
|
||||||
|
|
||||||
if (have_I && is_pm)
|
if (have_I && is_pm)
|
||||||
tm->tm_hour += 12;
|
tm->tm_hour += 12;
|
||||||
|
|
||||||
return (char *) rp;
|
return (char *) rp;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue