perf tools: Skip elided sort entries
authorNamhyung Kim <namhyung@kernel.org>
Tue, 18 Mar 2014 04:00:59 +0000 (13:00 +0900)
committerJiri Olsa <jolsa@kernel.org>
Wed, 21 May 2014 09:45:36 +0000 (11:45 +0200)
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>
tools/perf/ui/browsers/hists.c
tools/perf/ui/gtk/hists.c
tools/perf/ui/stdio/hist.c
tools/perf/util/hist.c
tools/perf/util/hist.h
tools/perf/util/sort.c

index 169224c3158683c850950dc5336ffac5c7ba370a..1c331b934ffc50747c1b6df0ba6658e81fe8971d 100644 (file)
@@ -711,6 +711,9 @@ static int hist_browser__show_entry(struct hist_browser *browser,
                ui_browser__gotorc(&browser->b, row, 0);
 
                perf_hpp__for_each_format(fmt) {
+                       if (perf_hpp__should_skip(fmt))
+                               continue;
+
                        if (current_entry && browser->b.navkeypressed) {
                                ui_browser__set_color(&browser->b,
                                                      HE_COLORSET_SELECTED);
@@ -1100,6 +1103,9 @@ static int hist_browser__fprintf_entry(struct hist_browser *browser,
                printed += fprintf(fp, "%c ", folded_sign);
 
        perf_hpp__for_each_format(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                if (!first) {
                        ret = scnprintf(hpp.buf, hpp.size, "  ");
                        advance_hpp(&hpp, ret);
index fd52669018eecccd7cfc08646a3aeb8b554049d3..9d90683914d46cc28c1aa88db2e2d54e863f5ae9 100644 (file)
@@ -178,6 +178,9 @@ static void perf_gtk__show_hists(GtkWidget *window, struct hists *hists,
        col_idx = 0;
 
        perf_hpp__for_each_format(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                fmt->header(fmt, &hpp, hists_to_evsel(hists));
 
                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;
 
                perf_hpp__for_each_format(fmt) {
+                       if (perf_hpp__should_skip(fmt))
+                               continue;
+
                        if (fmt->color)
                                fmt->color(fmt, &hpp, h);
                        else
index 49e2e4a7346a4c8c859f231db7be2df2fbf0547d..e3fdf4e869fc121446b75778d91db9c3ebd57857 100644 (file)
@@ -318,6 +318,9 @@ static int hist_entry__snprintf(struct hist_entry *he, struct perf_hpp *hpp)
                return 0;
 
        perf_hpp__for_each_format(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                /*
                 * If there's no field_sep, we still need
                 * to display initial '  '.
@@ -407,6 +410,9 @@ size_t hists__fprintf(struct hists *hists, bool show_header, int max_rows,
        fprintf(fp, "# ");
 
        perf_hpp__for_each_format(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                if (!first)
                        fprintf(fp, "%s", sep ?: "  ");
                else
@@ -430,6 +436,9 @@ size_t hists__fprintf(struct hists *hists, bool show_header, int max_rows,
        perf_hpp__for_each_format(fmt) {
                unsigned int i;
 
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                if (!first)
                        fprintf(fp, "%s", sep ?: "  ");
                else
index ae13c2dbd27a72c8e321e02ee8d6ce82b0755093..b262b44b7a656d8dca4fcab7488e43e3c49ebb8c 100644 (file)
@@ -436,6 +436,9 @@ hist_entry__cmp(struct hist_entry *left, struct hist_entry *right)
        int64_t cmp = 0;
 
        perf_hpp__for_each_sort_list(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                cmp = fmt->cmp(left, right);
                if (cmp)
                        break;
@@ -451,6 +454,9 @@ hist_entry__collapse(struct hist_entry *left, struct hist_entry *right)
        int64_t cmp = 0;
 
        perf_hpp__for_each_sort_list(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                cmp = fmt->collapse(left, right);
                if (cmp)
                        break;
@@ -570,6 +576,9 @@ static int hist_entry__sort(struct hist_entry *a, struct hist_entry *b)
        int64_t cmp = 0;
 
        perf_hpp__for_each_sort_list(fmt) {
+               if (perf_hpp__should_skip(fmt))
+                       continue;
+
                cmp = fmt->sort(a, b);
                if (cmp)
                        break;
index f3713b79742d08d46d70831a8a8ffc937e044ab1..f67feb432a44c3e55f1cda146ce2e13f1fa775b5 100644 (file)
@@ -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__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 int (*hpp_callback_fn)(struct perf_hpp *hpp, bool front);
index 5414ba541e473bc5c695116e88cb5884f305fde1..0fe7cbe47ea34790680705b5151852598aeea4ff 100644 (file)
@@ -1358,6 +1358,17 @@ static int __setup_sorting(void)
        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,
                                    struct strlist *list,
                                    const char *list_name, FILE *fp)