Blame src/clients/ksu/setenv.c

Packit fd8b60
/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */
Packit fd8b60
/*
Packit fd8b60
 * Copyright (c) 1987 Regents of the University of California.
Packit fd8b60
 * All rights reserved.
Packit fd8b60
 *
Packit fd8b60
 * Redistribution and use in source and binary forms are permitted
Packit fd8b60
 * provided that the above copyright notice and this paragraph are
Packit fd8b60
 * duplicated in all such forms and that any documentation,
Packit fd8b60
 * advertising materials, and other materials related to such
Packit fd8b60
 * distribution and use acknowledge that the software was developed
Packit fd8b60
 * by the University of California, Berkeley.  The name of the
Packit fd8b60
 * University may not be used to endorse or promote products derived
Packit fd8b60
 * from this software without specific prior written permission.
Packit fd8b60
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
Packit fd8b60
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
Packit fd8b60
 * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
Packit fd8b60
 */
Packit fd8b60
/*
Packit fd8b60
 * Copyright (c) 1987 Regents of the University of California.
Packit fd8b60
 * All rights reserved.
Packit fd8b60
 *
Packit fd8b60
 * Redistribution and use in source and binary forms are permitted
Packit fd8b60
 * provided that the above copyright notice and this paragraph are
Packit fd8b60
 * duplicated in all such forms and that any documentation,
Packit fd8b60
 * advertising materials, and other materials related to such
Packit fd8b60
 * distribution and use acknowledge that the software was developed
Packit fd8b60
 * by the University of California, Berkeley.  The name of the
Packit fd8b60
 * University may not be used to endorse or promote products derived
Packit fd8b60
 * from this software without specific prior written permission.
Packit fd8b60
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
Packit fd8b60
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
Packit fd8b60
 * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
Packit fd8b60
 */
Packit fd8b60
Packit fd8b60
/* based on @(#)setenv.c        5.2 (Berkeley) 6/27/88 */
Packit fd8b60
Packit fd8b60
#include "autoconf.h"
Packit fd8b60
#include <sys/types.h>
Packit fd8b60
#include <stdio.h>
Packit fd8b60
#include <stdlib.h>
Packit fd8b60
#include <string.h>
Packit fd8b60
Packit fd8b60
static char *_findenv(char *, int *);
Packit fd8b60
Packit fd8b60
#ifndef HAVE_SETENV
Packit fd8b60
extern int setenv(char *, char *, int);
Packit fd8b60
#endif
Packit fd8b60
#ifndef HAVE_UNSETENV
Packit fd8b60
extern void unsetenv(char *);
Packit fd8b60
#endif
Packit fd8b60
Packit fd8b60
/*
Packit fd8b60
 * setenv --
Packit fd8b60
 *      Set the value of the environmental variable "name" to be
Packit fd8b60
 *      "value".  If rewrite is set, replace any current value.
Packit fd8b60
 */
Packit fd8b60
#ifndef HAVE_SETENV
Packit fd8b60
int
Packit fd8b60
setenv(name, value, rewrite)
Packit fd8b60
    char *name, *value;
Packit fd8b60
    int rewrite;
