[Pdbg] [PATCH v3 1/3] pdbg: Add progress bars utility

Alistair Popple alistair at popple.id.au
Thu May 17 15:44:26 AEST 2018


From: Joel Stanley <joel at jms.id.au>

This comes from skiboot's pflash utility. Source is copyright IBM under
Apache 2.0.

Signed-off-by: Joel Stanley <joel at jms.id.au>
Signed-off-by: Alistair Popple <alistair at popple.id.au>
---
 Makefile.am    |  1 +
 src/progress.c | 99 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 src/progress.h | 24 ++++++++++++++
 3 files changed, 124 insertions(+)
 create mode 100644 src/progress.c
 create mode 100644 src/progress.h

diff --git a/Makefile.am b/Makefile.am
index c6668d8..ae8929b 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -52,6 +52,7 @@ libpdbg_la_SOURCES = \
 	libpdbg/adu.c \
 	libpdbg/device.c \
 	libpdbg/target.c \
+	libpdbg/progress.c \
 	libpdbg/htm.c
 
 M4_V = $(M4_V_$(V))
diff --git a/src/progress.c b/src/progress.c
new file mode 100644
index 0000000..cf95015
--- /dev/null
+++ b/src/progress.c
@@ -0,0 +1,99 @@
+/* Copyright 2018 IBM Corp.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ * implied.
+ */
+
+#include <inttypes.h>
+#include <limits.h>
+#include <stdint.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <time.h>
+
+#include "progress.h"
+
+static uint64_t progress_max;
+static uint64_t progress_pcent;
+static uint64_t progress_n_upd;
+static time_t progress_prevsec;
+static struct timespec progress_start;
+
+#define PROGRESS_CHARS	50
+
+void progress_init(uint64_t count)
+{
+	unsigned int i;
+
+	progress_max = count;
+	progress_pcent = 0;
+	progress_n_upd = ULONG_MAX;
+	progress_prevsec = ULONG_MAX;
+
+	fprintf(stderr, "\r[");
+	for (i = 0; i < PROGRESS_CHARS; i++)
+		fprintf(stderr, " ");
+	fprintf(stderr, "] 0%%");
+	fflush(stderr);
+	clock_gettime(CLOCK_MONOTONIC, &progress_start);}
+
+void progress_tick(uint64_t cur)
+{
+	unsigned int i, pos;
+	struct timespec now;
+	uint64_t pcent;
+	double sec;
+
+	pcent = (cur * 100) / progress_max;
+	if (progress_pcent == pcent && cur < progress_n_upd &&
+	    cur < progress_max)
+		return;
+	progress_pcent = pcent;
+	pos = (pcent * PROGRESS_CHARS) / 101;
+	clock_gettime(CLOCK_MONOTONIC, &now);
+
+	fprintf(stderr, "\r[");
+	for (i = 0; i <= pos; i++)
+		fprintf(stderr, "=");
+	for (; i < PROGRESS_CHARS; i++)
+		fprintf(stderr, " ");
+	fprintf(stderr, "] %" PRIu64 "%%", pcent);
+
+	sec = difftime(now.tv_sec, progress_start.tv_sec);
+	if (sec >= 5 && pcent > 0) {
+		uint64_t persec = cur / sec;
+		uint64_t rem_sec;
+
+		if (!persec)
+			persec = 1;
+		progress_n_upd = cur + persec;
+		rem_sec = ((sec * 100) + (pcent / 2)) / pcent - sec;
+		if (rem_sec > progress_prevsec)
+			rem_sec = progress_prevsec;
+		progress_prevsec = rem_sec;
+		if (rem_sec < 60)
+			fprintf(stderr, " ETA:%" PRIu64 "s     ", rem_sec);
+		else {
+			fprintf(stderr, " ETA:%" PRIu64 ":%02" PRIu64 ":%02" PRIu64 " ",
+				rem_sec / 3600,
+				(rem_sec / 60) % 60,
+				rem_sec % 60);
+		}
+	}
+
+	fflush(stderr);
+}
+
+void progress_end(void)
+{
+	fprintf(stderr, "\n");
+}
diff --git a/src/progress.h b/src/progress.h
new file mode 100644
index 0000000..990f6d5
--- /dev/null
+++ b/src/progress.h
@@ -0,0 +1,24 @@
+/* Copyright 2018 IBM Corp.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ * implied.
+ */
+
+#ifndef __PROGRESS_H
+#define __PROGRESS_H
+
+#include <inttypes.h>
+
+void progress_init(uint64_t count);
+void progress_tick(uint64_t cur);
+void progress_end(void);
+
+#endif /* __PROGRESS_H */
-- 
2.11.0



More information about the Pdbg mailing list