X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Freadwrite.h;h=cf4de14cb108750527cc0368e88ee2f68546cd43;hb=0fd87aaa18a4a08cc4e7aef6223aaebb16a70bc3;hp=eeead6bf7dfb9ac20fd2a2f4ae2c2d31978b60c1;hpb=47d7b87570ce3c79d3e0a6b8e765c74d065b6ba5;p=plomrogue
diff --git a/src/readwrite.h b/src/readwrite.h
index eeead6b..cf4de14 100644
--- a/src/readwrite.h
+++ b/src/readwrite.h
@@ -1,12 +1,28 @@
+/* readwrite.h:
+ *
+ * Routines for reading/writing (multi-)byte data from/to files. They ensure a
+ * defined endianness.
+ */
+
#ifndef READWRITE_H
#define READWRITE_H
-#include
-#include
-uint16_t read_uint16_bigendian(FILE * file);
-void write_uint16_bigendian(uint16_t x, FILE * file);
-uint32_t read_uint32_bigendian(FILE * file);
-void write_uint32_bigendian(uint32_t x, FILE * file);
+
+#include /* for FILE typedef */
+#include /* for uint8_t, uint16_t, uint32_t */
+
+
+
+/* Each function returns 0 on success and 1 on failure. "x" is the value to be
+ * written to "file" for write_* functions and for read_* functions the pointer
+ * to where the value read from "file" is to be written.
+ */
+extern uint8_t read_uint8(FILE * file, uint8_t * x);
+extern uint8_t read_uint16_bigendian(FILE * file, uint16_t * x);
+extern uint8_t read_uint32_bigendian(FILE * file, uint32_t * x);
+extern uint8_t write_uint8(uint8_t x, FILE * file);
+extern uint8_t write_uint16_bigendian(uint16_t x, FILE * file);
+extern uint8_t write_uint32_bigendian(uint32_t x, FILE * file);
#endif