summaryrefslogtreecommitdiffstats
path: root/tools/perf/util/ui/progress.c
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2010-08-11 09:39:10 +0200
committerIngo Molnar <mingo@elte.hu>2010-08-11 09:39:10 +0200
commitb3e84ffa21f916e3354a12a7f19169c9febe96d0 (patch)
tree1248316ef0cf5bee08309d492cf925fd87662ea8 /tools/perf/util/ui/progress.c
parent1c250d709fdc8aa5bf42d90be99428a01a256a55 (diff)
parent4694153c252a6ae19704b5bb66466050256395a4 (diff)
Merge branch 'perf/core' into perf/urgent
Diffstat (limited to 'tools/perf/util/ui/progress.c')
-rw-r--r--tools/perf/util/ui/progress.c60
1 files changed, 60 insertions, 0 deletions
diff --git a/tools/perf/util/ui/progress.c b/tools/perf/util/ui/progress.c
new file mode 100644
index 00000000000..d7fc399d36b
--- /dev/null
+++ b/tools/perf/util/ui/progress.c
@@ -0,0 +1,60 @@
+#include <stdlib.h>
+#include <newt.h>
+#include "../cache.h"
+#include "progress.h"
+
+struct ui_progress {
+ newtComponent form, scale;
+};
+
+struct ui_progress *ui_progress__new(const char *title, u64 total)
+{
+ struct ui_progress *self = malloc(sizeof(*self));
+
+ if (self != NULL) {
+ int cols;
+
+ if (use_browser <= 0)
+ return self;
+ newtGetScreenSize(&cols, NULL);
+ cols -= 4;
+ newtCenteredWindow(cols, 1, title);
+ self->form = newtForm(NULL, NULL, 0);
+ if (self->form == NULL)
+ goto out_free_self;
+ self->scale = newtScale(0, 0, cols, total);
+ if (self->scale == NULL)
+ goto out_free_form;
+ newtFormAddComponent(self->form, self->scale);
+ newtRefresh();
+ }
+
+ return self;
+
+out_free_form:
+ newtFormDestroy(self->form);
+out_free_self:
+ free(self);
+ return NULL;
+}
+
+void ui_progress__update(struct ui_progress *self, u64 curr)
+{
+ /*
+ * 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;
+ newtScaleSet(self->scale, curr);
+ newtRefresh();
+}
+
+void ui_progress__delete(struct ui_progress *self)
+{
+ if (use_browser > 0) {
+ newtFormDestroy(self->form);
+ newtPopWindow();
+ }
+ free(self);
+}