Packit fd8b60
{
Packit fd8b60
    extern char **environ;
Packit fd8b60
    static int alloced;                     /* if allocated space before */
Packit fd8b60
    char *C;
Packit fd8b60
    int l_value, offset;
Packit fd8b60
Packit fd8b60
    if (*value == '=')                      /* no `=' in value */
Packit fd8b60
        ++value;
Packit fd8b60
    l_value = strlen(value);
Packit fd8b60
    if ((C = _findenv(name, &offset))) {    /* find if already exists */
Packit fd8b60
        if (!rewrite)
Packit fd8b60
            return(0);
Packit fd8b60
        if (strlen(C) >= l_value) {     /* old larger; copy over */
Packit fd8b60
            while ((*C++ = *value++));
Packit fd8b60
            return(0);
Packit fd8b60
        }
Packit fd8b60
    }
Packit fd8b60
    else {                                  /* create new slot */
Packit fd8b60
        int    cnt;
Packit fd8b60
        char   **P;
Packit fd8b60
Packit fd8b60
        for (P = environ, cnt = 0; *P; ++P, ++cnt);
Packit fd8b60
        if (alloced) {                  /* just increase size */
Packit fd8b60
            environ = (char **)realloc((char *)environ,
Packit fd8b60
                                       (u_int)(sizeof(char *) * (cnt + 2)));
Packit fd8b60
            if (!environ)
Packit fd8b60
                return(-1);
Packit fd8b60
        }
Packit fd8b60
        else {                          /* get new space */
Packit fd8b60
            alloced = 1;            /* copy old entries into it */
Packit fd8b60
            P = (char **)malloc((u_int)(sizeof(char *) *
Packit fd8b60
                                        (cnt + 2)));
Packit fd8b60
            if (!P)
Packit fd8b60
                return(-1);
Packit fd8b60
            memcpy(P, environ, cnt * sizeof(char *));
Packit fd8b60
            environ = P;
Packit fd8b60
        }
Packit fd8b60
        environ[cnt + 1] = NULL;
Packit fd8b60
        offset = cnt;
Packit fd8b60
    }
Packit fd8b60
    for (C = name; *C && *C != '='; ++C);   /* no `=' in name */
Packit fd8b60
    if (!(environ[offset] =                 /* name + `=' + value */
Packit fd8b60
          malloc((u_int)((int)(C - name) + l_value + 2))))
Packit fd8b60
        return(-1);
Packit fd8b60
    for (C = environ[offset]; (*C = *name++) &&( *C != '='); ++C);
Packit fd8b60
    for (*C++ = '='; (*C++ = *value++) != NULL;);
Packit fd8b60
    return(0);
Packit fd8b60
}
Packit fd8b60
#endif
Packit fd8b60
Packit fd8b60
/*
Packit fd8b60
 * unsetenv(name) --
Packit fd8b60
 *      Delete environmental variable "name".
Packit fd8b60
 */
Packit fd8b60
#ifndef HAVE_UNSETENV
Packit fd8b60
void
Packit fd8b60
unsetenv(name)
Packit fd8b60
    char    *name;
Packit fd8b60
{
Packit fd8b60
    extern  char    **environ;
Packit fd8b60
    char   **P;
Packit fd8b60
    int     offset;
Packit fd8b60
Packit fd8b60
    while (_findenv(name, &offset))         /* if set multiple times */
Packit fd8b60
        for (P = &environ[offset];; ++P)
Packit fd8b60
            if (!(*P = *(P + 1)))
Packit fd8b60
                break;
Packit fd8b60
}
Packit fd8b60
#endif
Packit fd8b60
Packit fd8b60
/* based on @(#)getenv.c        5.5 (Berkeley) 6/27/88 */
Packit fd8b60
Packit fd8b60
/*
Packit fd8b60
 * getenv --
Packit fd8b60
 *      Returns ptr to value associated with name, if any, else NULL.
Packit fd8b60
 */
Packit fd8b60
#ifndef HAVE_GETENV
Packit fd8b60
char *
Packit fd8b60
getenv(name)
Packit fd8b60
    char *name;
Packit fd8b60
{
Packit fd8b60
    int offset;
Packit fd8b60
Packit fd8b60
    return(_findenv(name, &offset));
Packit fd8b60
}
Packit fd8b60
#endif
Packit fd8b60
Packit fd8b60
/*
Packit fd8b60
 * _findenv --
Packit fd8b60
 *      Returns pointer to value associated with name, if any, else NULL.
Packit fd8b60
 *      Sets offset to be the offset of the name/value combination in the
Packit fd8b60
 *      environmental array, for use by setenv(3) and unsetenv(3).
Packit fd8b60
 *      Explicitly removes '=' in argument name.
Packit fd8b60
 *
Packit fd8b60
 */
Packit fd8b60
static char *
Packit fd8b60
_findenv(name, offset)
Packit fd8b60
    char *name;
Packit fd8b60
    int *offset;
Packit fd8b60
{
Packit fd8b60
    extern char **environ;
Packit fd8b60
    int len;
Packit fd8b60
    char **P, *C;
Packit fd8b60
Packit fd8b60
    for (C = name, len = 0; *C && *C != '='; ++C, ++len);
Packit fd8b60
    for (P = environ; *P; ++P)
Packit fd8b60
        if (!strncmp(*P, name, len))
Packit fd8b60
            if (*(C = *P + len) == '=') {
Packit fd8b60
                *offset = P - environ;
Packit fd8b60
                return(++C);
Packit fd8b60
            }
Packit fd8b60
    return(NULL);
Packit fd8b60
}