From 24d08cd5a3ff0f130f1cef004cece8b8e32c3a36 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Tue, 11 Feb 1997 04:45:23 +0000 Subject: [PATCH] update from main archive 970210 --- ChangeLog | 17 ++++++++ locale/weight.h | 6 +-- posix/getopt_init.c | 77 +++++++++++++++++++++++++++++++++++ string/argz-ctsep.c => stdlib/atoll.c | 54 ++++-------------------- string/argz-ctsep.c | 4 +- 5 files changed, 107 insertions(+), 51 deletions(-) create mode 100644 posix/getopt_init.c copy string/argz-ctsep.c => stdlib/atoll.c (50%) diff --git a/ChangeLog b/ChangeLog index 2b2e5d14a9..c70e8ecf5f 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +1997-02-11 05:27 Ulrich Drepper + + * locale/weight.h (collate_rules): It's an u_int32_t array. + (get_weight): Compute initial SLOT value correctly. + +1997-02-10 17:45 Ulrich Drepper + + * string/argz-ctsep.c: Initialize *LEN when successful. + 1997-02-09 02:59 Ulrich Drepper * version.h (VERSION): Bump to 2.0.2. @@ -24,6 +33,10 @@ * stdio/vsnprintf.c: Likewise. Reported by Philip Blundell . + * libio/vsnprintf.c: If MAXLEN is 0 return 0. + * stdio/vsnprintf.c: Likewise. + Reported by Philip Blundell . + 1997-02-07 17:43 Ulrich Drepper * sysdeps/generic/sysd-stdio.c: Include . @@ -39,6 +52,10 @@ * rellns-sh: No need to check for existance of first parameter. +1997-02-06 13:49 Andreas Schwab + + * rellns-sh: No need to check for existance of first parameter. + 1997-02-06 14:50 Andreas Schwab * sysdeps/posix/getcwd.c (__getcwd): Fix resource leaks. Reported diff --git a/locale/weight.h b/locale/weight.h index 0d6ef51722..424e493209 100644 --- a/locale/weight.h +++ b/locale/weight.h @@ -1,4 +1,4 @@ -/* Copyright (C) 1996 Free Software Foundation, Inc. +/* Copyright (C) 1996, 1997 Free Software Foundation, Inc. This file is part of the GNU C Library. Written by Ulrich Drepper, . @@ -52,7 +52,7 @@ typedef struct weight_t #define collate_undefined \ (_NL_CURRENT_WORD (LC_COLLATE, _NL_COLLATE_UNDEFINED)) #define collate_rules \ - (_NL_CURRENT (LC_COLLATE, _NL_COLLATE_RULES)) + ((u_int32_t *) _NL_CURRENT (LC_COLLATE, _NL_COLLATE_RULES)) static __inline int get_weight (const STRING_TYPE **str, weight_t *result); @@ -69,7 +69,7 @@ get_weight (const STRING_TYPE **str, weight_t *result) const size_t level_size = collate_hash_size * (collate_nrules + 1); size_t level; - slot = (ch * (collate_nrules + 1)) % collate_hash_size; + slot = (ch % collate_hash_size) * (collate_nrules + 1); level = 0; while (__collate_table[slot] != (u_int32_t) ch) diff --git a/posix/getopt_init.c b/posix/getopt_init.c new file mode 100644 index 0000000000..e90c9d7d8a --- /dev/null +++ b/posix/getopt_init.c @@ -0,0 +1,77 @@ +/* Perform additional initialization for getopt functions in GNU libc. + Copyright (C) 1997 Free Software Foundation, Inc. + This file is part of the GNU C Library. + Contributed by Ulrich Drepper , 1997. + + 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., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ + +/* Attention: this file is *not* necessary when the GNU getopt functions + are used outside the GNU libc. Some additional functionality of the + getopt functions in GNU libc require this additional work. */ + +#include +#include +#include +#include + +#include "../stdio-common/_itoa.h" + +/* External variable to synchronize work. */ +extern char *__getopt_nonoption_flags; + +extern pid_t __libc_pid; + + +/* Remove the environment variable "__GNU_nonoption_argv_flags_" if + it is still available. If the getopt functions are also used in the + application it does not exist anymore since it was saved for the use + in getopt. */ +void +__getopt_clean_environment (void) +{ + /* Bash 2.0 puts a special variable in the environment for each + command it runs, specifying which ARGV elements are the results + of file name wildcard expansion and therefore should not be + considered as options. */ + static const char envvar_tail[] = "_GNU_nonoption_argv_flags_"; + char var[100]; + char *cp, **ep; + size_t len; + + /* Generate name of the environment variable. We must know the PID + and we must not use `sprintf'. */ + if (__libc_pid == 0) + __libc_pid = getpid (); + + /* Construct "__GNU_nonoption_argv_flags_" string. */ + cp = memcpy (&var[sizeof (var) - sizeof (envvar_tail)], envvar_tail, + sizeof (envvar_tail)); + cp = _itoa_word (__libc_pid, cp, 10, 0); + *--cp = '_'; + len = (var + sizeof (var) - 1) - cp; + + for (ep = __environ; *ep != NULL; ++ep) + if (!strncmp (*ep, cp, len) && (*ep)[len] == '=') + { + /* Found it. Store this pointer and move later ones back. */ + char **dp = ep; + __getopt_nonoption_flags = &(*ep)[len + 1]; + do + dp[0] = dp[1]; + while (*dp++); + /* Continue the loop in case the name appears again. */ + } +} diff --git a/string/argz-ctsep.c b/stdlib/atoll.c similarity index 50% copy from string/argz-ctsep.c copy to stdlib/atoll.c index 461b9beb87..dd387b949d 100644 --- a/string/argz-ctsep.c +++ b/stdlib/atoll.c @@ -1,6 +1,5 @@ -/* Copyright (C) 1996 Free Software Foundation, Inc. +/* Copyright (C) 1991, 1997 Free Software Foundation, Inc. This file is part of the GNU C Library. - Contributed by Ulrich Drepper , 1996. 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 @@ -17,53 +16,14 @@ write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ -#include -#include #include -#include +#undef atol -error_t -__argz_create_sep (const char *string, int delim, char **argz, size_t *len) -{ - size_t nlen = strlen (string) + 1; - - if (nlen > 1) - { - const char *rp; - char *wp; - - *argz = (char *) malloc (nlen); - if (*argz == NULL) - return ENOMEM; - rp = string; - wp = *argz; - do - if (*rp == delim) - { - if (wp > *argz && wp[-1] != '\0') - *wp++ = '\0'; - else - --nlen; - } - else - *wp++ = *rp; - while (*rp++ != '\0'); - - if (nlen == 0) - { - free (*argz); - *argz = NULL; - *len = 0; - } - } - else - { - *argz = NULL; - *len = 0; - } - - return 0; +/* Convert a string to a long int. */ +long long int +atoll (const char *nptr) +{ + return strtoll (nptr, (char **) NULL, 10); } -weak_alias (__argz_create_sep, argz_create_sep) diff --git a/string/argz-ctsep.c b/string/argz-ctsep.c index 461b9beb87..f21572459f 100644 --- a/string/argz-ctsep.c +++ b/string/argz-ctsep.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1996 Free Software Foundation, Inc. +/* Copyright (C) 1996, 1997 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper , 1996. @@ -57,6 +57,8 @@ __argz_create_sep (const char *string, int delim, char **argz, size_t *len) *argz = NULL; *len = 0; } + + *len = nlen; } else { -- 2.11.4.GIT