summaryrefslogtreecommitdiff
path: root/misc
diff options
context:
space:
mode:
authorPanu Matilainen <pmatilai@redhat.com>2010-01-04 14:15:20 +0200
committerPanu Matilainen <pmatilai@redhat.com>2010-01-04 14:15:20 +0200
commit580f9625e166be7771ead94f500e54a5b34d3196 (patch)
tree3b36e18c8119821e71489aad98946afc265f3e41 /misc
parent60dc809db136e8bba12a9d45e189248218e304cb (diff)
downloadrpm-580f9625e166be7771ead94f500e54a5b34d3196.tar.gz
rpm-580f9625e166be7771ead94f500e54a5b34d3196.tar.bz2
rpm-580f9625e166be7771ead94f500e54a5b34d3196.zip
Remove largely unnecessary putenv() replacement
- only the lua posix extension "uses" this by providing putenv() to Lua, make it conditional and return error if not supported by the underlying operating system
Diffstat (limited to 'misc')
-rw-r--r--misc/Makefile.am3
-rw-r--r--misc/putenv.c113
2 files changed, 1 insertions, 115 deletions
diff --git a/misc/Makefile.am b/misc/Makefile.am
index b84eea4ce..a45631306 100644
--- a/misc/Makefile.am
+++ b/misc/Makefile.am
@@ -8,8 +8,7 @@ EXTRA_DIST = \
fakefork.c fnmatch.c fnmatch.h \
getcwd.c getmntent.c \
getwd.c glob.c glob.h \
- putenv.c realpath.c \
- setenv.c stpcpy.c stpncpy.c
+ realpath.c setenv.c stpcpy.c stpncpy.c
noinst_LTLIBRARIES = libmisc.la
diff --git a/misc/putenv.c b/misc/putenv.c
deleted file mode 100644
index 15ee03715..000000000
--- a/misc/putenv.c
+++ /dev/null
@@ -1,113 +0,0 @@
-/* Copyright (C) 1991, 1994 Free Software Foundation, Inc.
-
-
-NOTE: The canonical source of this file is maintained with the GNU C Library.
-Bugs can be reported to bug-glibc@prep.ai.mit.edu.
-
-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 the
-Free Software Foundation; either version 2, or (at your option) any
-later version.
-
-This program 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 program; if not, write to the Free Software Foundation,
-Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
-
-#include <errno.h>
-
-#ifdef HAVE_CONFIG_H
-# include "config.h"
-#endif
-
-/* Define-away any (possibly conflicting) prototype of putenv.
- Many systems omit the `const' attribute on the argument. */
-#define putenv _sys_putenv
-
-#if defined (__GNU_LIBRARY__) || defined (HAVE_STDLIB_H)
-# include <stdlib.h>
-#endif
-#if defined (__GNU_LIBRARY__) || defined (HAVE_STRING_H)
-# include <string.h>
-#endif
-#if defined (__GNU_LIBRARY__) || defined (HAVE_UNISTD_H)
-# include <unistd.h>
-#endif
-
-#undef putenv
-
-#if !defined (__GNU_LIBRARY__) && !defined (HAVE_STRCHR)
-# define strchr index
-#endif
-#if !defined (__GNU_LIBRARY__) && !defined (HAVE_MEMCPY)
-# define memcpy(d,s,n) bcopy ((s), (d), (n))
-#endif
-
-#if HAVE_GNU_LD
-# define environ __environ
-#elif defined (__APPLE__)
-# include <crt_externs.h>
-# define environ (*_NSGetEnviron())
-#else
-extern char **environ;
-#endif
-
-
-/* Put STRING, which is of the form "NAME=VALUE", in the environment. */
-int
-putenv (string)
- const char *string;
-{
- const char *const name_end = strchr (string, '=');
- register size_t size;
- register char **ep;
-
- if (name_end == NULL)
- {
- /* Remove the variable from the environment. */
- size = strlen (string);
- for (ep = environ; *ep != NULL; ++ep)
- if (!strncmp (*ep, string, size) && (*ep)[size] == '=')
- {
- while (ep[1] != NULL)
- {
- ep[0] = ep[1];
- ++ep;
- }
- *ep = NULL;
- return 0;
- }
- }
-
- size = 0;
- for (ep = environ; *ep != NULL; ++ep)
- if (!strncmp (*ep, string, name_end - string) &&
- (*ep)[name_end - string] == '=')
- break;
- else
- ++size;
-
- if (*ep == NULL)
- {
- static char **last_environ = NULL;
- char **new_environ = (char **) malloc ((size + 2) * sizeof (char *));
- if (new_environ == NULL)
- return -1;
- (void) memcpy ((void *) new_environ, (void *) environ,
- size * sizeof (char *));
- new_environ[size] = (char *) string;
- new_environ[size + 1] = NULL;
- if (last_environ != NULL)
- free ((void *) last_environ);
- last_environ = new_environ;
- environ = new_environ;
- }
- else
- *ep = (char *) string;
-
- return 0;
-}