Mercurial > msvpvf
changeset 47:7cb4ca7cf257
Use a common.c file to hold concurrent functions
Also I fixed that 1.4 KB bug I think
author | Paper <mrpapersonic@gmail.com> |
---|---|
date | Sat, 21 May 2022 18:41:54 -0400 (2022-05-21) |
parents | 7cb9fad3f5ee |
children | 652343b56a60 |
files | Makefile include/common.h src/common.c src/gui.c src/main.c |
diffstat | 5 files changed, 58 insertions(+), 93 deletions(-) [+] |
line wrap: on
line diff
--- a/Makefile Fri May 20 14:41:46 2022 -0400 +++ b/Makefile Sat May 21 18:41:54 2022 -0400 @@ -4,12 +4,12 @@ src/%.o : src/%.c $(CC) -c $(CC_FLAGS) $< -o $@ -msvpvf: src/main.o - $(CC) -o $@ $< $(CC_FLAGS) $(LD_FLAGS) +msvpvf: src/main.o src/common.o + $(CC) -o $@ $^ $(CC_FLAGS) $(LD_FLAGS) # GUI is windows-only, please use cross-compiler! -gui: src/gui.o - $(CC) -o $@ $< $(CC_FLAGS) $(LD_FLAGS) -mwindows +gui: src/gui.o src/common.o + $(CC) -o $@ $^ $(CC_FLAGS) $(LD_FLAGS) -mwindows clean: rm -f src/*.o *.exe msvpvf gui
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/include/common.h Sat May 21 18:41:54 2022 -0400 @@ -0,0 +1,2 @@ +void set_data(unsigned char magic[], uint16_t version, FILE* target); +int copy_file(char* source_file, char* target_file); \ No newline at end of file
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/common.c Sat May 21 18:41:54 2022 -0400 @@ -0,0 +1,39 @@ +#include <stdio.h> +#include <stdint.h> + +void set_data(unsigned char magic[], uint16_t version, FILE* target) { + int i; + fseek(target, 0x46, SEEK_SET); + fputc(version, target); + for (i=0; i<=sizeof(*magic); ++i) { + fseek(target, 0x18+i, SEEK_SET); + fputc(magic[i], target); + } +} + +int copy_file(char* source_file, char* target_file) { + char ch[4096]; + FILE *source, *target; + + source = fopen(source_file, "rb"); + + if (source == NULL) + return 1; + + target = fopen(target_file, "wb"); + + if (target == NULL) { + fclose(source); + return 1; + } + + while (fgetc(source) != EOF) { + size_t b = fread(ch, 1, sizeof(ch), source); + if (b) + fwrite(ch, 1, b, target); + } + + fclose(target); + fclose(source); + return 0; +}
--- a/src/gui.c Fri May 20 14:41:46 2022 -0400 +++ b/src/gui.c Sat May 21 18:41:54 2022 -0400 @@ -27,6 +27,7 @@ #include <stdint.h> #include <stdbool.h> #include <commdlg.h> +#include "../include/common.h" #define _WIN32_WINNT 0x0400 #define ARRAYSIZE(a) \ sizeof(a)/sizeof(a[0]) @@ -46,40 +47,6 @@ } type; char* file_name = " "; -void set_data(unsigned char magic[], uint16_t version, FILE* target) { - int i; - fseek(target, 0x46, SEEK_SET); - fputc(version, target); - for (i=0; i<=sizeof(*magic); ++i) { - fseek(target, 0x18+i, SEEK_SET); - fputc(magic[i], target); - } -} - -int copy_file(char* source_file, char* target_file) { - /* Copy a file */ - FILE *source, *target; - - source = fopen(source_file, "rb"); - if (source == NULL) return 1; - target = fopen(target_file, "wb"); - if (target == NULL) { - fclose(source); - return 1; - } - - size_t n, m; - unsigned char buff[8192]; - do { - n = fread(buff, 1, sizeof(buff), source); - if (n) m = fwrite(buff, 1, n, target); - else m = 0; - } while ((n > 0) && (n == m)); - - fclose(target); - fclose(source); - return 0; -} void display_file(char* path) { /* Read the file to memory */ @@ -177,24 +144,14 @@ * these arguments are for, so chances * are that you don't either. **/ - TCHAR versions[][10] = {TEXT("8"), TEXT("9"), TEXT("10"), + TCHAR versions[][10] = {TEXT("8"), TEXT("9"), TEXT("10"), TEXT("11"), TEXT("12"), TEXT("13"), TEXT("14"), TEXT("15"), TEXT("16"), TEXT("17"), TEXT("18"), TEXT("19")}; - TCHAR A[16]; - - /** - * Here we can't just use a for loop - * and cast all of those to `TEXT()`. - * Why? I don't know. My brain is too - * small to figure it out. - **/ - memset(&A,0,sizeof(A)); int i = 0; - for (i = 0; i <= 11; i++) { - strncpy((TCHAR*)A, (TCHAR*)versions[i], ARRAYSIZE(A)); - SendMessage(hWndComboBox, (UINT)CB_ADDSTRING, (WPARAM)0, (LPARAM)A); + for (i = 0; i < ARRAYSIZE(versions); i++) { + SendMessage(hWndComboBox, (UINT)CB_ADDSTRING, (WPARAM)0, (LPARAM)versions[i]); } SendMessage(hWndComboBox, CB_SETCURSEL, (WPARAM)3, (LPARAM)0); /* Open File */
--- a/src/main.c Fri May 20 14:41:46 2022 -0400 +++ b/src/main.c Sat May 21 18:41:54 2022 -0400 @@ -6,6 +6,7 @@ #include <unistd.h> #include <getopt.h> #include <libgen.h> +#include "../include/common.h" #ifdef _MSC_VER #define strdup(p) _strdup(p) #endif @@ -29,40 +30,6 @@ return str; } -void set_data(unsigned char magic[], uint16_t version, FILE* target) { - int i; - fseek(target, 0x46, SEEK_SET); - fputc(version, target); - for (i=0; i<=sizeof(*magic); ++i) { - fseek(target, 0x18+i, SEEK_SET); - fputc(magic[i], target); - } -} - -int copy_file(char* source_file, char* target_file) { - char ch; - FILE *source, *target; - - source = fopen(source_file, "rb"); - - if (source == NULL) - return 1; - - target = fopen(target_file, "wb"); - - if (target == NULL) { - fclose(source); - return 1; - } - - while( ( ch = fgetc(source) ) != EOF ) - fputc(ch, target); - - fclose(target); - fclose(source); - return 0; -} - int main(int argc, char *argv[]) { int c, option_index = 0; unsigned char magic[16]; @@ -71,7 +38,7 @@ char input[256]; char output[256]; int version; - char type[256]; + char type[4]; } args; strcpy(args.input, " "); strcpy(args.output, " "); @@ -84,13 +51,13 @@ strncpy(args.input, optarg, sizeof(args.input)-1); /* subtract 1 to make sure it's "null-safe" */ break; case 'o': - strncpy(args.output, optarg, sizeof(args.input)-1); + strncpy(args.output, optarg, sizeof(args.output)-1); break; case 'v': args.version = abs(atoi(strdup(optarg))); /* abs() for possible negative inputs */ break; case 't': - strncpy(args.type, optarg, sizeof(args.input)-1); + strncpy(args.type, optarg, sizeof(args.type)-1); break; case 'h': default: @@ -148,14 +115,14 @@ if (strcmp(args.output, " ") == 0) { /* string manipulation hell */ char* temp = (char*)calloc(256, sizeof(char)); temp[0] = '\0'; - char str_version[16]; + char str_version[4]; sprintf(str_version, "V%d", args.version); - strncat(temp, str_version, 2); - strncat(temp, "_", 1); + strncat(temp, str_version, 4); + strncat(temp, "_", 2); strncat(temp, basename(args.input), 248); strcpy(temp, strremove(temp, strrchr(basename(args.input), ('.')))); /* remove file extension */ - strncat(temp, ".", 1); - strncat(temp, args.type, 3); + strncat(temp, ".", 2); + strncat(temp, args.type, 4); strncpy(args.output, temp, 255); free(temp); }