freebsd-dev/contrib/libf2c/libF77/getenv_.c

50 lines
1.0 KiB
C
Raw Normal View History

1999-09-18 10:51:31 +00:00
#include "f2c.h"
1999-09-19 05:59:11 +00:00
#undef abs
#include <stdlib.h>
#include <string.h>
2003-07-11 03:42:19 +00:00
extern char *F77_aloc (ftnlen, char *);
1999-09-18 10:51:31 +00:00
/*
* getenv - f77 subroutine to return environment variables
*
* called by:
* call getenv (ENV_NAME, char_var)
* where:
* ENV_NAME is the name of an environment variable
* char_var is a character variable which will receive
* the current value of ENV_NAME, or all blanks
* if ENV_NAME is not defined
*/
2003-07-11 03:42:19 +00:00
void
1999-09-19 05:59:11 +00:00
G77_getenv_0 (char *fname, char *value, ftnlen flen, ftnlen vlen)
1999-09-18 10:51:31 +00:00
{
2003-07-11 03:42:19 +00:00
char buf[256], *ep, *fp;
integer i;
1999-09-18 10:51:31 +00:00
2003-07-11 03:42:19 +00:00
if (flen <= 0)
goto add_blanks;
for (i = 0; i < (integer) sizeof (buf); i++)
{
if (i == flen || (buf[i] = fname[i]) == ' ')
{
buf[i] = 0;
ep = getenv (buf);
goto have_ep;
1999-09-19 05:59:11 +00:00
}
2003-07-11 03:42:19 +00:00
}
while (i < flen && fname[i] != ' ')
i++;
strncpy (fp = F77_aloc (i + 1, "getenv_"), fname, (int) i);
fp[i] = 0;
ep = getenv (fp);
free (fp);
have_ep:
if (ep)
while (*ep && vlen-- > 0)
*value++ = *ep++;
add_blanks:
while (vlen-- > 0)
*value++ = ' ';
}