freebsd-dev/crypto/heimdal/lib/roken/environment.c

154 lines
3.8 KiB
C
Raw Normal View History

2001-02-13 16:46:19 +00:00
/*
2011-10-05 07:23:29 +00:00
* Copyright (c) 2000, 2005 Kungliga Tekniska Högskolan
2001-02-13 16:46:19 +00:00
* (Royal Institute of Technology, Stockholm, Sweden).
* All rights reserved.
2011-10-05 07:23:29 +00:00
*
2001-02-13 16:46:19 +00:00
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
2011-10-05 07:23:29 +00:00
*
2001-02-13 16:46:19 +00:00
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
2011-10-05 07:23:29 +00:00
*
2001-02-13 16:46:19 +00:00
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
2011-10-05 07:23:29 +00:00
*
2001-02-13 16:46:19 +00:00
* 3. Neither the name of the Institute nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
2011-10-05 07:23:29 +00:00
*
2001-02-13 16:46:19 +00:00
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#include <config.h>
#include <stdio.h>
#include <string.h>
2008-05-07 13:39:42 +00:00
#include <ctype.h>
2001-02-13 16:46:19 +00:00
#include "roken.h"
2008-05-07 13:39:42 +00:00
/* find assignment in env list; len is length of variable including
2011-10-05 07:23:29 +00:00
* equal
2008-05-07 13:39:42 +00:00
*/
static int
find_var(char **env, char *assignment, size_t len)
{
int i;
for(i = 0; env != NULL && env[i] != NULL; i++)
if(strncmp(env[i], assignment, len) == 0)
return i;
return -1;
}
2001-02-13 16:46:19 +00:00
/*
2008-05-07 13:39:42 +00:00
* return count of environment assignments from open file F in
* assigned and list of malloced strings in env, return 0 or errno
* number
2001-02-13 16:46:19 +00:00
*/
2008-05-07 13:39:42 +00:00
static int
2011-10-05 07:23:29 +00:00
read_env_file(FILE *F, char ***env, int *assigned)
2001-02-13 16:46:19 +00:00
{
2008-05-07 13:39:42 +00:00
int idx = 0;
int i;
2001-02-13 16:46:19 +00:00
char **l;
char buf[BUFSIZ], *p, *r;
2008-05-07 13:39:42 +00:00
char **tmp;
int ret = 0;
2001-02-13 16:46:19 +00:00
2008-05-07 13:39:42 +00:00
*assigned = 0;
2001-02-13 16:46:19 +00:00
2008-05-07 13:39:42 +00:00
for(idx = 0; *env != NULL && (*env)[idx] != NULL; idx++);
2001-02-13 16:46:19 +00:00
l = *env;
2008-05-07 13:39:42 +00:00
2001-02-13 16:46:19 +00:00
/* This is somewhat more relaxed on what it accepts then
* Wietses sysv_environ from K4 was...
*/
while (fgets(buf, BUFSIZ, F) != NULL) {
2008-05-07 13:39:42 +00:00
buf[strcspn(buf, "#\n")] = '\0';
2001-02-13 16:46:19 +00:00
2008-05-07 13:39:42 +00:00
for(p = buf; isspace((unsigned char)*p); p++);
2001-02-13 16:46:19 +00:00
if (*p == '\0')
continue;
2008-05-07 13:39:42 +00:00
/* Here one should check that it's a 'valid' env string... */
2001-02-13 16:46:19 +00:00
r = strchr(p, '=');
if (r == NULL)
continue;
2008-05-07 13:39:42 +00:00
if((i = find_var(l, p, r - p + 1)) >= 0) {
char *val = strdup(p);
if(val == NULL) {
ret = ENOMEM;
break;
}
free(l[i]);
l[i] = val;
(*assigned)++;
continue;
}
tmp = realloc(l, (idx+2) * sizeof (char *));
if(tmp == NULL) {
ret = ENOMEM;
break;
}
l = tmp;
l[idx] = strdup(p);
if(l[idx] == NULL) {
ret = ENOMEM;
break;
}
l[++idx] = NULL;
(*assigned)++;
2001-02-13 16:46:19 +00:00
}
2008-05-07 13:39:42 +00:00
if(ferror(F))
ret = errno;
2001-02-13 16:46:19 +00:00
*env = l;
2008-05-07 13:39:42 +00:00
return ret;
}
/*
2011-10-05 07:23:29 +00:00
* return count of environment assignments from file and
2008-05-07 13:39:42 +00:00
* list of malloced strings in `env'
*/
2011-10-05 07:23:29 +00:00
ROKEN_LIB_FUNCTION int ROKEN_LIB_CALL
2008-05-07 13:39:42 +00:00
read_environment(const char *file, char ***env)
{
int assigned;
FILE *F;
if ((F = fopen(file, "r")) == NULL)
return 0;
2011-10-05 07:23:29 +00:00
read_env_file(F, env, &assigned);
2008-05-07 13:39:42 +00:00
fclose(F);
return assigned;
}
2011-10-05 07:23:29 +00:00
ROKEN_LIB_FUNCTION void ROKEN_LIB_CALL
2008-05-07 13:39:42 +00:00
free_environment(char **env)
{
int i;
if (env == NULL)
return;
for (i = 0; env[i]; i++)
free(env[i]);
free(env);
2001-02-13 16:46:19 +00:00
}