diff src/main.c @ 85:1acd477da42f

posix: improvements
author Paper <paper@paper.us.eu.org>
date Mon, 17 Jun 2024 21:18:37 -0400
parents c06dcab17923
children
line wrap: on
line diff
--- a/src/main.c	Fri Mar 22 22:30:04 2024 -0400
+++ b/src/main.c	Mon Jun 17 21:18:37 2024 -0400
@@ -1,6 +1,7 @@
 #include <stdio.h>
 #include <stdint.h>
 #include <stdlib.h>
+#include <stdarg.h>
 #include <string.h>
 
 #include <getopt.h>
@@ -9,7 +10,7 @@
 #include "common.h"
 
 /* non-portable functions */
-static inline char* msvpvf_internal_strdup(const char* str) {
+static char* msvpvf_internal_strdup(const char* str) {
 	size_t len = strlen(str) + 1;
 
 	char* copy = malloc(len);
@@ -20,8 +21,38 @@
 	return copy;
 }
 
+static char *msvpvf_internal_asnprintf(const char *format, ...) {
+	va_list args;
+	int needed_size;
+	char *output = NULL;
+
+	va_start(args, format);
+
+	needed_size = vsnprintf(NULL, 0, format, args);
+	if (needed_size < 0)
+		return NULL;
+
+	va_end(args);
+
+	output = malloc((needed_size + 1) * sizeof(char));
+	if (!output)
+		return NULL;
+
+	va_start(args, format);
+
+	needed_size = vsnprintf(output, needed_size + 1, format, args);
+	if (needed_size < 0) {
+		free(output);
+		return NULL;
+	}
+
+	va_end(args);
+
+	return output;
+}
+
 /* source needs read permissions, target needs write permissions, both must be in binary mode */
-static inline int copy_file(FILE* source, FILE* target) {
+static int copy_file(FILE* source, FILE* target) {
 	char ch[4096];
 
 	while (!feof(source)) {
@@ -33,30 +64,24 @@
 	return 0;
 }
 
-static inline const char* type_to_string(enum types type) {
-	switch (type) {
-		case TYPES_VF: return "Movie Studio";
-		case TYPES_VEG: return "Vegas Pro";
-		case TYPES_UNKNOWN:
-		default: return "Unknown";
-	}
-}
+static const char* type_names[] = {
+	[TYPES_VF] = "Movie Studio",
+	[TYPES_VEG] = "Vegas Pro",
+	[TYPES_UNKNOWN] = "Unknown",
+};
 
-static inline const char* type_to_extension(enum types type) {
-	switch (type) {
-		case TYPES_VF: return "vf";
-		case TYPES_VEG:
-		case TYPES_UNKNOWN:
-		default: return "veg";
-	}
-}
+static const char* type_extensions[] = {
+	[TYPES_VF] = "vf",
+	[TYPES_VEG] = "veg",
+};
 
 #ifndef ARRAYSIZE
 #define ARRAYSIZE(x) (sizeof(x) / sizeof((x)[0]))
 #endif
 
 static const char* help_text =
-	"msvpvf by Paper\n"
+	"msvpvf help text\n"
+	"author: Paper <paper@paper.us.eu.org>\n"
 	"usage: %s <input>... (arguments)\n"
 	"\n"
 	"arguments:\n"
@@ -67,12 +92,12 @@
 static struct option options_long[] = {
 	{"version", required_argument, NULL, 'v'},
 	{"type", required_argument, NULL, 't'},
-	{"help", 0, NULL, 'h'}
+	{"help", 0, NULL, 'h'},
 };
 
 int main(int argc, char *argv[]) {
 	uint8_t version = 0;
-	enum types type = TYPES_UNKNOWN;
+	enum types type = TYPES_VEG; /* ...? */
 
 	int c;
 	int option_index = 0;
@@ -101,7 +126,7 @@
 	}
 
 	if (argc <= optind) {
-		fprintf(stderr, "[ERROR]: Missing input file!\n");
+		fprintf(stderr, "[ERROR]: Missing input file(s)!\n");
 		printf(help_text, argv[0]);
 		return 1;
 	}
@@ -111,72 +136,68 @@
 		return 1;
 	}
 
-	/* this progressively */
 	while (optind < argc) {
 		const char* input = argv[optind++];
-		FILE* output_file = NULL;
+		FILE *input_file, *output_file = NULL;
+		uint8_t file_version = 0;
+		enum types file_type = TYPES_UNKNOWN;
+
+		printf("Input file name: %s\n", input);
+
+		/* print information about the input file */
+		input_file = fopen(input, "rb");
+		if (!input_file) {
+			fprintf(stderr, "[ERROR]: Error opening input file %s!\n\n", input);
+			continue;
+		}
+
+		if (fgetc(input_file) == EOF) {
+			fprintf(stderr, "[ERROR]: Input file \"%s\" is empty.\n", input);
+			fclose(input_file);
+			continue;
+		}
+
+		if (get_file_information(input_file, &file_version, &file_type)) {
+			fprintf(stderr, "[ERROR]: Failed to get file information for input file \"%s\"!\n", input);
+			fclose(input_file);
+			continue;
+		}
+
+		printf("Input file version: %u\n", file_version);
+		printf("Input file type: %s\n\n", type_names[file_type]);
 
 		{
-			uint8_t file_version = 0;
-			enum types file_type = TYPES_UNKNOWN;
+			/* open the output file... */
+			char* basec = msvpvf_internal_strdup(input);
+			char* bname = basename(basec);
+			int ext = strrchr(bname, '.') - bname;
 
-			printf("Input file name: %s\n", input);
-			/* print information about the input file */
-			FILE* input_file = fopen(input, "rb");
-			if (!input_file) {
-				fprintf(stderr, "[ERROR]: Error opening input file %s!\n\n", input);
-				continue;
-			}
-
-			if (fgetc(input_file) == EOF) {
-				fprintf(stderr, "[ERROR]: Input file \"%s\" is empty.\n", input);
-				fclose(input_file);
-				continue;
-			}
-
-			if (get_file_information(input_file, &file_version, &file_type)) {
-				fprintf(stderr, "[ERROR]: Failed to get file information for input file \"%s\"!\n", input);
+			char *output = msvpvf_internal_asnprintf("V%u_%.*s.%s", version, ext, bname, type_extensions[type]);
+			if (!output) {
+				fprintf(stderr, "[ERROR]: msvpvf_internal_asnprintf failed!\n");
+				free(basec);
+				free(output);
 				fclose(input_file);
 				continue;
 			}
 
-			printf("Input file version: %u\n", file_version);
-			printf("Input file type: %s\n\n", type_to_string(file_type));
-
-			{
-				/* open the output file... */
-				char* basec = msvpvf_internal_strdup(input);
-				char* bname = basename(basec);
-				int ext = strrchr(bname, '.') - bname;
-
-				/* create the output filename */
-				int needed_size = snprintf(NULL, 0, "V%u_%.*s.%s", version, ext, bname, type_to_extension(type));
-				char* output = malloc((needed_size + 1) * sizeof(char));
-				if (!output) {
-					fprintf(stderr, "[ERROR]: Failed to allocate memory for output string!\n");
-					free(basec);
-					return 1;
-				}
-
-				snprintf(output, needed_size + 1, "V%u_%.*s.%s", version, ext, bname, type_to_extension(type));
-				printf("Output filename: %s\n", output);
-
-				output_file = fopen(output, "w+b");
-				if (!output_file) {
-					fprintf(stderr, "[ERROR]: Failed to open output file %s! Do you have write permissions?\n", output);
-					free(basec);
-					free(output);
-					continue;
-				}
+			output_file = fopen(output, "w+b");
+			if (!output_file) {
+				fprintf(stderr, "[ERROR]: Failed to open output file %s! Do you have write permissions?\n", output);
 				free(basec);
 				free(output);
+				fclose(input_file);
+				continue;
 			}
 
-			copy_file(input_file, output_file);
+			free(basec);
+			free(output);
+		}
 
-			fflush(stdout);
-			fclose(input_file);
-		}
+		copy_file(input_file, output_file);
+
+		fflush(stdout);
+		fclose(input_file);
 
 		set_file_information(output_file, version, type);
 		fclose(output_file);