Blame gfs2/mkfs/progress.c

Packit 6ef888
/**
Packit 6ef888
 * Progress bar to give updates for operations in gfs2-utils.
Packit 6ef888
 * Adapted from the simple progress bar in e2fsprogs progress.c
Packit 6ef888
 *
Packit 6ef888
 */
Packit 6ef888
Packit 6ef888
#include <stdio.h>
Packit 6ef888
#include <string.h>
Packit 6ef888
#include <inttypes.h>
Packit 6ef888
#include <unistd.h>
Packit 6ef888
#include <time.h>
Packit 6ef888
Packit 6ef888
#include "progress.h"
Packit 6ef888
Packit 6ef888
static char spaces[44], backspaces[44];
Packit 6ef888
static time_t last_update;
Packit 6ef888
Packit 6ef888
static int number_of_digits(int value)
Packit 6ef888
{
Packit 6ef888
	int digits = 0;
Packit 6ef888
Packit 6ef888
	do {
Packit 6ef888
		value /= 10;
Packit 6ef888
		digits++;
Packit 6ef888
	} while (value != 0);
Packit 6ef888
Packit 6ef888
	return digits;
Packit 6ef888
}
Packit 6ef888
Packit 6ef888
void gfs2_progress_init(struct gfs2_progress_bar *progress, uint64_t max, const char *message, int quiet)
Packit 6ef888
{
Packit 6ef888
	/**
Packit 6ef888
	 * NOTE:
Packit 6ef888
	 *
Packit 6ef888
	 * Default operation is to output the progress indication
Packit 6ef888
	 * in full. Although we will honor the quiet flag in the
Packit 6ef888
	 * application, if this is set we skip progress bar any
Packit 6ef888
	 * update operations and output.
Packit 6ef888
	 *
Packit 6ef888
	 */
Packit 6ef888
Packit 6ef888
	memset(spaces, ' ', sizeof(spaces)-1);
Packit 6ef888
	spaces[sizeof(spaces)-1] = 0;
Packit 6ef888
Packit 6ef888
	memset(backspaces, '\b', sizeof(backspaces)-1);
Packit 6ef888
	backspaces[sizeof(backspaces)-1] = 0;
Packit 6ef888
Packit 6ef888
	memset(progress, 0, sizeof(*progress));
Packit 6ef888
Packit 6ef888
	if (quiet) {
Packit 6ef888
		progress->skip_progress++;
Packit 6ef888
		return;
Packit 6ef888
	}
Packit 6ef888
Packit 6ef888
	progress->max = max;
Packit 6ef888
	progress->max_digits = number_of_digits(max);
Packit 6ef888
Packit 6ef888
	if (message) {
Packit 6ef888
		fputs(message, stdout);
Packit 6ef888
		fflush(stdout);
Packit 6ef888
	}
Packit 6ef888
	last_update = 0;
Packit 6ef888
}
Packit 6ef888
Packit 6ef888
void gfs2_progress_update(struct gfs2_progress_bar *progress, uint64_t value)
Packit 6ef888
{
Packit 6ef888
	time_t current_time;
Packit 6ef888
Packit 6ef888
	if (progress->skip_progress || (!isatty(STDOUT_FILENO)))
Packit 6ef888
		return;
Packit 6ef888
Packit 6ef888
	current_time = time(0);
Packit 6ef888
	if (current_time == last_update)
Packit 6ef888
		return;
Packit 6ef888
	last_update = current_time;
Packit 6ef888
Packit 6ef888
	printf("[%*"PRIu64"/%*"PRIu64"]", progress->max_digits, value,
Packit 6ef888
		progress->max_digits, progress->max);
Packit 6ef888
	fflush(stdout);
Packit 6ef888
	fprintf(stdout, "%.*s", (2 * progress->max_digits) + 3, backspaces);
Packit 6ef888
}
Packit 6ef888
Packit 6ef888
void gfs2_progress_close(struct gfs2_progress_bar *progress, const char *message)
Packit 6ef888
{
Packit 6ef888
	if (progress->skip_progress)
Packit 6ef888
		return;
Packit 6ef888
Packit 6ef888
	if (isatty(STDOUT_FILENO)) {
Packit 6ef888
		fprintf(stdout, "%.*s", (2 * progress->max_digits) + 3, spaces);
Packit 6ef888
		fprintf(stdout, "%.*s", (2 * progress->max_digits) + 3, backspaces);
Packit 6ef888
	}
Packit 6ef888
Packit 6ef888
	if (message)
Packit 6ef888
		fputs(message, stdout);
Packit 6ef888
}