mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-30 22:43:12 +03:00
Wed May 22 01:48:54 1996 Ulrich Drepper <drepper@cygnus.com>
* stdlib/strtol.c [!QUAD] (ULONG_MAX, LONG_MAX): Define these macros if they are not available. (WEAKNAME): New macro to declare argument as weak. Define function with __ prefix and add normal name as weak alias. * sysdeps/posix/euidaccess.c (S_IROTH, S_IWOTH, S_IXOTH): Defines these macros if not already available based on R_OK, W_OK, and X_OK. Tue May 21 18:48:46 1996 Roland McGrath <roland@delasyd.gnu.ai.mit.edu> * misc/sys/syslog.h (__need___va_list): Define this instead of __need_va_list before including <stdarg.h>. * Makerules (o-iterator): Use $(object-suffixes-left) instead of $(object-suffixes) to produce repetitions; this is used for other lists than just that one. [versioned]: Use $(o-iterator) properly. * sysdeps/unix/sysv/linux/Implies: Include `gnu'. * sysdeps/mach/hurd/Implies: Likewise. Sat May 18 02:57:46 1996 Ulrich Drepper <drepper@cygnus.com> * login/Makefile: New file. This directory contains functions for user administration. * Makefile (subdirs): Add login. * misc/Makefile (headers): Remove utmp.h. Now in login/utmp.h. (extra-libs, libutil-routines): Ditto. * misc/login.c, misc/login_tty.c, misc/logout.c, misc/logwtmp.c, misc/utmp.h: Moved to misc/. * login/login.c, login/login_tty.c, login/logout.c, login/logwtmp.c, login/utmp.h: Moved to here from misc/. * login/utmp.h: Split file. Definitions of data structures and constants are now in the system dependent utmpbits.h file. * login/setutent_r.c, login/setutent.c, login/endutent_r.c, login/endutent.c, login/getutent_r.c, login/getutent.c, login/getutid_r.c, login/getutid.c, login/getutline_r.c, login/getutline.c, login/pututline_r.c, login/pututline.c: New files. Routines to handle utmp-style files. * sysdeps/gnu/utmpbits.h: New file. Contains GNU/Linux specific definitions of utmp data structures and constants. * sysdeps/unix/sysv/utmpbits.h: Renamed from sysdeps/unix/sysv/utmp.h. * sysdeps/generic/utmpbits.h: New file. Generic (BSDish) version of definitions of utmp data structures and constants. Fri May 17 00:01:31 1996 Ulrich Drepper <drepper@cygnus.com> * locale/C-monetary.c: Default value for mon_decimal_point should be '.'. * stdio-common/printf.h: Remove Linux libc compatibility stuff. Add `extra' flag. Currently used in __printf_fp. * stdio-common/printf_fp.c (__guess_grouping): Renamed from `guess_grouping' and extend visibility to extern. This function is now used in `strfmon'. (__printf_fp): Recognize new bit flag in info struct. This triggers to use the grouping information and decimal point from the LC_MONETARY category instead of the LC_NUMERIC category. * stdio-common/vfprintf.c (process_arg): Correct major bug. In `complicated' loop we must not use the varargs because the args are already available in the ARGS_VALUE array. * stdlib/Makefile (headers): Add monetary.h. (routines): Add strfmon. * stdlib/monetary.h: New file. Header for strfmon function. * stdlib/strfmon.c: New file. Implement strfmon function to print monetary amounts according to current locale's rules. * sysdeps/unix/sysv/linux/i386/sys/vm86.h: The kernel header is now (>= Linux-1.3.100) called <asm/vm86.h>.
This commit is contained in:
@ -414,7 +414,10 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
{ \
|
||||
long long int signed_number; \
|
||||
\
|
||||
signed_number = va_arg (ap, long long int); \
|
||||
if (fspec == NULL) \
|
||||
signed_number = va_arg (ap, long long int); \
|
||||
else \
|
||||
signed_number = args_value[fspec->data_arg].pa_long_long_int; \
|
||||
\
|
||||
is_negative = signed_number < 0; \
|
||||
number.longlong = is_negative ? (- signed_number) : signed_number; \
|
||||
@ -425,10 +428,16 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
{ \
|
||||
long int signed_number; \
|
||||
\
|
||||
if (is_long) \
|
||||
signed_number = va_arg (ap, long int); \
|
||||
else /* `short int' will be promoted to `int'. */ \
|
||||
signed_number = va_arg (ap, int); \
|
||||
if (fspec == NULL) \
|
||||
if (is_long) \
|
||||
signed_number = va_arg (ap, long int); \
|
||||
else /* `short int' will be promoted to `int'. */ \
|
||||
signed_number = va_arg (ap, int); \
|
||||
else \
|
||||
if (is_long) \
|
||||
signed_number = args_value[fspec->data_arg].pa_long_int; \
|
||||
else \
|
||||
signed_number = args_value[fspec->data_arg].pa_int; \
|
||||
\
|
||||
is_negative = signed_number < 0; \
|
||||
number.word = is_negative ? (- signed_number) : signed_number; \
|
||||
@ -463,7 +472,10 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
\
|
||||
if (is_longlong) \
|
||||
{ \
|
||||
number.longlong = va_arg (ap, unsigned long long int); \
|
||||
if (fspec == NULL) \
|
||||
number.longlong = va_arg (ap, unsigned long long int); \
|
||||
else \
|
||||
number.longlong = args_value[fspec->data_arg].pa_u_long_long_int; \
|
||||
\
|
||||
LABEL (longlong_number): \
|
||||
if (prec < 0) \
|
||||
@ -493,12 +505,21 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
} \
|
||||
else \
|
||||
{ \
|
||||
if (is_long) \
|
||||
number.word = va_arg (ap, unsigned long int); \
|
||||
else if (!is_short) \
|
||||
number.word = va_arg (ap, unsigned int); \
|
||||
if (fspec == NULL) \
|
||||
if (is_long) \
|
||||
number.word = va_arg (ap, unsigned long int); \
|
||||
else if (!is_short) \
|
||||
number.word = va_arg (ap, unsigned int); \
|
||||
else \
|
||||
number.word = (unsigned short int) va_arg (ap, unsigned int); \
|
||||
else \
|
||||
number.word = (unsigned short int) va_arg (ap, unsigned int); \
|
||||
if (is_long) \
|
||||
number.word = args_value[fspec->data_arg].pa_u_long_int; \
|
||||
else if (!is_short) \
|
||||
number.word = args_value[fspec->data_arg].pa_u_int; \
|
||||
else \
|
||||
number.word = (unsigned short int) \
|
||||
args_value[fspec->data_arg].pa_u_short_int; \
|
||||
\
|
||||
LABEL (number): \
|
||||
if (prec < 0) \
|
||||
@ -617,13 +638,6 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
const void *ptr; \
|
||||
int function_done; \
|
||||
\
|
||||
if (is_long_double) \
|
||||
the_arg.pa_long_double = va_arg (ap, long double); \
|
||||
else \
|
||||
the_arg.pa_double = va_arg (ap, double); \
|
||||
\
|
||||
ptr = (const void *) &the_arg; \
|
||||
\
|
||||
if (fspec == NULL) \
|
||||
{ \
|
||||
struct printf_info info = { prec: prec, \
|
||||
@ -637,12 +651,23 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
left: left, \
|
||||
showsign: showsign, \
|
||||
group: group, \
|
||||
pad: pad }; \
|
||||
pad: pad, \
|
||||
extra: 0 }; \
|
||||
\
|
||||
if (is_long_double) \
|
||||
the_arg.pa_long_double = va_arg (ap, long double); \
|
||||
else \
|
||||
the_arg.pa_double = va_arg (ap, double); \
|
||||
ptr = (const void *) &the_arg; \
|
||||
\
|
||||
function_done = __printf_fp (s, &info, &ptr); \
|
||||
} \
|
||||
else \
|
||||
function_done = __printf_fp (s, &fspec->info, &ptr); \
|
||||
{ \
|
||||
ptr = (const void *) &args_value[fspec->data_arg]; \
|
||||
\
|
||||
function_done = __printf_fp (s, &fspec->info, &ptr); \
|
||||
} \
|
||||
\
|
||||
if (function_done < 0) \
|
||||
/* Error in print handler. */ \
|
||||
@ -657,7 +682,10 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
--width; /* Account for the character itself. */ \
|
||||
if (!left) \
|
||||
PAD (' '); \
|
||||
outchar ((unsigned char) va_arg (ap, int)); /* Promoted. */ \
|
||||
if (fspec == NULL) \
|
||||
outchar ((unsigned char) va_arg (ap, int)); /* Promoted. */ \
|
||||
else \
|
||||
outchar ((unsigned char) args_value[fspec->data_arg].pa_char); \
|
||||
if (left) \
|
||||
PAD (' '); \
|
||||
break; \
|
||||
@ -668,7 +696,10 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
\
|
||||
/* The string argument could in fact be `char *' or `wchar_t *'. \
|
||||
But this should not make a difference here. */ \
|
||||
string = (char *) va_arg (ap, const char *); \
|
||||
if (fspec == NULL) \
|
||||
string = (char *) va_arg (ap, const char *); \
|
||||
else \
|
||||
string = (char *) args_value[fspec->data_arg].pa_string; \
|
||||
\
|
||||
/* Entry point for printing other strings. */ \
|
||||
LABEL (print_string): \
|
||||
@ -738,7 +769,10 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
/* Generic pointer. */ \
|
||||
{ \
|
||||
const void *ptr; \
|
||||
ptr = va_arg (ap, void *); \
|
||||
if (fspec == NULL) \
|
||||
ptr = va_arg (ap, void *); \
|
||||
else \
|
||||
ptr = args_value[fspec->data_arg].pa_pointer; \
|
||||
if (ptr != NULL) \
|
||||
{ \
|
||||
/* If the pointer is not NULL, write it as a %#x spec. */ \
|
||||
@ -765,14 +799,24 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
\
|
||||
LABEL (form_number): \
|
||||
/* Answer the count of characters written. */ \
|
||||
if (is_longlong) \
|
||||
*(long long int *) va_arg (ap, void *) = done; \
|
||||
else if (is_long) \
|
||||
*(long int *) va_arg (ap, void *) = done; \
|
||||
else if (!is_short) \
|
||||
*(int *) va_arg (ap, void *) = done; \
|
||||
if (fspec == NULL) \
|
||||
if (is_longlong) \
|
||||
*(long long int *) va_arg (ap, void *) = done; \
|
||||
else if (is_long) \
|
||||
*(long int *) va_arg (ap, void *) = done; \
|
||||
else if (!is_short) \
|
||||
*(int *) va_arg (ap, void *) = done; \
|
||||
else \
|
||||
*(short int *) va_arg (ap, void *) = done; \
|
||||
else \
|
||||
*(short int *) va_arg (ap, void *) = done; \
|
||||
if (is_longlong) \
|
||||
*(long long int *) args_value[fspec->data_arg].pa_pointer = done; \
|
||||
else if (is_long) \
|
||||
*(long int *) args_value[fspec->data_arg].pa_pointer = done; \
|
||||
else if (!is_short) \
|
||||
*(int *) args_value[fspec->data_arg].pa_pointer = done; \
|
||||
else \
|
||||
*(short int *) args_value[fspec->data_arg].pa_pointer = done; \
|
||||
break; \
|
||||
\
|
||||
LABEL (form_strerror): \
|
||||
@ -827,6 +871,7 @@ vfprintf (FILE *s, const CHAR_T *format, va_list ap)
|
||||
STEP0_3_TABLE;
|
||||
STEP4_TABLE;
|
||||
|
||||
union printf_arg *args_value; /* This is not used here but ... */
|
||||
int is_negative; /* Flag for negative number. */
|
||||
union
|
||||
{
|
||||
|
Reference in New Issue
Block a user