X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Freadwrite.h;h=cf4de14cb108750527cc0368e88ee2f68546cd43;hb=b97faa0009abc699ab7bff7bcc3221b8b3104e12;hp=a4b0973ea2d68e95d70c35a8e9888356d58661e4;hpb=bd82dfaa9bfeaae84690728554b43113e469904d;p=plomrogue
diff --git a/src/readwrite.h b/src/readwrite.h
index a4b0973..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
-extern uint16_t read_uint16_bigendian(FILE * file);
-extern uint32_t read_uint32_bigendian(FILE * file);
-extern void write_uint16_bigendian(uint16_t x, FILE * file);
-extern 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