OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [newlib-1.10.0/] [newlib/] [libc/] [stdlib/] [setenv_r.c] - Diff between revs 1010 and 1765

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 1010 Rev 1765
/* This file may have been modified by DJ Delorie (Jan 1991).  If so,
/* This file may have been modified by DJ Delorie (Jan 1991).  If so,
** these modifications are Copyright (C) 1991 DJ Delorie
** these modifications are Copyright (C) 1991 DJ Delorie
*/
*/
 
 
/*
/*
 * Copyright (c) 1987 Regents of the University of California.
 * Copyright (c) 1987 Regents of the University of California.
 * All rights reserved.
 * All rights reserved.
 *
 *
 * Redistribution and use in source and binary forms are permitted
 * Redistribution and use in source and binary forms are permitted
 * provided that: (1) source distributions retain this entire copyright
 * provided that: (1) source distributions retain this entire copyright
 * notice and comment, and (2) distributions including binaries display
 * notice and comment, and (2) distributions including binaries display
 * the following acknowledgement:  ``This product includes software
 * the following acknowledgement:  ``This product includes software
 * developed by the University of California, Berkeley and its contributors''
 * developed by the University of California, Berkeley and its contributors''
 * in the documentation or other materials provided with the distribution
 * in the documentation or other materials provided with the distribution
 * and in all advertising materials mentioning features or use of this
 * and in all advertising materials mentioning features or use of this
 * software. Neither the name of the University nor the names of its
 * software. Neither the name of the University nor the names of its
 * contributors may be used to endorse or promote products derived
 * contributors may be used to endorse or promote products derived
 * from this software without specific prior written permission.
 * from this software without specific prior written permission.
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 */
 */
 
 
#include <reent.h>
#include <reent.h>
 
 
#include <stddef.h>
#include <stddef.h>
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
#include "envlock.h"
#include "envlock.h"
 
 
extern char **environ;
extern char **environ;
 
 
/* Only deal with a pointer to environ, to work around subtle bugs with shared
/* Only deal with a pointer to environ, to work around subtle bugs with shared
   libraries and/or small data systems where the user declares his own
   libraries and/or small data systems where the user declares his own
   'environ'.  */
   'environ'.  */
static char ***p_environ = &environ;
static char ***p_environ = &environ;
 
 
/* _findenv_r is defined in getenv_r.c.  */
/* _findenv_r is defined in getenv_r.c.  */
extern char *_findenv_r _PARAMS ((struct _reent *, const char *, int *));
extern char *_findenv_r _PARAMS ((struct _reent *, const char *, int *));
 
 
/*
/*
 * _setenv_r --
 * _setenv_r --
 *      Set the value of the environmental variable "name" to be
 *      Set the value of the environmental variable "name" to be
 *      "value".  If rewrite is set, replace any current value.
 *      "value".  If rewrite is set, replace any current value.
 */
 */
 
 
