From 791130208506f50be63672fa733a70db871900da Mon Sep 17 00:00:00 2001 From: Sami Kerola Date: Sat, 17 Mar 2012 18:04:37 +0100 Subject: [PATCH] addpart: align with util-linux coding standards Add long options and usage function, use gnu errror printing facilities and validate inputs. Signed-off-by: Sami Kerola --- partx/Makefile.am | 1 + partx/addpart.c | 78 +++++++++++++++++++++++++++++++++-------------- 2 files changed, 56 insertions(+), 23 deletions(-) diff --git a/partx/Makefile.am b/partx/Makefile.am index 6f7f90ec9..d67ddd22b 100644 --- a/partx/Makefile.am +++ b/partx/Makefile.am @@ -4,6 +4,7 @@ usrsbin_exec_PROGRAMS = addpart delpart dist_man_MANS = addpart.8 delpart.8 usrsbin_exec_PROGRAMS += partx +addpart_SOURCES = addpart.c $(top_srcdir)/lib/strutils.c partx_SOURCES = \ partx.c \ partx.h \ diff --git a/partx/addpart.c b/partx/addpart.c index 84770320f..be9b0792c 100644 --- a/partx/addpart.c +++ b/partx/addpart.c @@ -1,31 +1,63 @@ +#include #include #include #include +#include "c.h" +#include "nls.h" #include "partx.h" +#include "strutils.h" -int -main(int argc, char **argv) +static void __attribute__ ((__noreturn__)) usage(FILE * out) { - int fd; - - if (argc != 5) { - fprintf(stderr, - "usage: %s diskdevice partitionnr start length\n", - argv[0]); - exit(1); - } - if ((fd = open(argv[1], O_RDONLY)) < 0) { - perror(argv[1]); - exit(1); - } - - if (partx_add_partition(fd, atoi(argv[2]), - atoll(argv[3]), - atoll(argv[4]))) { - perror("BLKPG"); - exit(1); - } - - return 0; + fputs(USAGE_HEADER, out); + fprintf(out, _(" %s \n"), + program_invocation_short_name); + fputs(USAGE_OPTIONS, out); + fputs(USAGE_HELP, out); + fputs(USAGE_VERSION, out); + fprintf(out, USAGE_MAN_TAIL("addpart(8)")); + exit(out == stderr ? EXIT_FAILURE : EXIT_SUCCESS); +} + +int main(int argc, char **argv) +{ + int c, fd; + + static const struct option longopts[] = { + {"help", no_argument, 0, 'h'}, + {"version", no_argument, 0, 'V'}, + {NULL, no_argument, 0, '0'}, + }; + + setlocale(LC_ALL, ""); + bindtextdomain(PACKAGE, LOCALEDIR); + textdomain(PACKAGE); + + while ((c = getopt_long(argc, argv, "Vh", longopts, NULL)) != -1) + switch (c) { + case 'V': + printf(UTIL_LINUX_VERSION); + return EXIT_SUCCESS; + case 'h': + usage(stdout); + default: + usage(stderr); + } + + if (argc != 5) + usage(stderr); + if ((fd = open(argv[1], O_RDONLY)) < 0) + err(EXIT_FAILURE, "%s", argv[1]); + + if (partx_add_partition(fd, + strtol_or_err(argv[2], + _("failed to parse argument")), + strtoll_or_err(argv[3], + _("failed to parse argument")), + strtoll_or_err(argv[4], + _("failed to parse argument")))) + err(EXIT_FAILURE, "BLKPG"); + + return EXIT_SUCCESS; }