mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
perf help: Remove use of die and handle errors
Allows perf to clean up properly on exit. Signed-off-by: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/1346005487-62961-6-git-send-email-dsahern@gmail.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
fceda7feb4
commit
cc58482133
@ -24,13 +24,14 @@ static struct man_viewer_info_list {
|
|||||||
} *man_viewer_info_list;
|
} *man_viewer_info_list;
|
||||||
|
|
||||||
enum help_format {
|
enum help_format {
|
||||||
|
HELP_FORMAT_NONE,
|
||||||
HELP_FORMAT_MAN,
|
HELP_FORMAT_MAN,
|
||||||
HELP_FORMAT_INFO,
|
HELP_FORMAT_INFO,
|
||||||
HELP_FORMAT_WEB,
|
HELP_FORMAT_WEB,
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool show_all = false;
|
static bool show_all = false;
|
||||||
static enum help_format help_format = HELP_FORMAT_MAN;
|
static enum help_format help_format = HELP_FORMAT_NONE;
|
||||||
static struct option builtin_help_options[] = {
|
static struct option builtin_help_options[] = {
|
||||||
OPT_BOOLEAN('a', "all", &show_all, "print all available commands"),
|
OPT_BOOLEAN('a', "all", &show_all, "print all available commands"),
|
||||||
OPT_SET_UINT('m', "man", &help_format, "show man page", HELP_FORMAT_MAN),
|
OPT_SET_UINT('m', "man", &help_format, "show man page", HELP_FORMAT_MAN),
|
||||||
@ -54,7 +55,9 @@ static enum help_format parse_help_format(const char *format)
|
|||||||
return HELP_FORMAT_INFO;
|
return HELP_FORMAT_INFO;
|
||||||
if (!strcmp(format, "web") || !strcmp(format, "html"))
|
if (!strcmp(format, "web") || !strcmp(format, "html"))
|
||||||
return HELP_FORMAT_WEB;
|
return HELP_FORMAT_WEB;
|
||||||
die("unrecognized help format '%s'", format);
|
|
||||||
|
pr_err("unrecognized help format '%s'", format);
|
||||||
|
return HELP_FORMAT_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *get_man_viewer_info(const char *name)
|
static const char *get_man_viewer_info(const char *name)
|
||||||
@ -259,6 +262,8 @@ static int perf_help_config(const char *var, const char *value, void *cb)
|
|||||||
if (!value)
|
if (!value)
|
||||||
return config_error_nonbool(var);
|
return config_error_nonbool(var);
|
||||||
help_format = parse_help_format(value);
|
help_format = parse_help_format(value);
|
||||||
|
if (help_format == HELP_FORMAT_NONE)
|
||||||
|
return -1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (!strcmp(var, "man.viewer")) {
|
if (!strcmp(var, "man.viewer")) {
|
||||||
@ -352,7 +357,7 @@ static void exec_viewer(const char *name, const char *page)
|
|||||||
warning("'%s': unknown man viewer.", name);
|
warning("'%s': unknown man viewer.", name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void show_man_page(const char *perf_cmd)
|
static int show_man_page(const char *perf_cmd)
|
||||||
{
|
{
|
||||||
struct man_viewer_list *viewer;
|
struct man_viewer_list *viewer;
|
||||||
const char *page = cmd_to_page(perf_cmd);
|
const char *page = cmd_to_page(perf_cmd);
|
||||||
@ -365,28 +370,35 @@ static void show_man_page(const char *perf_cmd)
|
|||||||
if (fallback)
|
if (fallback)
|
||||||
exec_viewer(fallback, page);
|
exec_viewer(fallback, page);
|
||||||
exec_viewer("man", page);
|
exec_viewer("man", page);
|
||||||
die("no man viewer handled the request");
|
|
||||||
|
pr_err("no man viewer handled the request");
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void show_info_page(const char *perf_cmd)
|
static int show_info_page(const char *perf_cmd)
|
||||||
{
|
{
|
||||||
const char *page = cmd_to_page(perf_cmd);
|
const char *page = cmd_to_page(perf_cmd);
|
||||||
setenv("INFOPATH", system_path(PERF_INFO_PATH), 1);
|
setenv("INFOPATH", system_path(PERF_INFO_PATH), 1);
|
||||||
execlp("info", "info", "perfman", page, NULL);
|
execlp("info", "info", "perfman", page, NULL);
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void get_html_page_path(struct strbuf *page_path, const char *page)
|
static int get_html_page_path(struct strbuf *page_path, const char *page)
|
||||||
{
|
{
|
||||||
struct stat st;
|
struct stat st;
|
||||||
const char *html_path = system_path(PERF_HTML_PATH);
|
const char *html_path = system_path(PERF_HTML_PATH);
|
||||||
|
|
||||||
/* Check that we have a perf documentation directory. */
|
/* Check that we have a perf documentation directory. */
|
||||||
if (stat(mkpath("%s/perf.html", html_path), &st)
|
if (stat(mkpath("%s/perf.html", html_path), &st)
|
||||||
|| !S_ISREG(st.st_mode))
|
|| !S_ISREG(st.st_mode)) {
|
||||||
die("'%s': not a documentation directory.", html_path);
|
pr_err("'%s': not a documentation directory.", html_path);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
strbuf_init(page_path, 0);
|
strbuf_init(page_path, 0);
|
||||||
strbuf_addf(page_path, "%s/%s.html", html_path, page);
|
strbuf_addf(page_path, "%s/%s.html", html_path, page);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -401,19 +413,23 @@ static void open_html(const char *path)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void show_html_page(const char *perf_cmd)
|
static int show_html_page(const char *perf_cmd)
|
||||||
{
|
{
|
||||||
const char *page = cmd_to_page(perf_cmd);
|
const char *page = cmd_to_page(perf_cmd);
|
||||||
struct strbuf page_path; /* it leaks but we exec bellow */
|
struct strbuf page_path; /* it leaks but we exec bellow */
|
||||||
|
|
||||||
get_html_page_path(&page_path, page);
|
if (get_html_page_path(&page_path, page) != 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
open_html(page_path.buf);
|
open_html(page_path.buf);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int cmd_help(int argc, const char **argv, const char *prefix __used)
|
int cmd_help(int argc, const char **argv, const char *prefix __used)
|
||||||
{
|
{
|
||||||
const char *alias;
|
const char *alias;
|
||||||
|
int rc = 0;
|
||||||
|
|
||||||
load_command_list("perf-", &main_cmds, &other_cmds);
|
load_command_list("perf-", &main_cmds, &other_cmds);
|
||||||
|
|
||||||
@ -444,16 +460,20 @@ int cmd_help(int argc, const char **argv, const char *prefix __used)
|
|||||||
|
|
||||||
switch (help_format) {
|
switch (help_format) {
|
||||||
case HELP_FORMAT_MAN:
|
case HELP_FORMAT_MAN:
|
||||||
show_man_page(argv[0]);
|
rc = show_man_page(argv[0]);
|
||||||
break;
|
break;
|
||||||
case HELP_FORMAT_INFO:
|
case HELP_FORMAT_INFO:
|
||||||
show_info_page(argv[0]);
|
rc = show_info_page(argv[0]);
|
||||||
break;
|
break;
|
||||||
case HELP_FORMAT_WEB:
|
case HELP_FORMAT_WEB:
|
||||||
show_html_page(argv[0]);
|
rc = show_html_page(argv[0]);
|
||||||
|
break;
|
||||||
|
case HELP_FORMAT_NONE:
|
||||||
|
/* fall-through */
|
||||||
default:
|
default:
|
||||||
|
rc = -1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return rc;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user