int
int
_DEFUN (_setenv_r, (reent_ptr, name, value, rewrite),
_DEFUN (_setenv_r, (reent_ptr, name, value, rewrite),
        struct _reent *reent_ptr _AND
        struct _reent *reent_ptr _AND
        _CONST char *name _AND
        _CONST char *name _AND
        _CONST char *value _AND
        _CONST char *value _AND
        int rewrite)
        int rewrite)
{
{
  static int alloced;           /* if allocated space before */
  static int alloced;           /* if allocated space before */
  register char *C;
  register char *C;
  int l_value, offset;
  int l_value, offset;
 
 
  ENV_LOCK;
  ENV_LOCK;
 
 
  if (*value == '=')            /* no `=' in value */
  if (*value == '=')            /* no `=' in value */
    ++value;
    ++value;
  l_value = strlen (value);
  l_value = strlen (value);
  if ((C = _findenv_r (reent_ptr, name, &offset)))
  if ((C = _findenv_r (reent_ptr, name, &offset)))
    {                           /* find if already exists */
    {                           /* find if already exists */
      if (!rewrite)
      if (!rewrite)
        {
        {
          ENV_UNLOCK;
          ENV_UNLOCK;
          return 0;
          return 0;
        }
        }
      if (strlen (C) >= l_value)
      if (strlen (C) >= l_value)
        {                       /* old larger; copy over */
        {                       /* old larger; copy over */
         while ((*C++ = *value++) != 0);
         while ((*C++ = *value++) != 0);
          ENV_UNLOCK;
          ENV_UNLOCK;
          return 0;
          return 0;
        }
        }
    }
    }
  else
  else
    {                           /* create new slot */
    {                           /* create new slot */
      register int cnt;
      register int cnt;
      register char **P;
      register char **P;
 
 
      for (P = *p_environ, cnt = 0; *P; ++P, ++cnt);
      for (P = *p_environ, cnt = 0; *P; ++P, ++cnt);
      if (alloced)
      if (alloced)
        {                       /* just increase size */
        {                       /* just increase size */
          *p_environ = (char **) _realloc_r (reent_ptr, (char *) environ,
          *p_environ = (char **) _realloc_r (reent_ptr, (char *) environ,
                                             (size_t) (sizeof (char *) * (cnt + 2)));
                                             (size_t) (sizeof (char *) * (cnt + 2)));
          if (!*p_environ)
          if (!*p_environ)
            {
            {
              ENV_UNLOCK;
              ENV_UNLOCK;
              return -1;
              return -1;
            }
            }
        }
        }
      else
      else
        {                       /* get new space */
        {                       /* get new space */
          alloced = 1;          /* copy old entries into it */
          alloced = 1;          /* copy old entries into it */
          P = (char **) _malloc_r (reent_ptr, (size_t) (sizeof (char *) * (cnt + 2)));
          P = (char **) _malloc_r (reent_ptr, (size_t) (sizeof (char *) * (cnt + 2)));
          if (!P)
          if (!P)
            {
            {
              ENV_UNLOCK;
              ENV_UNLOCK;
              return (-1);
              return (-1);
            }
            }
          bcopy ((char *) *p_environ, (char *) P, cnt * sizeof (char *));
          bcopy ((char *) *p_environ, (char *) P, cnt * sizeof (char *));
          *p_environ = P;
          *p_environ = P;
        }
        }
      (*p_environ)[cnt + 1] = NULL;
      (*p_environ)[cnt + 1] = NULL;
      offset = cnt;
      offset = cnt;
    }
    }
  for (C = (char *) name; *C && *C != '='; ++C);        /* no `=' in name */
  for (C = (char *) name; *C && *C != '='; ++C);        /* no `=' in name */
  if (!((*p_environ)[offset] =  /* name + `=' + value */
  if (!((*p_environ)[offset] =  /* name + `=' + value */
        _malloc_r (reent_ptr, (size_t) ((int) (C - name) + l_value + 2))))
        _malloc_r (reent_ptr, (size_t) ((int) (C - name) + l_value + 2))))
    {
    {
      ENV_UNLOCK;
      ENV_UNLOCK;
      return -1;
      return -1;
    }
    }
  for (C = (*p_environ)[offset]; (*C = *name++) && *C != '='; ++C);
  for (C = (*p_environ)[offset]; (*C = *name++) && *C != '='; ++C);
  for (*C++ = '='; (*C++ = *value++) != 0;);
  for (*C++ = '='; (*C++ = *value++) != 0;);
 
 
  ENV_UNLOCK;
  ENV_UNLOCK;
 
 
  return 0;
  return 0;
}
}
 
 
/*
/*
 * _unsetenv_r(name) --
 * _unsetenv_r(name) --
 *      Delete environmental variable "name".
 *      Delete environmental variable "name".
 */
 */
void
void
_DEFUN (_unsetenv_r, (reent_ptr, name),
_DEFUN (_unsetenv_r, (reent_ptr, name),
        struct _reent *reent_ptr _AND
        struct _reent *reent_ptr _AND
        _CONST char *name)
        _CONST char *name)
{
{
  register char **P;
  register char **P;
  int offset;
  int offset;
 
 
  ENV_LOCK;
  ENV_LOCK;
 
 
  while (_findenv_r (reent_ptr, name, &offset)) /* if set multiple times */
  while (_findenv_r (reent_ptr, name, &offset)) /* if set multiple times */
    for (P = &(*p_environ)[offset];; ++P)
    for (P = &(*p_environ)[offset];; ++P)
      if (!(*P = *(P + 1)))
      if (!(*P = *(P + 1)))
        break;
        break;
 
 
  ENV_UNLOCK;
  ENV_UNLOCK;
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.