From 7404c288d9ab64e7ddb4459360dd524e984704f7 Mon Sep 17 00:00:00 2001 From: Michael Shalayeff Date: Tue, 30 Sep 1997 00:07:26 +0000 Subject: don't say 'dirty' if nothing is changed actually --- sbin/fdisk/cmd.c | 79 ++++++++++++++++++++++++++++---------------------------- 1 file changed, 40 insertions(+), 39 deletions(-) diff --git a/sbin/fdisk/cmd.c b/sbin/fdisk/cmd.c index 7fff0bedb28..1be44585835 100644 --- a/sbin/fdisk/cmd.c +++ b/sbin/fdisk/cmd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd.c,v 1.2 1997/09/29 23:33:32 mickey Exp $ */ +/* $OpenBSD: cmd.c,v 1.3 1997/09/30 00:07:25 mickey Exp $ */ /* * Copyright (c) 1997 Tobias Weingartner @@ -98,33 +98,40 @@ Xedit(cmd, disk, mbr, tt, offset) mbr_t *tt; int offset; { - int num; + int pn, num, ret; prt_t *pp; + ret = CMD_CONT; + if(!isdigit(cmd->args[0])){ printf("Invalid argument: %s \n", cmd->cmd); - return(CMD_CONT); + return (ret); } - num = atoi(cmd->args); + pn = atoi(cmd->args); - if(num < 0 || num > 3){ + if(pn < 0 || pn > 3){ printf("Invalid partition number.\n"); - return(CMD_CONT); + return (ret); } /* Print out current table entry */ - pp = &mbr->part[num]; + pp = &mbr->part[pn]; PRT_print(0, NULL); - PRT_print(num, pp); + PRT_print(pn, pp); + +#define EDIT(p, f, v, n, m) \ + if ((num = ask_num(p, f, v, n, m)) != v) \ + ret = CMD_DIRTY; \ + v = num; /* Ask for partition type */ - pp->id = ask_num("Partition id", ASK_HEX, pp->id, 0, 0xFF); + EDIT("Partition id", ASK_HEX, pp->id, 0, 0xFF); /* Unused, so just zero out */ if(pp->id == DOSPTYP_UNUSED){ memset(pp, 0, sizeof(*pp)); - printf("Partiton %d cleared.\n", num); - return(CMD_DIRTY); + printf("Partiton %d cleared.\n", pn); + return(ret); } /* Change table entry */ @@ -137,31 +144,25 @@ Xedit(cmd, disk, mbr, tt, offset) maxsect = disk->bios->sectors; /* Get data */ - pp->scyl = ask_num("Starting cylinder", ASK_DEC, pp->scyl, 0, maxcyl); - pp->shead = ask_num("Starting head", ASK_DEC, pp->shead, 0, maxhead); - pp->ssect = ask_num("Starting sector", ASK_DEC, pp->ssect, 1, maxsect); - pp->ecyl = ask_num("Ending cylinder", ASK_DEC, pp->ecyl, 0, maxcyl); - pp->ehead = ask_num("Ending head", ASK_DEC, pp->ehead, 0, maxhead); - pp->esect = ask_num("Ending sector", ASK_DEC, pp->esect, 1, maxsect); - + EDIT("Starting cylinder", ASK_DEC, pp->scyl, 0, maxcyl); + EDIT("Starting head", ASK_DEC, pp->shead, 0, maxhead); + EDIT("Starting sector", ASK_DEC, pp->ssect, 1, maxsect); + EDIT("Ending cylinder", ASK_DEC, pp->ecyl, 0, maxcyl); + EDIT("Ending head", ASK_DEC, pp->ehead, 0, maxhead); + EDIT("Ending sector", ASK_DEC, pp->esect, 1, maxsect); /* Fix up off/size values */ PRT_fix_BN(disk, pp); }else{ - int start, size; - - /* Get data */ - start = disk->bios->size; - pp->bs = ask_num("Partition offset", ASK_DEC, pp->bs, 0, start); - - size = disk->bios->size - pp->bs; - pp->ns = ask_num("Partition size", ASK_DEC, pp->ns, 1, size); + EDIT("Partition offset", ASK_DEC, pp->bs, 0, disk->bios->size); + EDIT("Partition size", ASK_DEC, pp->ns, 1, + disk->bios->size - pp->bs); /* Fix up CHS values */ PRT_fix_CHS(disk, pp); } - - return(CMD_DIRTY); +#undef EDIT + return(ret); } int @@ -173,26 +174,26 @@ Xselect(cmd, disk, mbr, tt, offset) int offset; { int off; - int num; + int pn; if(!isdigit(cmd->args[0])){ printf("Invalid argument: %s \n", cmd->cmd); return(CMD_CONT); } - num = atoi(cmd->args); - off = mbr->part[num].bs; + pn = atoi(cmd->args); + off = mbr->part[pn].bs; /* Sanity checks */ - if(mbr->part[num].id != DOSPTYP_EXTEND){ - printf("Partition %d is not an extended partition.\n", num); + if(mbr->part[pn].id != DOSPTYP_EXTEND){ + printf("Partition %d is not an extended partition.\n", pn); return(CMD_CONT); } if(!off){ printf("Loop to offset 0! Not selected.\n"); return(CMD_CONT); }else{ - printf("Selected extended partition %d\n", num); + printf("Selected extended partition %d\n", pn); printf("New MBR at offset %d.\n", off); } @@ -313,27 +314,27 @@ Xflag(cmd, disk, mbr, tt, offset) mbr_t *tt; int offset; { - int i, num = -1; + int i, pn = -1; /* Parse partition table entry number */ if(!isdigit(cmd->args[0])){ printf("Invalid argument: %s \n", cmd->cmd); return(CMD_CONT); } - num = atoi(cmd->args); + pn = atoi(cmd->args); - if(num < 0 || num > 3){ + if(pn < 0 || pn > 3){ printf("Invalid partition number.\n"); return(CMD_CONT); } /* Set active flag */ for(i = 0; i < 4; i++){ - if(i == num) mbr->part[i].flag = DOSACTIVE; + if(i == pn) mbr->part[i].flag = DOSACTIVE; else mbr->part[i].flag = 0x00; } - printf("Partition %d marked active.\n", num); + printf("Partition %d marked active.\n", pn); return(CMD_DIRTY); } -- cgit v1.2.3