2007-04-21 04:15:05 +04:00
|
|
|
/*
|
2007-04-21 04:16:31 +04:00
|
|
|
* Copyright (c) 2006-2007 Los Alamos National Security, LLC. All rights
|
2009-07-22 04:02:00 +04:00
|
|
|
* reserved.
|
We (Ralph and Jeff) discovered that if the OPAL_DESTDIR environment
variable was set, it was prefixed to ''all'' values in the wrapper
compiler data text files. For example, if OPAL_DESTDIR was set to
/tmp/bogus and a wrapper compiler data file contained the line:
preprocessor_flags=-pthread
The value would be exanded to:
/tmp/bogus/-pthread
Which is clearly wrong. After some back-and-forth with Ralph and
Brian, Brian submitted this patch that fixes the problem. Now we
handle three cases properly (assume that configure was invoked with
--prefix=/opt/openmpi and no other directory specifications, and
$OPAL_DESTDIR is set to /tmp/buildroot):
1. Individual directories, such as libdir. These need to be prepended
with DESTDIR. I.e., return /tmp/buildroot/opt/openmpi/lib.
2. Compiler flags that have ${FIELD} values embedded in them. For
example, consider if a wrapper compiler data file contains the
line:
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
The value we should return is:
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
3. Compiler flags that do not have any ${FIELD} values. For example,
consider if a wrapper compiler data file contains the line:
preprocessor_flags=-pthread
The value we should return is:
-pthread
Note, too, that this OPAL_DESTDIR futzing only needs to occur during
opal_init(). By the time opal_init() has completed, all values should
be substituted in that need substituting. Hence, we take an extra
parameter (is_setup) to know whether we should do this futzing or
not.
This commit was SVN r23402.
2010-07-14 04:53:08 +04:00
|
|
|
* Copyright (c) 2007-2010 Cisco Systems, Inc. All rights reserved.
|
2009-07-22 04:02:00 +04:00
|
|
|
* Copyright (c) 2007 Sun Microsystem, Inc. All rights reserved.
|
We (Ralph and Jeff) discovered that if the OPAL_DESTDIR environment
variable was set, it was prefixed to ''all'' values in the wrapper
compiler data text files. For example, if OPAL_DESTDIR was set to
/tmp/bogus and a wrapper compiler data file contained the line:
preprocessor_flags=-pthread
The value would be exanded to:
/tmp/bogus/-pthread
Which is clearly wrong. After some back-and-forth with Ralph and
Brian, Brian submitted this patch that fixes the problem. Now we
handle three cases properly (assume that configure was invoked with
--prefix=/opt/openmpi and no other directory specifications, and
$OPAL_DESTDIR is set to /tmp/buildroot):
1. Individual directories, such as libdir. These need to be prepended
with DESTDIR. I.e., return /tmp/buildroot/opt/openmpi/lib.
2. Compiler flags that have ${FIELD} values embedded in them. For
example, consider if a wrapper compiler data file contains the
line:
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
The value we should return is:
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
3. Compiler flags that do not have any ${FIELD} values. For example,
consider if a wrapper compiler data file contains the line:
preprocessor_flags=-pthread
The value we should return is:
-pthread
Note, too, that this OPAL_DESTDIR futzing only needs to occur during
opal_init(). By the time opal_init() has completed, all values should
be substituted in that need substituting. Hence, we take an extra
parameter (is_setup) to know whether we should do this futzing or
not.
This commit was SVN r23402.
2010-07-14 04:53:08 +04:00
|
|
|
* Copyright (c) 2010 Sandia National Laboratories. All rights reserved.
|
2007-04-21 04:15:05 +04:00
|
|
|
* $COPYRIGHT$
|
2009-07-22 04:02:00 +04:00
|
|
|
*
|
2007-04-21 04:15:05 +04:00
|
|
|
* Additional copyrights may follow
|
2009-07-22 04:02:00 +04:00
|
|
|
*
|
2007-04-21 04:15:05 +04:00
|
|
|
* $HEADER$
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "opal/util/os_path.h"
|
|
|
|
#include "opal/mca/installdirs/base/base.h"
|
|
|
|
#include "opal/mca/installdirs/installdirs.h"
|
|
|
|
|
2013-05-11 04:49:17 +04:00
|
|
|
/* Support both ${name} and @{name} forms. The latter allows us to
|
|
|
|
pass values through AC_SUBST without being munged by m4 (e.g., if
|
|
|
|
we want to pass "@{libdir}" and not have it replaced by m4 to be
|
|
|
|
whatever the actual value of the shell variable is. */
|
2009-07-22 04:02:00 +04:00
|
|
|
#define EXPAND_STRING(field) \
|
|
|
|
do { \
|
|
|
|
if (NULL != (start_pos = strstr(retval, "${" #field "}"))) { \
|
|
|
|
tmp = retval; \
|
|
|
|
*start_pos = '\0'; \
|
|
|
|
end_pos = start_pos + strlen("${" #field "}"); \
|
|
|
|
asprintf(&retval, "%s%s%s", tmp, \
|
|
|
|
opal_install_dirs.field + destdir_offset, \
|
|
|
|
end_pos); \
|
|
|
|
free(tmp); \
|
|
|
|
changed = true; \
|
2013-05-11 04:49:17 +04:00
|
|
|
} else if (NULL != (start_pos = strstr(retval, "@{" #field "}"))) { \
|
|
|
|
tmp = retval; \
|
|
|
|
*start_pos = '\0'; \
|
|
|
|
end_pos = start_pos + strlen("@{" #field "}"); \
|
|
|
|
asprintf(&retval, "%s%s%s", tmp, \
|
|
|
|
opal_install_dirs.field + destdir_offset, \
|
|
|
|
end_pos); \
|
|
|
|
free(tmp); \
|
|
|
|
changed = true; \
|
2009-07-22 04:02:00 +04:00
|
|
|
} \
|
|
|
|
} while (0)
|
2007-04-21 04:15:05 +04:00
|
|
|
|
|
|
|
|
We (Ralph and Jeff) discovered that if the OPAL_DESTDIR environment
variable was set, it was prefixed to ''all'' values in the wrapper
compiler data text files. For example, if OPAL_DESTDIR was set to
/tmp/bogus and a wrapper compiler data file contained the line:
preprocessor_flags=-pthread
The value would be exanded to:
/tmp/bogus/-pthread
Which is clearly wrong. After some back-and-forth with Ralph and
Brian, Brian submitted this patch that fixes the problem. Now we
handle three cases properly (assume that configure was invoked with
--prefix=/opt/openmpi and no other directory specifications, and
$OPAL_DESTDIR is set to /tmp/buildroot):
1. Individual directories, such as libdir. These need to be prepended
with DESTDIR. I.e., return /tmp/buildroot/opt/openmpi/lib.
2. Compiler flags that have ${FIELD} values embedded in them. For
example, consider if a wrapper compiler data file contains the
line:
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
The value we should return is:
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
3. Compiler flags that do not have any ${FIELD} values. For example,
consider if a wrapper compiler data file contains the line:
preprocessor_flags=-pthread
The value we should return is:
-pthread
Note, too, that this OPAL_DESTDIR futzing only needs to occur during
opal_init(). By the time opal_init() has completed, all values should
be substituted in that need substituting. Hence, we take an extra
parameter (is_setup) to know whether we should do this futzing or
not.
This commit was SVN r23402.
2010-07-14 04:53:08 +04:00
|
|
|
/*
|
|
|
|
* Read the lengthy comment below to understand the value of the
|
|
|
|
* is_setup parameter.
|
|
|
|
*/
|
|
|
|
static char *
|
|
|
|
opal_install_dirs_expand_internal(const char* input, bool is_setup)
|
2007-04-21 04:15:05 +04:00
|
|
|
{
|
2009-07-22 04:02:00 +04:00
|
|
|
size_t len, i;
|
|
|
|
bool needs_expand = false;
|
2007-07-11 18:00:29 +04:00
|
|
|
char *retval = NULL;
|
We (Ralph and Jeff) discovered that if the OPAL_DESTDIR environment
variable was set, it was prefixed to ''all'' values in the wrapper
compiler data text files. For example, if OPAL_DESTDIR was set to
/tmp/bogus and a wrapper compiler data file contained the line:
preprocessor_flags=-pthread
The value would be exanded to:
/tmp/bogus/-pthread
Which is clearly wrong. After some back-and-forth with Ralph and
Brian, Brian submitted this patch that fixes the problem. Now we
handle three cases properly (assume that configure was invoked with
--prefix=/opt/openmpi and no other directory specifications, and
$OPAL_DESTDIR is set to /tmp/buildroot):
1. Individual directories, such as libdir. These need to be prepended
with DESTDIR. I.e., return /tmp/buildroot/opt/openmpi/lib.
2. Compiler flags that have ${FIELD} values embedded in them. For
example, consider if a wrapper compiler data file contains the
line:
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
The value we should return is:
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
3. Compiler flags that do not have any ${FIELD} values. For example,
consider if a wrapper compiler data file contains the line:
preprocessor_flags=-pthread
The value we should return is:
-pthread
Note, too, that this OPAL_DESTDIR futzing only needs to occur during
opal_init(). By the time opal_init() has completed, all values should
be substituted in that need substituting. Hence, we take an extra
parameter (is_setup) to know whether we should do this futzing or
not.
This commit was SVN r23402.
2010-07-14 04:53:08 +04:00
|
|
|
char *destdir = NULL;
|
2009-07-22 04:02:00 +04:00
|
|
|
size_t destdir_offset = 0;
|
2007-04-21 04:15:05 +04:00
|
|
|
|
We (Ralph and Jeff) discovered that if the OPAL_DESTDIR environment
variable was set, it was prefixed to ''all'' values in the wrapper
compiler data text files. For example, if OPAL_DESTDIR was set to
/tmp/bogus and a wrapper compiler data file contained the line:
preprocessor_flags=-pthread
The value would be exanded to:
/tmp/bogus/-pthread
Which is clearly wrong. After some back-and-forth with Ralph and
Brian, Brian submitted this patch that fixes the problem. Now we
handle three cases properly (assume that configure was invoked with
--prefix=/opt/openmpi and no other directory specifications, and
$OPAL_DESTDIR is set to /tmp/buildroot):
1. Individual directories, such as libdir. These need to be prepended
with DESTDIR. I.e., return /tmp/buildroot/opt/openmpi/lib.
2. Compiler flags that have ${FIELD} values embedded in them. For
example, consider if a wrapper compiler data file contains the
line:
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
The value we should return is:
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
3. Compiler flags that do not have any ${FIELD} values. For example,
consider if a wrapper compiler data file contains the line:
preprocessor_flags=-pthread
The value we should return is:
-pthread
Note, too, that this OPAL_DESTDIR futzing only needs to occur during
opal_init(). By the time opal_init() has completed, all values should
be substituted in that need substituting. Hence, we take an extra
parameter (is_setup) to know whether we should do this futzing or
not.
This commit was SVN r23402.
2010-07-14 04:53:08 +04:00
|
|
|
/* This is subtle, and worth explaining.
|
|
|
|
|
|
|
|
If we substitute in any ${FIELD} values, we need to prepend it
|
|
|
|
with the value of the $OPAL_DESTDIR environment variable -- if
|
|
|
|
it is set.
|
|
|
|
|
|
|
|
We need to handle at least three cases properly (assume that
|
|
|
|
configure was invoked with --prefix=/opt/openmpi and no other
|
|
|
|
directory specifications, and OPAL_DESTDIR is set to
|
|
|
|
/tmp/buildroot):
|
|
|
|
|
|
|
|
1. Individual directories, such as libdir. These need to be
|
|
|
|
prepended with DESTDIR. I.e., return
|
|
|
|
/tmp/buildroot/opt/openmpi/lib.
|
|
|
|
|
|
|
|
2. Compiler flags that have ${FIELD} values embedded in them.
|
|
|
|
For example, consider if a wrapper compiler data file
|
|
|
|
contains the line:
|
|
|
|
|
|
|
|
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
|
|
|
|
|
|
|
|
The value we should return is:
|
|
|
|
|
|
|
|
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
|
|
|
|
|
|
|
|
3. Compiler flags that do not have any ${FIELD} values.
|
|
|
|
For example, consider if a wrapper compiler data file
|
|
|
|
contains the line:
|
|
|
|
|
|
|
|
preprocessor_flags=-pthread
|
|
|
|
|
|
|
|
The value we should return is:
|
|
|
|
|
|
|
|
-pthread
|
|
|
|
|
|
|
|
Note, too, that this OPAL_DESTDIR futzing only needs to occur
|
|
|
|
during opal_init(). By the time opal_init() has completed, all
|
|
|
|
values should be substituted in that need substituting. Hence,
|
|
|
|
we take an extra parameter (is_setup) to know whether we should
|
|
|
|
do this futzing or not. */
|
|
|
|
if (is_setup) {
|
|
|
|
destdir = getenv("OPAL_DESTDIR");
|
|
|
|
if (NULL != destdir && strlen(destdir) > 0) {
|
|
|
|
destdir_offset = strlen(destdir);
|
|
|
|
}
|
2007-04-21 04:15:05 +04:00
|
|
|
}
|
|
|
|
|
2009-07-22 04:02:00 +04:00
|
|
|
len = strlen(input);
|
|
|
|
for (i = 0 ; i < len ; ++i) {
|
2013-05-11 04:49:17 +04:00
|
|
|
if ('$' == input[i] || '@' == input[i]) {
|
2009-07-22 04:02:00 +04:00
|
|
|
needs_expand = true;
|
2007-04-21 04:15:05 +04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-07-22 04:02:00 +04:00
|
|
|
retval = strdup(input);
|
|
|
|
if (NULL == retval) return NULL;
|
|
|
|
|
|
|
|
if (needs_expand) {
|
|
|
|
bool changed = false;
|
|
|
|
char *start_pos, *end_pos, *tmp;
|
|
|
|
|
|
|
|
do {
|
|
|
|
changed = false;
|
|
|
|
EXPAND_STRING(prefix);
|
|
|
|
EXPAND_STRING(exec_prefix);
|
|
|
|
EXPAND_STRING(bindir);
|
|
|
|
EXPAND_STRING(sbindir);
|
|
|
|
EXPAND_STRING(libexecdir);
|
|
|
|
EXPAND_STRING(datarootdir);
|
|
|
|
EXPAND_STRING(datadir);
|
|
|
|
EXPAND_STRING(sysconfdir);
|
|
|
|
EXPAND_STRING(sharedstatedir);
|
|
|
|
EXPAND_STRING(localstatedir);
|
|
|
|
EXPAND_STRING(libdir);
|
|
|
|
EXPAND_STRING(includedir);
|
|
|
|
EXPAND_STRING(infodir);
|
|
|
|
EXPAND_STRING(mandir);
|
|
|
|
EXPAND_STRING(pkgdatadir);
|
|
|
|
EXPAND_STRING(pkglibdir);
|
|
|
|
EXPAND_STRING(pkgincludedir);
|
|
|
|
} while (changed);
|
2007-04-21 04:15:05 +04:00
|
|
|
}
|
|
|
|
|
2009-07-22 04:02:00 +04:00
|
|
|
if (NULL != destdir) {
|
|
|
|
char *tmp = retval;
|
|
|
|
retval = opal_os_path(false, destdir, tmp, NULL);
|
|
|
|
free(tmp);
|
2007-04-21 04:15:05 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
We (Ralph and Jeff) discovered that if the OPAL_DESTDIR environment
variable was set, it was prefixed to ''all'' values in the wrapper
compiler data text files. For example, if OPAL_DESTDIR was set to
/tmp/bogus and a wrapper compiler data file contained the line:
preprocessor_flags=-pthread
The value would be exanded to:
/tmp/bogus/-pthread
Which is clearly wrong. After some back-and-forth with Ralph and
Brian, Brian submitted this patch that fixes the problem. Now we
handle three cases properly (assume that configure was invoked with
--prefix=/opt/openmpi and no other directory specifications, and
$OPAL_DESTDIR is set to /tmp/buildroot):
1. Individual directories, such as libdir. These need to be prepended
with DESTDIR. I.e., return /tmp/buildroot/opt/openmpi/lib.
2. Compiler flags that have ${FIELD} values embedded in them. For
example, consider if a wrapper compiler data file contains the
line:
preprocessor_flags=-DMYFLAG="${prefix}/share/randomthingy/"
The value we should return is:
-DMYFLAG="/tmp/buildroot/opt/openmpi/share/randomthingy/"
3. Compiler flags that do not have any ${FIELD} values. For example,
consider if a wrapper compiler data file contains the line:
preprocessor_flags=-pthread
The value we should return is:
-pthread
Note, too, that this OPAL_DESTDIR futzing only needs to occur during
opal_init(). By the time opal_init() has completed, all values should
be substituted in that need substituting. Hence, we take an extra
parameter (is_setup) to know whether we should do this futzing or
not.
This commit was SVN r23402.
2010-07-14 04:53:08 +04:00
|
|
|
|
|
|
|
|
|
|
|
char *
|
|
|
|
opal_install_dirs_expand(const char* input)
|
|
|
|
{
|
|
|
|
/* We do NOT want OPAL_DESTDIR expansion in this case. */
|
|
|
|
return opal_install_dirs_expand_internal(input, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
char *
|
|
|
|
opal_install_dirs_expand_setup(const char* input)
|
|
|
|
{
|
|
|
|
/* We DO want OPAL_DESTDIR expansion in this case. */
|
|
|
|
return opal_install_dirs_expand_internal(input, true);
|
|
|
|
}
|