summaryrefslogtreecommitdiffstats
path: root/fdisk/fdisk.c
diff options
context:
space:
mode:
authorDavidlohr Bueso2012-05-21 21:23:27 +0200
committerKarel Zak2012-05-23 10:52:09 +0200
commit6da365de2db02344f8d2633dfdab256d86e4be4c (patch)
treecc800d548fe43e9e13fda56ecdfe87c528e140a3 /fdisk/fdisk.c
parentfdisk: use BSD label header (diff)
downloadkernel-qcow2-util-linux-6da365de2db02344f8d2633dfdab256d86e4be4c.tar.gz
kernel-qcow2-util-linux-6da365de2db02344f8d2633dfdab256d86e4be4c.tar.xz
kernel-qcow2-util-linux-6da365de2db02344f8d2633dfdab256d86e4be4c.zip
fdisk: refactor -s option
Signed-off-by: Davidlohr Bueso <dave@gnu.org>
Diffstat (limited to 'fdisk/fdisk.c')
-rw-r--r--fdisk/fdisk.c41
1 files changed, 22 insertions, 19 deletions
diff --git a/fdisk/fdisk.c b/fdisk/fdisk.c
index b38502769..2589a166d 100644
--- a/fdisk/fdisk.c
+++ b/fdisk/fdisk.c
@@ -2096,10 +2096,22 @@ static void command_prompt(void)
}
}
+static unsigned long long get_dev_blocks(char *dev)
+{
+ int fd;
+ unsigned long long size;
+
+ if ((fd = open(dev, O_RDONLY)) < 0)
+ err(EXIT_FAILURE, _("unable to open %s"), dev);
+ if (blkdev_get_sectors(fd, &size) == -1)
+ fatal(ioctl_error);
+ close(fd);
+ return size/2;
+}
+
int main(int argc, char **argv)
{
- int j, c;
- int optl = 0, opts = 0;
+ int c, optl = 0, opts = 0;
setlocale(LC_ALL, "");
bindtextdomain(PACKAGE, LOCALEDIR);
@@ -2183,27 +2195,18 @@ int main(int argc, char **argv)
}
if (opts) {
- unsigned long long size;
-
- nowarn = 1;
-
- opts = argc - optind;
- if (opts <= 0)
+ /* print partition size for one or more devices */
+ int i, ndevs = argc - optind;
+ if (ndevs <= 0)
usage(stderr);
- for (j = optind; j < argc; j++) {
- disk_device = argv[j];
- if ((fd = open(disk_device, O_RDONLY)) < 0)
- err(EXIT_FAILURE, _("unable to open %s"), disk_device);
- if (blkdev_get_sectors(fd, &size) == -1)
- fatal(ioctl_error);
- close(fd);
- if (opts == 1)
- printf("%llu\n", size/2);
+ for (i = optind; i < argc; i++) {
+ if (ndevs == 1)
+ printf("%llu\n", get_dev_blocks(argv[i]));
else
- printf("%s: %llu\n", argv[j], size/2);
+ printf("%s: %llu\n", argv[i], get_dev_blocks(argv[i]));
}
- exit(0);
+ exit(EXIT_SUCCESS);
}
if (argc-optind == 1)