Replaced some stderr fprintfs with opal_show_help functions, with
more user friendly error messages. Removed the "--version" command line option, since they should get this from ompi_info [later to be orte_info]. If we find an invalid command line option print out the help screen before exiting. This commit was SVN r6670.
Этот коммит содержится в:
родитель
4959a2ca92
Коммит
8deed21e00
@ -21,3 +21,13 @@ Usage: %s [OPTION]...
|
|||||||
Start an Open RTE Daemon
|
Start an Open RTE Daemon
|
||||||
|
|
||||||
%s
|
%s
|
||||||
|
[orted:environ]
|
||||||
|
Error: Could not set %s in environ.
|
||||||
|
Open RTE Daemon was unable to set
|
||||||
|
%s = %s
|
||||||
|
in the environment. Returned value %d instead of ORTE_SUCCESS.
|
||||||
|
|
||||||
|
[orted:init-failure]
|
||||||
|
Open RTE was unable to initialize properly. The error occured while
|
||||||
|
attempting to %s. Returned value %d instead of ORTE_SUCCESS.
|
||||||
|
|
||||||
|
@ -78,10 +78,6 @@ opal_cmd_line_init_t orte_cmd_line_opts[] = {
|
|||||||
&orted_globals.help, OPAL_CMD_LINE_TYPE_BOOL,
|
&orted_globals.help, OPAL_CMD_LINE_TYPE_BOOL,
|
||||||
"This help message" },
|
"This help message" },
|
||||||
|
|
||||||
{ NULL, NULL, NULL, '\0', NULL, "version", 0,
|
|
||||||
&orted_globals.version, OPAL_CMD_LINE_TYPE_BOOL,
|
|
||||||
"Show the orted version" },
|
|
||||||
|
|
||||||
{ "orte", "debug", NULL, 'd', NULL, "debug", 0,
|
{ "orte", "debug", NULL, 'd', NULL, "debug", 0,
|
||||||
&orted_globals.debug, OPAL_CMD_LINE_TYPE_BOOL,
|
&orted_globals.debug, OPAL_CMD_LINE_TYPE_BOOL,
|
||||||
"Debug the OpenRTE" },
|
"Debug the OpenRTE" },
|
||||||
@ -173,10 +169,15 @@ int main(int argc, char *argv[])
|
|||||||
opal_cmd_line_create(cmd_line, orte_cmd_line_opts);
|
opal_cmd_line_create(cmd_line, orte_cmd_line_opts);
|
||||||
if (OMPI_SUCCESS != (ret = opal_cmd_line_parse(cmd_line, false,
|
if (OMPI_SUCCESS != (ret = opal_cmd_line_parse(cmd_line, false,
|
||||||
argc, argv))) {
|
argc, argv))) {
|
||||||
|
char *args = NULL;
|
||||||
|
args = opal_cmd_line_get_usage_msg(cmd_line);
|
||||||
|
opal_show_help("help-orted.txt", "orted:usage", false,
|
||||||
|
argv[0], args);
|
||||||
|
free(args);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check for help and version requests */
|
/* check for help request */
|
||||||
if (orted_globals.help) {
|
if (orted_globals.help) {
|
||||||
char *args = NULL;
|
char *args = NULL;
|
||||||
args = opal_cmd_line_get_usage_msg(cmd_line);
|
args = opal_cmd_line_get_usage_msg(cmd_line);
|
||||||
@ -186,12 +187,6 @@ int main(int argc, char *argv[])
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (orted_globals.version) {
|
|
||||||
/* show version message */
|
|
||||||
printf("...showing off my version!\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Okay, now on to serious business
|
/* Okay, now on to serious business
|
||||||
* First, ensure the process info structure in instantiated and initialized
|
* First, ensure the process info structure in instantiated and initialized
|
||||||
* and set the daemon flag to true
|
* and set the daemon flag to true
|
||||||
@ -206,12 +201,14 @@ int main(int argc, char *argv[])
|
|||||||
if (orted_globals.name) {
|
if (orted_globals.name) {
|
||||||
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds",
|
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds",
|
||||||
"env", true, &environ))) {
|
"env", true, &environ))) {
|
||||||
fprintf(stderr, "orted: could not set my name in environ\n");
|
opal_show_help("help-orted.txt", "orted:environ", false,
|
||||||
|
"OMPI_MCA_ns_nds", "env", ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds_name",
|
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds_name",
|
||||||
orted_globals.name, true, &environ))) {
|
orted_globals.name, true, &environ))) {
|
||||||
fprintf(stderr, "orted: could not set my name in environ\n");
|
opal_show_help("help-orted.txt", "orted:environ", false,
|
||||||
|
"OMPI_MCA_ns_nds_name", orted_globals.name, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
/* the following values are meaningless to the daemon, but may have
|
/* the following values are meaningless to the daemon, but may have
|
||||||
@ -220,12 +217,14 @@ int main(int argc, char *argv[])
|
|||||||
*/
|
*/
|
||||||
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds_vpid_start",
|
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds_vpid_start",
|
||||||
orted_globals.vpid_start, true, &environ))) {
|
orted_globals.vpid_start, true, &environ))) {
|
||||||
fprintf(stderr, "orted: could not set vpid_start in environ\n");
|
opal_show_help("help-orted.txt", "orted:environ", false,
|
||||||
|
"OMPI_MCA_ns_nds_vpid_start", orted_globals.vpid_start, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds_num_procs",
|
if (ORTE_SUCCESS != (ret = opal_setenv("OMPI_MCA_ns_nds_num_procs",
|
||||||
orted_globals.num_procs, true, &environ))) {
|
orted_globals.num_procs, true, &environ))) {
|
||||||
fprintf(stderr, "orted: could not set num_procs in environ\n");
|
opal_show_help("help-orted.txt", "orted:environ", false,
|
||||||
|
"OMPI_MCA_ns_nds_num_procs", orted_globals.num_procs, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -254,7 +253,8 @@ int main(int argc, char *argv[])
|
|||||||
mca_base_param_set_int(ret, 1);
|
mca_base_param_set_int(ret, 1);
|
||||||
|
|
||||||
if (ORTE_SUCCESS != (ret = orte_init())) {
|
if (ORTE_SUCCESS != (ret = orte_init())) {
|
||||||
fprintf(stderr, "orted: failed to init rte\n");
|
opal_show_help("help-orted.txt", "orted:init-failure", false,
|
||||||
|
"orte_init()", ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,7 +48,6 @@ typedef uint16_t orte_daemon_cmd_flag_t;
|
|||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
bool help;
|
bool help;
|
||||||
bool version;
|
|
||||||
bool no_daemonize;
|
bool no_daemonize;
|
||||||
bool debug;
|
bool debug;
|
||||||
bool debug_daemons;
|
bool debug_daemons;
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user