home · contact · privacy
Make try_fgetc() prepend clearerr() for fgetc() versions that need it.
[plomrogue] / src / common / readwrite.h
index 9affeb855946f0272587f5b0f2268443edf8f306..b61230fb59487ba05f0feed3a05de66bb0ab0dcb 100644 (file)
@@ -22,7 +22,9 @@ extern void try_fputc(uint8_t c, FILE * file, char * f);
 
 /* Wrapper to calling fgetc() and fgets() from function "f". The return code is
  * returned unless ferror() indicates an error (i.e. to signify an end of file,
- * fgetc() may return an EOF and fgets() a NULL.
+ * fgetc() may return an EOF and fgets() a NULL). try_fgetc() calls clearerr()
+ * on "file" before fgetc(), because some Unixes fgetc() remember old EOFs and
+ * only return those until explicitely cleared.
  */
 extern int try_fgetc(FILE * file, char * f);
 extern char * try_fgets(char * line, int size, FILE * file, char * f);
@@ -34,9 +36,7 @@ extern char * try_fgets(char * line, int size, FILE * file, char * f);
 extern void try_fclose_unlink_rename(FILE * file, char * p1, char * p2,
                                      char * f);
 
-/* Return largest line length from "file" the largest line length (including
- * newline chars).
- */
+/* Return largest line length from "file" (including  newline chars). */
 extern uint32_t textfile_width(FILE * file);