Cover the remaining code paths for Java apps to define class path
Refs trac:4926 This commit was SVN r32823. The following Trac tickets were found above: Ticket 4926 --> https://svn.open-mpi.org/trac/ompi/ticket/4926
Этот коммит содержится в:
родитель
9e35f80ab6
Коммит
84810b80fd
@ -2029,19 +2029,19 @@ static int create_app(int argc, char* argv[],
|
|||||||
/* yep - but does it include the path to the mpi libs? */
|
/* yep - but does it include the path to the mpi libs? */
|
||||||
found = true;
|
found = true;
|
||||||
/* check if mpi.jar exists - if so, add it */
|
/* check if mpi.jar exists - if so, add it */
|
||||||
value = opal_os_path(opal_install_dirs.libdir, "mpi.jar", NULL);
|
value = opal_os_path(false, opal_install_dirs.libdir, "mpi.jar", NULL);
|
||||||
if (access(value, F_OK ) != -1) {
|
if (access(value, F_OK ) != -1) {
|
||||||
set_classpath_jar_file(app, i+1, "mpi.jar");
|
set_classpath_jar_file(app, i+1, "mpi.jar");
|
||||||
}
|
}
|
||||||
free(value);
|
free(value);
|
||||||
/* check for oshmem support */
|
/* check for oshmem support */
|
||||||
value = opal_os_path(opal_install_dirs.libdir, "shmem.jar", NULL);
|
value = opal_os_path(false, opal_install_dirs.libdir, "shmem.jar", NULL);
|
||||||
if (access(value, F_OK ) != -1) {
|
if (access(value, F_OK ) != -1) {
|
||||||
set_classpath_jar_file(app, i+1, "shmem.jar");
|
set_classpath_jar_file(app, i+1, "shmem.jar");
|
||||||
}
|
}
|
||||||
free(value);
|
free(value);
|
||||||
/* always add the local directory */
|
/* always add the local directory */
|
||||||
asprintf(&value, "%s:%s", app->argv[i+1], app->cwd);
|
asprintf(&value, "%s:%s", app->cwd, app->argv[i+1]);
|
||||||
free(app->argv[i+1]);
|
free(app->argv[i+1]);
|
||||||
app->argv[i+1] = value;
|
app->argv[i+1] = value;
|
||||||
break;
|
break;
|
||||||
@ -2049,15 +2049,26 @@ static int create_app(int argc, char* argv[],
|
|||||||
}
|
}
|
||||||
if (!found) {
|
if (!found) {
|
||||||
/* check to see if CLASSPATH is in the environment */
|
/* check to see if CLASSPATH is in the environment */
|
||||||
|
found = false; // just to be pedantic
|
||||||
for (i=0; NULL != environ[i]; i++) {
|
for (i=0; NULL != environ[i]; i++) {
|
||||||
if (0 == strncmp(environ[i], "CLASSPATH", strlen("CLASSPATH"))) {
|
if (0 == strncmp(environ[i], "CLASSPATH", strlen("CLASSPATH"))) {
|
||||||
value = strchr(environ[i], '=');
|
value = strchr(environ[i], '=');
|
||||||
++value; /* step over the = */
|
++value; /* step over the = */
|
||||||
opal_argv_insert_element(&app->argv, 1, value);
|
opal_argv_insert_element(&app->argv, 1, value);
|
||||||
set_classpath_jar_file(app, 1, "mpi.jar");
|
/* check for mpi.jar */
|
||||||
set_classpath_jar_file(app, 1, "shmem.jar");
|
value = opal_os_path(false, opal_install_dirs.libdir, "mpi.jar", NULL);
|
||||||
|
if (access(value, F_OK ) != -1) {
|
||||||
|
set_classpath_jar_file(app, 1, "mpi.jar");
|
||||||
|
}
|
||||||
|
free(value);
|
||||||
|
/* check for shmem.jar */
|
||||||
|
value = opal_os_path(false, opal_install_dirs.libdir, "shmem.jar", NULL);
|
||||||
|
if (access(value, F_OK ) != -1) {
|
||||||
|
set_classpath_jar_file(app, 1, "shmem.jar");
|
||||||
|
}
|
||||||
|
free(value);
|
||||||
/* always add the local directory */
|
/* always add the local directory */
|
||||||
asprintf(&value, "%s:%s", app->cwd, app->argv[1]);
|
(void)asprintf(&value, "%s:%s", app->cwd, app->argv[1]);
|
||||||
free(app->argv[1]);
|
free(app->argv[1]);
|
||||||
app->argv[1] = value;
|
app->argv[1] = value;
|
||||||
opal_argv_insert_element(&app->argv, 1, "-cp");
|
opal_argv_insert_element(&app->argv, 1, "-cp");
|
||||||
@ -2067,13 +2078,30 @@ static int create_app(int argc, char* argv[],
|
|||||||
}
|
}
|
||||||
if (!found) {
|
if (!found) {
|
||||||
/* need to add it right after the java command - have
|
/* need to add it right after the java command - have
|
||||||
* to include the current directory and trust that
|
* to include the working directory and trust that
|
||||||
* the user set cwd if necessary
|
* the user set cwd if necessary
|
||||||
*/
|
*/
|
||||||
asprintf(&value, "%s:%s/mpi.jar:%s/shmem.jar",
|
char *str, *str2;
|
||||||
app->cwd, opal_install_dirs.libdir, opal_install_dirs.libdir);
|
/* always start with the working directory */
|
||||||
opal_argv_insert_element(&app->argv, 1, value);
|
str = strdup(app->cwd);
|
||||||
|
/* check for mpi.jar */
|
||||||
|
value = opal_os_path(false, opal_install_dirs.libdir, "mpi.jar", NULL);
|
||||||
|
if (access(value, F_OK ) != -1) {
|
||||||
|
(void)asprintf(&str2, "%s:%s", str, value);
|
||||||
|
free(str);
|
||||||
|
str = str2;
|
||||||
|
}
|
||||||
free(value);
|
free(value);
|
||||||
|
/* check for shmem.jar */
|
||||||
|
value = opal_os_path(false, opal_install_dirs.libdir, "shmem.jar", NULL);
|
||||||
|
if (access(value, F_OK ) != -1) {
|
||||||
|
asprintf(&str2, "%s:%s", str, value);
|
||||||
|
free(str);
|
||||||
|
str = str2;
|
||||||
|
}
|
||||||
|
free(value);
|
||||||
|
opal_argv_insert_element(&app->argv, 1, str);
|
||||||
|
free(str);
|
||||||
opal_argv_insert_element(&app->argv, 1, "-cp");
|
opal_argv_insert_element(&app->argv, 1, "-cp");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user