Blame SOURCES/0033-efivar-rework-usage.patch

a43681
From 5f0b2b3460dfa826d75b95450bdc2903fa59e32e Mon Sep 17 00:00:00 2001
a43681
From: Peter Jones <pjones@redhat.com>
a43681
Date: Mon, 17 Jun 2019 14:45:39 -0400
a43681
Subject: [PATCH 33/63] efivar: rework usage()
a43681
a43681
Signed-off-by: Peter Jones <pjones@redhat.com>
a43681
---
a43681
 src/efivar.c | 74 ++++++++++++++++++++++++++++------------------------
a43681
 1 file changed, 40 insertions(+), 34 deletions(-)
a43681
a43681
diff --git a/src/efivar.c b/src/efivar.c
a43681
index df075809db5..7f16ab15bab 100644
a43681
--- a/src/efivar.c
a43681
+++ b/src/efivar.c
a43681
@@ -39,10 +39,11 @@ extern int optind, opterr, optopt;
a43681
 
a43681
 #include "efivar.h"
a43681
 
a43681
-#define ACTION_LIST		0x1
a43681
-#define ACTION_PRINT		0x2
a43681
-#define ACTION_APPEND		0x4
a43681
-#define ACTION_LIST_GUIDS	0x8
a43681
+#define ACTION_USAGE		0x00
a43681
+#define ACTION_LIST		0x01
a43681
+#define ACTION_PRINT		0x02
a43681
+#define ACTION_APPEND		0x04
a43681
+#define ACTION_LIST_GUIDS	0x08
a43681
 #define ACTION_WRITE		0x10
a43681
 #define ACTION_PRINT_DEC	0x20
a43681
 
a43681
@@ -326,7 +327,7 @@ validate_name(const char *name)
a43681
 }
a43681
 
a43681
 static void
a43681
-prepare_data(const char *filename, void **data, size_t *data_size)
a43681
+prepare_data(const char *filename, uint8_t **data, size_t *data_size)
a43681
 {
a43681
 	int fd = -1;
a43681
 	void *buf;
a43681
@@ -365,25 +366,29 @@ err:
a43681
 	exit(1);
a43681
 }
a43681
 
a43681
-static void
a43681
-usage(const char *progname)
a43681
+static void __attribute__((__noreturn__))
a43681
+usage(int ret)
a43681
 {
a43681
-	printf("Usage: %s [OPTION...]\n", basename(progname));
a43681
-	printf("  -l, --list                        list current variables\n");
a43681
-	printf("  -p, --print                       print variable specified by --name\n");
a43681
-	printf("  -d, --print-decimal               print variable in decimal values specified\n");
a43681
-	printf("                                    by --name\n");
a43681
-	printf("  -n, --name=<guid-name>            variable to manipulate, in the form\n");
a43681
-	printf("                                    8be4df61-93ca-11d2-aa0d-00e098032b8c-Boot0000\n");
a43681
-	printf("  -a, --append                      append to variable specified by --name\n");
a43681
-	printf("  -f, --fromfile=<file>             use data from <file>\n");
a43681
-	printf("  -t, --attributes=<attributes>     attributes to use on append\n");
a43681
-	printf("  -L, --list-guids                  show internal guid list\n");
a43681
-	printf("  -w, --write                       write to variable specified by --name\n\n");
a43681
-	printf("Help options:\n");
a43681
-	printf("  -?, --help                        Show this help message\n");
a43681
-	printf("      --usage                       Display brief usage message\n");
a43681
-	return;
a43681
+	FILE *out = ret == 0 ? stdout : stderr;
a43681
+	fprintf(out,
a43681
+		"Usage: %s [OPTION...]\n"
a43681
+		"  -l, --list                        list current variables\n"
a43681
+		"  -p, --print                       print variable specified by --name\n"
a43681
+		"  -d, --print-decimal               print variable in decimal values specified\n"
a43681
+		"                                    by --name\n"
a43681
+		"  -n, --name=<guid-name>            variable to manipulate, in the form\n"
a43681
+		"                                    8be4df61-93ca-11d2-aa0d-00e098032b8c-Boot0000\n"
a43681
+		"  -a, --append                      append to variable specified by --name\n"
a43681
+		"  -e, --export=<file>               export variable to <file>\n"
a43681
+		"  -f, --fromfile=<file>             use data from <file>\n"
a43681
+		"  -t, --attributes=<attributes>     attributes to use on append\n"
a43681
+		"  -L, --list-guids                  show internal guid list\n"
a43681
+		"  -w, --write                       write to variable specified by --name\n\n"
a43681
+		"Help options:\n"
a43681
+		"  -?, --help                        Show this help message\n"
a43681
+		"      --usage                       Display brief usage message\n",
a43681
+		program_invocation_short_name);
a43681
+	exit(ret);
a43681
 }
a43681
 
a43681
 int main(int argc, char *argv[])
a43681
@@ -391,7 +396,7 @@ int main(int argc, char *argv[])
a43681
 	int c = 0;
a43681
 	int i = 0;
a43681
 	int action = 0;
a43681
-	void *data = NULL;
a43681
+	uint8_t *data = NULL;
a43681
 	size_t data_size = 0;
a43681
 	char *name = NULL;
a43681
 	char *file = NULL;
a43681
@@ -434,10 +439,10 @@ int main(int argc, char *argv[])
a43681
 				break;
a43681
 			case 't':
a43681
 				attributes = strtoul(optarg, NULL, 10);
a43681
-				if (errno == ERANGE || errno == EINVAL) {
a43681
-					fprintf(stderr, "invalid argument for -t: %s: %s\n", optarg, strerror(errno));
a43681
-					return EXIT_FAILURE;
a43681
-				}
a43681
+				if (errno == ERANGE || errno == EINVAL)
a43681
+					err(1,
a43681
+					    "invalid argument for -t: %s: %m\n",
a43681
+					    optarg);
a43681
 				break;
a43681
 			case 'L':
a43681
 				action |= ACTION_LIST_GUIDS;
a43681
@@ -446,13 +451,11 @@ int main(int argc, char *argv[])
a43681
 				action |= ACTION_WRITE;
a43681
 				break;
a43681
 			case '?':
a43681
-				usage(argv[0]);
a43681
-				return EXIT_SUCCESS;
a43681
+				usage(EXIT_SUCCESS);
a43681
+				break;
a43681
 			case 0:
a43681
-				if (strcmp(lopts[i].name, "usage")) {
a43681
-					usage(argv[0]);
a43681
-					return EXIT_SUCCESS;
a43681
-				}
a43681
+				if (strcmp(lopts[i].name, "usage"))
a43681
+					usage(EXIT_SUCCESS);
a43681
 				break;
a43681
 		}
a43681
 	}
a43681
@@ -506,6 +509,9 @@ int main(int argc, char *argv[])
a43681
 					guid[i].symbol + strlen("efi_guid_"),
a43681
 					guid[i].symbol, guid[i].name);
a43681
 			}
a43681
+		case ACTION_USAGE:
a43681
+		default:
a43681
+			usage(EXIT_FAILURE);
a43681
 		}
a43681
 	};
a43681
 
a43681
-- 
a43681
2.26.2
a43681