1
1

Update the opal_environ code so it behaves correct with the environ if setenv is not available

Этот коммит содержится в:
Ralph Castain 2014-11-05 08:54:06 -08:00
родитель 7327b13823
Коммит 2c9987b7d1

Просмотреть файл

@ -123,15 +123,38 @@ int opal_setenv(const char *name, const char *value, bool overwrite,
/* If this is the "environ" array, use putenv */ /* If this is the "environ" array, use putenv */
if( *env == environ ) { if( *env == environ ) {
/* THIS IS POTENTIALLY A MEMORY LEAK! But I am doing it /* THIS IS POTENTIALLY A MEMORY LEAK! But I am doing it
because so that we don't violate the law of least so that we don't violate the law of least
astonishment for OPAL developers (i.e., those that don't astonishment for OPAL developers (i.e., those that don't
check the return code of opal_setenv() and notice that we check the return code of opal_setenv() and notice that we
returned an error if you passed in the real environ) */ returned an error if you passed in the real environ) */
#if defined (HAVE_SETENV) #if defined (HAVE_SETENV)
setenv(name, value, overwrite); setenv(name, value, overwrite);
/* setenv copies the value, so we can free it here */
free(newvalue); free(newvalue);
#else #else
len - strlen(name);
for (i = 0; (*env)[i] != NULL; ++i) {
if (0 == strncmp((*env)[i], name, len)) {
/* if we find the value in the environ, then
* we need to check the overwrite flag to determine
* the correct response */
if (overwrite) {
/* since it was okay to overwrite, do so */
putenv(newvalue);
/* putenv does NOT copy the value, so we
* cannot free it here */
return OPAL_SUCCESS;
}
/* since overwrite was not allowed, we return
* an error as we cannot perform the requested action */
free(newvalue);
return OPAL_EXISTS;
}
}
/* since the value wasn't found, we can add it */
putenv(newvalue); putenv(newvalue);
/* putenv does NOT copy the value, so we
* cannot free it here */
#endif #endif
return OPAL_SUCCESS; return OPAL_SUCCESS;
} }