X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Fcommon%2Freadwrite.c;h=045bc4fbbc89f80ff2044bc971e98251488d1681;hb=2690e30a5d476cdf8689af9203748e7ed0fa841d;hp=c2c970d292cb9579d5e6fddc64eb733ac3524246;hpb=ef60270da2acf29953b411632e26503d7787d9d8;p=plomrogue
diff --git a/src/common/readwrite.c b/src/common/readwrite.c
index c2c970d..045bc4f 100644
--- a/src/common/readwrite.c
+++ b/src/common/readwrite.c
@@ -4,7 +4,7 @@
#include /* size_t */
#include /* uint8_t, uint16_t, uint32_t, UINT32_MAX */
#include /* FILE, fseek(), sprintf(), fgets(), fgetc(), ferror(),
- * fputc(), fwrite(), fclose(), fopen()
+ * fputc(), fwrite(), fclose(), fopen(), clearerr()
*/
#include /* strlen() */
#include /* for access(), unlink() */
@@ -53,6 +53,7 @@ extern void try_fputc(uint8_t c, FILE * file, char * f)
extern int try_fgetc(FILE * file, char * f)
{
+ clearerr(file); /* OSX' (BSD?) fgetc() needs this to undo previous EOFs. */
int test = fgetc(file);
exit_trouble(EOF == test && ferror(file), f, "fgetc()");
return test;