mirror of
https://github.com/torvalds/linux.git
synced 2024-11-12 07:01:57 +00:00
perf tools: Skip elided sort entries
When it converted sort entries to hpp formats, it missed se->elide handling, so add it for compatibility. Signed-off-by: Namhyung Kim <namhyung@kernel.org> Link: http://lkml.kernel.org/r/1400480762-22852-16-git-send-email-namhyung@kernel.org Signed-off-by: Jiri Olsa <jolsa@kernel.org>
This commit is contained in:
parent
6fe8c26d7a
commit
e67d49a72d
@ -711,6 +711,9 @@ static int hist_browser__show_entry(struct hist_browser *browser,
|
|||||||
ui_browser__gotorc(&browser->b, row, 0);
|
ui_browser__gotorc(&browser->b, row, 0);
|
||||||
|
|
||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (current_entry && browser->b.navkeypressed) {
|
if (current_entry && browser->b.navkeypressed) {
|
||||||
ui_browser__set_color(&browser->b,
|
ui_browser__set_color(&browser->b,
|
||||||
HE_COLORSET_SELECTED);
|
HE_COLORSET_SELECTED);
|
||||||
@ -1100,6 +1103,9 @@ static int hist_browser__fprintf_entry(struct hist_browser *browser,
|
|||||||
printed += fprintf(fp, "%c ", folded_sign);
|
printed += fprintf(fp, "%c ", folded_sign);
|
||||||
|
|
||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (!first) {
|
if (!first) {
|
||||||
ret = scnprintf(hpp.buf, hpp.size, " ");
|
ret = scnprintf(hpp.buf, hpp.size, " ");
|
||||||
advance_hpp(&hpp, ret);
|
advance_hpp(&hpp, ret);
|
||||||
|
@ -178,6 +178,9 @@ static void perf_gtk__show_hists(GtkWidget *window, struct hists *hists,
|
|||||||
col_idx = 0;
|
col_idx = 0;
|
||||||
|
|
||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
fmt->header(fmt, &hpp, hists_to_evsel(hists));
|
fmt->header(fmt, &hpp, hists_to_evsel(hists));
|
||||||
|
|
||||||
gtk_tree_view_insert_column_with_attributes(GTK_TREE_VIEW(view),
|
gtk_tree_view_insert_column_with_attributes(GTK_TREE_VIEW(view),
|
||||||
@ -222,6 +225,9 @@ static void perf_gtk__show_hists(GtkWidget *window, struct hists *hists,
|
|||||||
col_idx = 0;
|
col_idx = 0;
|
||||||
|
|
||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (fmt->color)
|
if (fmt->color)
|
||||||
fmt->color(fmt, &hpp, h);
|
fmt->color(fmt, &hpp, h);
|
||||||
else
|
else
|
||||||
|
@ -318,6 +318,9 @@ static int hist_entry__snprintf(struct hist_entry *he, struct perf_hpp *hpp)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If there's no field_sep, we still need
|
* If there's no field_sep, we still need
|
||||||
* to display initial ' '.
|
* to display initial ' '.
|
||||||
@ -407,6 +410,9 @@ size_t hists__fprintf(struct hists *hists, bool show_header, int max_rows,
|
|||||||
fprintf(fp, "# ");
|
fprintf(fp, "# ");
|
||||||
|
|
||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (!first)
|
if (!first)
|
||||||
fprintf(fp, "%s", sep ?: " ");
|
fprintf(fp, "%s", sep ?: " ");
|
||||||
else
|
else
|
||||||
@ -430,6 +436,9 @@ size_t hists__fprintf(struct hists *hists, bool show_header, int max_rows,
|
|||||||
perf_hpp__for_each_format(fmt) {
|
perf_hpp__for_each_format(fmt) {
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
if (!first)
|
if (!first)
|
||||||
fprintf(fp, "%s", sep ?: " ");
|
fprintf(fp, "%s", sep ?: " ");
|
||||||
else
|
else
|
||||||
|
@ -436,6 +436,9 @@ hist_entry__cmp(struct hist_entry *left, struct hist_entry *right)
|
|||||||
int64_t cmp = 0;
|
int64_t cmp = 0;
|
||||||
|
|
||||||
perf_hpp__for_each_sort_list(fmt) {
|
perf_hpp__for_each_sort_list(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
cmp = fmt->cmp(left, right);
|
cmp = fmt->cmp(left, right);
|
||||||
if (cmp)
|
if (cmp)
|
||||||
break;
|
break;
|
||||||
@ -451,6 +454,9 @@ hist_entry__collapse(struct hist_entry *left, struct hist_entry *right)
|
|||||||
int64_t cmp = 0;
|
int64_t cmp = 0;
|
||||||
|
|
||||||
perf_hpp__for_each_sort_list(fmt) {
|
perf_hpp__for_each_sort_list(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
cmp = fmt->collapse(left, right);
|
cmp = fmt->collapse(left, right);
|
||||||
if (cmp)
|
if (cmp)
|
||||||
break;
|
break;
|
||||||
@ -570,6 +576,9 @@ static int hist_entry__sort(struct hist_entry *a, struct hist_entry *b)
|
|||||||
int64_t cmp = 0;
|
int64_t cmp = 0;
|
||||||
|
|
||||||
perf_hpp__for_each_sort_list(fmt) {
|
perf_hpp__for_each_sort_list(fmt) {
|
||||||
|
if (perf_hpp__should_skip(fmt))
|
||||||
|
continue;
|
||||||
|
|
||||||
cmp = fmt->sort(a, b);
|
cmp = fmt->sort(a, b);
|
||||||
if (cmp)
|
if (cmp)
|
||||||
break;
|
break;
|
||||||
|
@ -201,6 +201,7 @@ void perf_hpp__append_sort_keys(void);
|
|||||||
|
|
||||||
bool perf_hpp__is_sort_entry(struct perf_hpp_fmt *format);
|
bool perf_hpp__is_sort_entry(struct perf_hpp_fmt *format);
|
||||||
bool perf_hpp__same_sort_entry(struct perf_hpp_fmt *a, struct perf_hpp_fmt *b);
|
bool perf_hpp__same_sort_entry(struct perf_hpp_fmt *a, struct perf_hpp_fmt *b);
|
||||||
|
bool perf_hpp__should_skip(struct perf_hpp_fmt *format);
|
||||||
|
|
||||||
typedef u64 (*hpp_field_fn)(struct hist_entry *he);
|
typedef u64 (*hpp_field_fn)(struct hist_entry *he);
|
||||||
typedef int (*hpp_callback_fn)(struct perf_hpp *hpp, bool front);
|
typedef int (*hpp_callback_fn)(struct perf_hpp *hpp, bool front);
|
||||||
|
@ -1358,6 +1358,17 @@ static int __setup_sorting(void)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool perf_hpp__should_skip(struct perf_hpp_fmt *format)
|
||||||
|
{
|
||||||
|
if (perf_hpp__is_sort_entry(format)) {
|
||||||
|
struct hpp_sort_entry *hse;
|
||||||
|
|
||||||
|
hse = container_of(format, struct hpp_sort_entry, hpp);
|
||||||
|
return hse->se->elide;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static void sort_entry__setup_elide(struct sort_entry *se,
|
static void sort_entry__setup_elide(struct sort_entry *se,
|
||||||
struct strlist *list,
|
struct strlist *list,
|
||||||
const char *list_name, FILE *fp)
|
const char *list_name, FILE *fp)
|
||||||
|
Loading…
Reference in New Issue
Block a user