binutils-gdb/gdb/putenv.c
Fred Fish 51b57ded88 * dbxread.c, i386-pinsn.c, i386-tdep.c, regex.c, solib.c, symmisc.c,
symtab.h, tm-i386v4.h, valprint.c, values.c:  Lint.
	* breakpoint.c, c-exp.y, coffread.c, command.c, environ.c, eval.c,
	findvar.c, infcmd.c, infptrace.c, infrun.c, m2-exp.y, parse.c,
	putenv.c, solib.c, sparc-xdep.c, symtab.c, tm-i386v.h, tm-sparc.h,
	utils.c, valarith.c, valops.c, valprint.c, values.c:
	Replace bcopy() use with memcpy(), which is more standard and can
	take advantage of gcc's builtin functions for increased performance.
	* breakpoint.c, buildsym.c, coffread.c, dbxread.c, i386-tdep.c,
	ieee-float.c, infcmd.c, sparc-tdep.c, stack.c, symtab.c, symtab.h,
	target.c, values.c:
	Replace bzero() use with memset(), which is more standard and can
	take advantage of gcc's builtin functions for increased performance.
	* i386-tdep.c, main.c, valprint.c:
	Replace bcmp() use with memcmp(), which is more standard and can
	take advantage of gcc's builtin functions for increased performance.
1992-06-29 23:34:38 +00:00

112 lines
2.8 KiB
C

/****************************************************************/
/* */
/* putenv(3) */
/* */
/* Change or add an environment entry */
/* */
/****************************************************************/
/* origination 1987-Oct-7 T. Holm */
/****************************************************************/
/*
Path: hoptoad!pacbell!ames!ll-xn!mit-eddie!uw-beaver!ssc-vax!uvicctr!tholm
From: tholm@uvicctr.UUCP (Terrence W. Holm)
Newsgroups: comp.os.minix
Subject: putenv(3)
Message-ID: <395@uvicctr.UUCP>
Date: 5 May 88 06:40:52 GMT
Organization: University of Victoria, Victoria B.C. Canada
EFTH Minix report #2 - May 1988 - putenv(3)
This is an implementation of putenv(3) that we
wrote for Minix. Please consider this a public
domain program.
*/
#include <stdio.h>
#define PSIZE sizeof(char *)
extern char **environ;
char *index();
char *malloc();
/****************************************************************/
/* */
/* int */
/* putenv( entry ) */
/* */
/* The "entry" should follow the form */
/* "NAME=VALUE". This routine will search the */
/* user environment for "NAME" and replace its */
/* value with "VALUE". */
/* */
/* Note that "entry" is not copied, it is used */
/* as the environment entry. This means that it */
/* must not be unallocated or otherwise modifed */
/* by the caller, unless it is replaced by a */
/* subsequent putenv(). */
/* */
/* If the name is not found in the environment, */
/* then a new vector of pointers is allocated, */
/* "entry" is put at the end and the global */
/* variable "environ" is updated. */
/* */
/* This function normally returns NULL, but -1 */
/* is returned if it can not allocate enough */
/* space using malloc(3), or "entry" does not */
/* contain a '='. */
/* */
/****************************************************************/
int
putenv( entry )
char *entry;
{
unsigned length;
unsigned size;
char *temp;
char **p;
char **new_environ;
/* Find the length of the "NAME=" */
temp = index(entry,'=');
if ( temp == 0 )
return( -1 );
length = (unsigned) (temp - entry + 1);
/* Scan through the environment looking for "NAME=" */
for ( p=environ; *p != 0 ; p++ )
if ( strncmp( entry, *p, length ) == 0 )
{
*p = entry;
return( 0 );
}
/* The name was not found, build a bigger environment */
size = p - environ;
new_environ = (char **) malloc( (size+2)*PSIZE );
if ( new_environ == (char **) NULL )
return( -1 );
(void) memcpy ((char *) new_environ, (char *) environ, size*PSIZE );
new_environ[size] = entry;
new_environ[size+1] = NULL;
environ = new_environ;
return(0);
}