shithub: scc

Download patch

ref: 128f871fd0d4943b50c2de4b5afcde1b1210ae30
parent: 63e58ec2d143083afa060d26ac15a125ffe88609
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Wed Nov 29 07:52:42 EST 2017

[objdump] Add doit() function

This fuction allows a better separation of the code and it is
a first step to centralize the error handle code.

--- a/objdump/main.c
+++ b/objdump/main.c
@@ -238,18 +238,15 @@
 }
 
 void
-dump(char *fname)
+dump(char *fname, FILE *fp)
 {
-	FILE *fp;
 	struct obj_info obj;
 	struct myrohdr *hdr;
 
 	obj.fname = fname;
-	if ((fp = fopen(fname, "rb")) == NULL)
-		goto wrong_file;
-
 	obj.fp = fp;
 	hdr = &obj.hdr;
+
 	if (rdmyrohdr(obj.fp, hdr) < 0)
 		goto wrong_file;
 	if (strncmp(hdr->magic, MYROMAGIC, MYROMAGIC_SIZ)) {
@@ -256,7 +253,7 @@
 		fprintf(stderr,
 		        "objdump: %s: File format not recognized\n",
 		        fname);
-		goto close_file;
+		return;
 	}
 	puts(fname);
 	if (hdr->strsize > SIZE_MAX) {
@@ -263,7 +260,7 @@
 		fprintf(stderr,
 			"objdump: %s: overflow in header\n",
 			fname);
-			goto close_file;
+			return;
 	}
 	strsiz = hdr->strsize;
 
@@ -286,19 +283,28 @@
 		goto wrong_file;
 	if (printdata(&obj) < 0)
 		goto wrong_file;
+	return;
 
-	goto close_file;
-
 wrong_file:
 	fprintf(stderr,
 		"objdump: %s: %s\n",
 		fname, strerror(errno));
-close_file:
-	if (fp)
-		fclose(fp);
 }
 
 void
+doit(char *fname)
+{
+	FILE *fp;
+
+	if ((fp = fopen(fname, "rb")) == NULL) {
+		fprintf(stderr, "objdump: %s: %s\n", fname, strerror(errno));
+		return;
+	}
+	dump(fname, fp);
+	fclose(fp);
+}
+
+void
 usage(void)
 {
 	fputs("usage: objdump file ...\n", stderr);
@@ -314,11 +320,11 @@
 	} ARGEND
 
 	if (argc == 0)
-		dump("a.out");
+		doit("a.out");
 	else while (*argv) {
 		free(strings);
 		strings = NULL;
-		dump(*argv++);
+		doit(*argv++);
 	}
 
 	if (fclose(stdout) == EOF)