e2fsprogs/resize/sim_progress.c
Theodore Ts'o ca8abba7e0 Many files:
resize2fs.h: If EXT2_FLAT_INCLUDES is defined, then assume all
  	of the ext2-specific header files are in a flat directory.
  ext2_block_move.c, ext2_inode_move.c, extent.c, resize2fs.c,
  	resize2fs.h: Rename variables named "new" to "new_block",
  	"new_inode", or "new_loc" to avoid C++ reserved word
  	clash.
  ext2_block_move.c, ext2_inode_move.c, extent.c, resize2fs.c,
  	sim_progress.c: Use ext2fs_get_memory(),
  	ext2fs_free_memory(), et. al., instead of malloc() and
  	free().
  ext2_block_move.c, ext2_inode_move.c, extent.c: Explicitly cast
  	all assignments from void * to be compatible with C++.
  banalysis.c, banalysis.h, ext2_inode_move.c, ext2_block_move.c:
  	Change private to priv_data to avoid C++ namespace clash.
ChangeLog, badblocks.8.in:
  badblocks.8.in: Add documentation for the -s option.
1998-01-19 14:55:24 +00:00

109 lines
2.2 KiB
C

/*
* sim_progress.c --- simple progress meter
*/
#include "resize2fs.h"
struct ext2_sim_progress {
FILE *f;
char *label;
int labelwidth;
int barwidth;
__u32 maxdone;
__u32 current;
int shown;
int flags;
};
static errcode_t ext2fs_progress_display(ext2_sim_progmeter prog)
{
int i, width;
fputs(prog->label, prog->f);
width = prog->labelwidth - strlen(prog->label);
while (width-- > 0)
putc(' ', prog->f);
if (prog->labelwidth + prog->barwidth > 80) {
fputs("\n", prog->f);
for (width = prog->labelwidth; width > 0; width--)
putc(' ', prog->f);
}
for (i=0; i < prog->barwidth; i++)
putc('-', prog->f);
for (i=0; i < prog->barwidth; i++)
putc('\b', prog->f);
fflush(prog->f);
return 0;
}
void ext2fs_progress_update(ext2_sim_progmeter prog, __u32 current)
{
int old_level, level, num, i;
level = prog->barwidth * current / prog->maxdone;
old_level = prog->barwidth * prog->current / prog->maxdone;
prog->current = current;
num = level - old_level;
if (num == 0)
return;
if (num > 0) {
for (i=0; i < num; i++)
putc('X', prog->f);
} else {
num = -num;
for (i=0; i < num; i++)
putc('\b', prog->f);
for (i=0; i < num; i++)
putc('-', prog->f);
for (i=0; i < num; i++)
putc('\b', prog->f);
}
fflush(prog->f);
}
errcode_t ext2fs_progress_init(ext2_sim_progmeter *ret_prog,
const char *label,
int labelwidth, int barwidth,
__u32 maxdone, int flags)
{
ext2_sim_progmeter prog;
errcode_t retval;
retval = ext2fs_get_mem(sizeof(struct ext2_sim_progress),
(void **) &prog);
if (!prog)
return retval;
memset(prog, 0, sizeof(struct ext2_sim_progress));
retval = ext2fs_get_mem(strlen(label)+1, (void **) &prog->label);
if (retval) {
free(prog);
return retval;
}
strcpy(prog->label, label);
prog->labelwidth = labelwidth;
prog->barwidth = barwidth;
prog->flags = flags;
prog->maxdone = maxdone;
prog->current = 0;
prog->shown = 0;
prog->f = stdout;
*ret_prog = prog;
return ext2fs_progress_display(prog);
}
void ext2fs_progress_close(ext2_sim_progmeter prog)
{
if (prog->label)
ext2fs_free_mem((void **) &prog->label);
ext2fs_free_mem((void **) &prog);
printf("\n");
return;
}