2007-04-21 00:15:05 +00:00
|
|
|
/*
|
2013-03-27 21:11:47 +00:00
|
|
|
* Copyright (c) 2006-2012 Los Alamos National Security, LLC. All rights
|
2009-07-22 00:02:00 +00:00
|
|
|
* reserved.
|
2007-04-21 00:15:05 +00:00
|
|
|
* Copyright (c) 2007 Cisco Systems, 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 00:53:08 +00:00
|
|
|
* Copyright (c) 2010 Sandia National Laboratories. All rights reserved.
|
2007-04-21 00:15:05 +00:00
|
|
|
* $COPYRIGHT$
|
2009-07-22 00:02:00 +00:00
|
|
|
*
|
2007-04-21 00:15:05 +00:00
|
|
|
* Additional copyrights may follow
|
2009-07-22 00:02:00 +00:00
|
|
|
*
|
2007-04-21 00:15:05 +00:00
|
|
|
* $HEADER$
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
|
2009-03-13 02:10:32 +00:00
|
|
|
#include "opal/constants.h"
|
2007-04-21 00:15:05 +00:00
|
|
|
#include "opal/mca/mca.h"
|
|
|
|
#include "opal/mca/installdirs/installdirs.h"
|
|
|
|
#include "opal/mca/installdirs/base/base.h"
|
|
|
|
#include "opal/mca/installdirs/base/static-components.h"
|
|
|
|
|
|
|
|
opal_install_dirs_t opal_install_dirs;
|
|
|
|
|
2009-07-22 00:02:00 +00:00
|
|
|
#define CONDITIONAL_COPY(target, origin, field) \
|
|
|
|
do { \
|
|
|
|
if (origin.field != NULL && target.field == NULL) { \
|
|
|
|
target.field = origin.field; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
2007-04-21 00:15:05 +00:00
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
static int
|
|
|
|
opal_installdirs_base_open(mca_base_open_flag_t flags)
|
2007-04-21 00:15:05 +00:00
|
|
|
{
|
2013-03-27 21:11:47 +00:00
|
|
|
mca_base_component_list_item_t *component_item;
|
|
|
|
int ret;
|
2007-04-21 00:15:05 +00:00
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
ret = mca_base_framework_components_open (&opal_installdirs_base_framework,
|
|
|
|
flags);
|
|
|
|
if (OPAL_SUCCESS != ret) {
|
|
|
|
return ret;
|
|
|
|
}
|
2007-04-21 00:15:05 +00:00
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
OPAL_LIST_FOREACH(component_item, &opal_installdirs_base_framework.framework_components, mca_base_component_list_item_t) {
|
|
|
|
const opal_installdirs_base_component_t *component =
|
|
|
|
(const opal_installdirs_base_component_t *) component_item->cli_component;
|
2007-04-21 00:15:05 +00:00
|
|
|
|
|
|
|
/* copy over the data, if something isn't already there */
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
prefix);
|
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
|
|
|
exec_prefix);
|
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
|
|
|
bindir);
|
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
|
|
|
sbindir);
|
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
|
|
|
libexecdir);
|
2007-04-21 00:16:31 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
|
|
|
datarootdir);
|
2007-04-21 00:15:05 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
|
|
|
datadir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
sysconfdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
sharedstatedir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
localstatedir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
libdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
includedir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
infodir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2007-04-21 00:15:05 +00:00
|
|
|
mandir);
|
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2014-01-07 23:36:33 +00:00
|
|
|
ompidatadir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2014-01-07 23:36:33 +00:00
|
|
|
ompilibdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
CONDITIONAL_COPY(opal_install_dirs, component->install_dirs_data,
|
2014-01-07 23:36:33 +00:00
|
|
|
ompiincludedir);
|
2007-04-21 00:15:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* expand out all the fields */
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.prefix =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.prefix);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.exec_prefix =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.exec_prefix);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.bindir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.bindir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.sbindir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.sbindir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.libexecdir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.libexecdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.datarootdir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.datarootdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.datadir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.datadir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.sysconfdir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.sysconfdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.sharedstatedir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.sharedstatedir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.localstatedir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.localstatedir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.libdir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.libdir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.includedir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.includedir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.infodir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.infodir);
|
2009-07-22 00:02:00 +00:00
|
|
|
opal_install_dirs.mandir =
|
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 00:53:08 +00:00
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.mandir);
|
2014-01-07 23:36:33 +00:00
|
|
|
opal_install_dirs.ompidatadir =
|
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.ompidatadir);
|
|
|
|
opal_install_dirs.ompilibdir =
|
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.ompilibdir);
|
|
|
|
opal_install_dirs.ompiincludedir =
|
|
|
|
opal_install_dirs_expand_setup(opal_install_dirs.ompiincludedir);
|
2007-04-21 00:15:05 +00:00
|
|
|
|
2007-04-21 00:16:31 +00:00
|
|
|
#if 0
|
|
|
|
fprintf(stderr, "prefix: %s\n", opal_install_dirs.prefix);
|
|
|
|
fprintf(stderr, "exec_prefix: %s\n", opal_install_dirs.exec_prefix);
|
|
|
|
fprintf(stderr, "bindir: %s\n", opal_install_dirs.bindir);
|
|
|
|
fprintf(stderr, "sbindir: %s\n", opal_install_dirs.sbindir);
|
|
|
|
fprintf(stderr, "libexecdir: %s\n", opal_install_dirs.libexecdir);
|
|
|
|
fprintf(stderr, "datarootdir: %s\n", opal_install_dirs.datarootdir);
|
|
|
|
fprintf(stderr, "datadir: %s\n", opal_install_dirs.datadir);
|
|
|
|
fprintf(stderr, "sysconfdir: %s\n", opal_install_dirs.sysconfdir);
|
|
|
|
fprintf(stderr, "sharedstatedir: %s\n", opal_install_dirs.sharedstatedir);
|
|
|
|
fprintf(stderr, "localstatedir: %s\n", opal_install_dirs.localstatedir);
|
|
|
|
fprintf(stderr, "libdir: %s\n", opal_install_dirs.libdir);
|
|
|
|
fprintf(stderr, "includedir: %s\n", opal_install_dirs.includedir);
|
|
|
|
fprintf(stderr, "infodir: %s\n", opal_install_dirs.infodir);
|
|
|
|
fprintf(stderr, "mandir: %s\n", opal_install_dirs.mandir);
|
|
|
|
fprintf(stderr, "pkgdatadir: %s\n", opal_install_dirs.pkgdatadir);
|
|
|
|
fprintf(stderr, "pkglibdir: %s\n", opal_install_dirs.pkglibdir);
|
|
|
|
fprintf(stderr, "pkgincludedir: %s\n", opal_install_dirs.pkgincludedir);
|
|
|
|
#endif
|
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
/* NTH: Is it ok not to close the components? If not we can add a flag
|
|
|
|
to mca_base_framework_components_close to indicate not to deregister
|
|
|
|
variable groups */
|
2007-04-21 00:15:05 +00:00
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
static int
|
2007-04-21 00:15:05 +00:00
|
|
|
opal_installdirs_base_close(void)
|
|
|
|
{
|
|
|
|
free(opal_install_dirs.prefix);
|
|
|
|
free(opal_install_dirs.exec_prefix);
|
|
|
|
free(opal_install_dirs.bindir);
|
|
|
|
free(opal_install_dirs.sbindir);
|
|
|
|
free(opal_install_dirs.libexecdir);
|
2007-04-21 00:16:31 +00:00
|
|
|
free(opal_install_dirs.datarootdir);
|
2007-04-21 00:15:05 +00:00
|
|
|
free(opal_install_dirs.datadir);
|
|
|
|
free(opal_install_dirs.sysconfdir);
|
|
|
|
free(opal_install_dirs.sharedstatedir);
|
|
|
|
free(opal_install_dirs.localstatedir);
|
|
|
|
free(opal_install_dirs.libdir);
|
|
|
|
free(opal_install_dirs.includedir);
|
|
|
|
free(opal_install_dirs.infodir);
|
|
|
|
free(opal_install_dirs.mandir);
|
2014-01-07 23:36:33 +00:00
|
|
|
free(opal_install_dirs.ompidatadir);
|
|
|
|
free(opal_install_dirs.ompilibdir);
|
|
|
|
free(opal_install_dirs.ompiincludedir);
|
2007-04-21 00:15:05 +00:00
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
return mca_base_framework_components_close (&opal_installdirs_base_framework, NULL);
|
2007-04-21 00:15:05 +00:00
|
|
|
}
|
|
|
|
|
2013-03-27 21:11:47 +00:00
|
|
|
/* Declare the installdirs framework */
|
|
|
|
MCA_BASE_FRAMEWORK_DECLARE(opal, installdirs, NULL, NULL, opal_installdirs_base_open,
|
|
|
|
opal_installdirs_base_close, mca_installdirs_base_static_components,
|
|
|
|
MCA_BASE_FRAMEWORK_FLAG_NOREGISTER);
|