Commit f4536ddd authored by Namhyung Kim's avatar Namhyung Kim Committed by Arnaldo Carvalho de Melo

perf hists browser: Factor out hist_browser__show_callchain_entry()

Factor out duplicate callchain printing code into the hist_browser__
show_callchain_entry().
Signed-off-by: default avatarNamhyung Kim <namhyung@kernel.org>
Cc: Andi Kleen <andi@firstfloor.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung.kim@lge.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/1408522080-26556-3-git-send-email-namhyung@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 2bfa1528
...@@ -477,6 +477,29 @@ static char *callchain_list__sym_name(struct callchain_list *cl, ...@@ -477,6 +477,29 @@ static char *callchain_list__sym_name(struct callchain_list *cl,
return bf; return bf;
} }
static void hist_browser__show_callchain_entry(struct hist_browser *browser,
struct callchain_list *chain,
unsigned short row, int offset,
char folded_sign, const char *str,
bool *is_current_entry)
{
int color, width;
color = HE_COLORSET_NORMAL;
width = browser->b.width - (offset + 2);
if (ui_browser__is_current_entry(&browser->b, row)) {
browser->selection = &chain->ms;
color = HE_COLORSET_SELECTED;
*is_current_entry = true;
}
ui_browser__set_color(&browser->b, color);
hist_browser__gotorc(browser, row, 0);
slsmg_write_nstring(" ", offset);
slsmg_printf("%c ", folded_sign);
slsmg_write_nstring(str, width);
}
#define LEVEL_OFFSET_STEP 3 #define LEVEL_OFFSET_STEP 3
static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browser, static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browser,
...@@ -487,7 +510,7 @@ static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browse ...@@ -487,7 +510,7 @@ static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browse
bool *is_current_entry) bool *is_current_entry)
{ {
struct rb_node *node; struct rb_node *node;
int first_row = row, width, offset = level * LEVEL_OFFSET_STEP; int first_row = row, offset = level * LEVEL_OFFSET_STEP;
u64 new_total; u64 new_total;
if (callchain_param.mode == CHAIN_GRAPH_REL) if (callchain_param.mode == CHAIN_GRAPH_REL)
...@@ -508,7 +531,6 @@ static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browse ...@@ -508,7 +531,6 @@ static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browse
list_for_each_entry(chain, &child->val, list) { list_for_each_entry(chain, &child->val, list) {
char bf[1024], *alloc_str; char bf[1024], *alloc_str;
const char *str; const char *str;
int color;
bool was_first = first; bool was_first = first;
if (first) if (first)
...@@ -534,19 +556,10 @@ static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browse ...@@ -534,19 +556,10 @@ static int hist_browser__show_callchain_node_rb_tree(struct hist_browser *browse
str = alloc_str; str = alloc_str;
} }
color = HE_COLORSET_NORMAL; hist_browser__show_callchain_entry(browser, chain, row,
width = browser->b.width - (offset + extra_offset + 2); offset + extra_offset,
if (ui_browser__is_current_entry(&browser->b, row)) { folded_sign, str,
browser->selection = &chain->ms; is_current_entry);
color = HE_COLORSET_SELECTED;
*is_current_entry = true;
}
ui_browser__set_color(&browser->b, color);
hist_browser__gotorc(browser, row, 0);
slsmg_write_nstring(" ", offset + extra_offset);
slsmg_printf("%c ", folded_sign);
slsmg_write_nstring(str, width);
free(alloc_str); free(alloc_str);
if (++row == browser->b.rows) if (++row == browser->b.rows)
...@@ -577,14 +590,12 @@ static int hist_browser__show_callchain_node(struct hist_browser *browser, ...@@ -577,14 +590,12 @@ static int hist_browser__show_callchain_node(struct hist_browser *browser,
bool *is_current_entry) bool *is_current_entry)
{ {
struct callchain_list *chain; struct callchain_list *chain;
int first_row = row, int first_row = row;
offset = level * LEVEL_OFFSET_STEP, int offset = level * LEVEL_OFFSET_STEP;
width = browser->b.width - offset;
char folded_sign = ' '; char folded_sign = ' ';
list_for_each_entry(chain, &node->val, list) { list_for_each_entry(chain, &node->val, list) {
char bf[1024], *s; char bf[1024], *s;
int color;
folded_sign = callchain_list__folded(chain); folded_sign = callchain_list__folded(chain);
...@@ -593,20 +604,11 @@ static int hist_browser__show_callchain_node(struct hist_browser *browser, ...@@ -593,20 +604,11 @@ static int hist_browser__show_callchain_node(struct hist_browser *browser,
continue; continue;
} }
color = HE_COLORSET_NORMAL;
if (ui_browser__is_current_entry(&browser->b, row)) {
browser->selection = &chain->ms;
color = HE_COLORSET_SELECTED;
*is_current_entry = true;
}
s = callchain_list__sym_name(chain, bf, sizeof(bf), s = callchain_list__sym_name(chain, bf, sizeof(bf),
browser->show_dso); browser->show_dso);
hist_browser__gotorc(browser, row, 0); hist_browser__show_callchain_entry(browser, chain, row,
ui_browser__set_color(&browser->b, color); offset, folded_sign, s,
slsmg_write_nstring(" ", offset); is_current_entry);
slsmg_printf("%c ", folded_sign);
slsmg_write_nstring(s, width - 2);
if (++row == browser->b.rows) if (++row == browser->b.rows)
goto out; goto out;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment