forked from Minki/linux
1e259ad4a2
So that we can erase the progress bar after we're done with it, avoiding things like: ------------------------------------------------------------------- ┌─Error:──────────────────────────────────────────────────────┐ │Can't annotate unmapped_area_topdown: │ │ │ │No vmlinux file with build id a826726b5ddacfab1f0bade868f1a79│ │was found in the path. │ │ │ │Note that annotation using /proc/kcore requires CAP_SYS_RAWIO│ ┌Processin│ │──┐ │ │Please use: │ │ └─────────│ │──┘ │ perf buildid-cache -vu vmlinux │ │ │ │or: │ │ │ │ --vmlinux vmlinux │ │ │ │ │ │Press any key... │ └─────────────────────────────────────────────────────────────┘ Can't annotate unmapped_area_topdown: ------------------------------------------------------------------- I.e. that finished progress bar behind the error window. It is not a problem when we end up redrawing the whole screen, but its ugly when we present such error windows, provide a TUI method so that code like the above may avoid this situation, as will be done with the annotation code in the next cset. Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Borislav Petkov <bp@suse.de> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/n/tip-qvktnojzwwe37pweging058t@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
62 lines
1.3 KiB
C
62 lines
1.3 KiB
C
#include "../cache.h"
|
|
#include "../progress.h"
|
|
#include "../libslang.h"
|
|
#include "../ui.h"
|
|
#include "tui.h"
|
|
#include "../browser.h"
|
|
|
|
static void tui_progress__update(struct ui_progress *p)
|
|
{
|
|
int bar, y;
|
|
/*
|
|
* FIXME: We should have a per UI backend way of showing progress,
|
|
* stdio will just show a percentage as NN%, etc.
|
|
*/
|
|
if (use_browser <= 0)
|
|
return;
|
|
|
|
if (p->total == 0)
|
|
return;
|
|
|
|
ui__refresh_dimensions(false);
|
|
pthread_mutex_lock(&ui__lock);
|
|
y = SLtt_Screen_Rows / 2 - 2;
|
|
SLsmg_set_color(0);
|
|
SLsmg_draw_box(y, 0, 3, SLtt_Screen_Cols);
|
|
SLsmg_gotorc(y++, 1);
|
|
SLsmg_write_string((char *)p->title);
|
|
SLsmg_fill_region(y, 1, 1, SLtt_Screen_Cols - 2, ' ');
|
|
SLsmg_set_color(HE_COLORSET_SELECTED);
|
|
bar = ((SLtt_Screen_Cols - 2) * p->curr) / p->total;
|
|
SLsmg_fill_region(y, 1, 1, bar, ' ');
|
|
SLsmg_refresh();
|
|
pthread_mutex_unlock(&ui__lock);
|
|
}
|
|
|
|
static void tui_progress__finish(void)
|
|
{
|
|
int y;
|
|
|
|
if (use_browser <= 0)
|
|
return;
|
|
|
|
ui__refresh_dimensions(false);
|
|
pthread_mutex_lock(&ui__lock);
|
|
y = SLtt_Screen_Rows / 2 - 2;
|
|
SLsmg_set_color(0);
|
|
SLsmg_fill_region(y, 0, 3, SLtt_Screen_Cols, ' ');
|
|
SLsmg_refresh();
|
|
pthread_mutex_unlock(&ui__lock);
|
|
}
|
|
|
|
static struct ui_progress_ops tui_progress__ops =
|
|
{
|
|
.update = tui_progress__update,
|
|
.finish = tui_progress__finish,
|
|
};
|
|
|
|
void tui_progress__init(void)
|
|
{
|
|
ui_progress__ops = &tui_progress__ops;
|
|
}
|