summaryrefslogtreecommitdiff
path: root/tools/common.h
diff options
context:
space:
mode:
authorDaniel Harding <33dannye@gmail.com>2018-03-10 18:36:19 -0600
committerGitHub <noreply@github.com>2018-03-10 18:36:19 -0600
commit42cfe3d36192aca4d0c4ca222be0088c03236e0d (patch)
treedd050c795930a34af6ea020c00f52dc7116ee49a /tools/common.h
parent37ded1d150197b3784bc351eeeb0a8d9713c2e35 (diff)
parent4768fed52d7379704ecd958f171ec0dc2d36efc0 (diff)
Merge pull request #177 from yenatch/rgbgfx
Use rgbgfx and c tools instead of the submodule.
Diffstat (limited to 'tools/common.h')
-rw-r--r--tools/common.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/tools/common.h b/tools/common.h
new file mode 100644
index 00000000..4da0b2ef
--- /dev/null
+++ b/tools/common.h
@@ -0,0 +1,40 @@
+#ifndef GUARD_COMMON_H
+#define GUARD_COMMON_H
+
+int __getopt_long_i__;
+#define getopt_long(c, v, s, l) getopt_long(c, v, s, l, &__getopt_long_i__)
+
+FILE *fopen_verbose(char *filename, char *mode) {
+ FILE *f = fopen(filename, mode);
+ if (!f) {
+ fprintf(stderr, "Could not open file: \"%s\"\n", filename);
+ }
+ return f;
+}
+
+uint8_t *read_u8(char *filename, int *size) {
+ FILE *f = fopen_verbose(filename, "rb");
+ if (!f) {
+ exit(1);
+ }
+ fseek(f, 0, SEEK_END);
+ *size = ftell(f);
+ rewind(f);
+ uint8_t *data = malloc(*size);
+ if (*size != (int)fread(data, 1, *size, f)) {
+ fprintf(stderr, "Could not read file: \"%s\"\n", filename);
+ exit(1);
+ }
+ fclose(f);
+ return data;
+}
+
+void write_u8(char *filename, uint8_t *data, int size) {
+ FILE *f = fopen_verbose(filename, "wb");
+ if (f) {
+ fwrite(data, 1, size, f);
+ fclose(f);
+ }
+}
+
+#endif // GUARD_COMMON_H