CBufferedFile: add explicit close function
- also use identical close function for CAutoFile (avoids setting file to NULL under wrong conditions)
This commit is contained in:
parent
c9fb27da0a
commit
0c35486dc9
1 changed files with 18 additions and 6 deletions
|
@ -1154,7 +1154,7 @@ public:
|
|||
|
||||
|
||||
|
||||
/** Non-refcounted RAII wrapper for FILE*.
|
||||
/** Non-refcounted RAII wrapper for FILE*
|
||||
*
|
||||
* Will automatically close the file when it goes out of scope if not null.
|
||||
* If you're returning the file pointer, return file.release().
|
||||
|
@ -1186,9 +1186,10 @@ public:
|
|||
|
||||
void fclose()
|
||||
{
|
||||
if (file != NULL && file != stdin && file != stdout && file != stderr)
|
||||
if (file) {
|
||||
::fclose(file);
|
||||
file = NULL;
|
||||
file = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
FILE* release() { FILE* ret = file; file = NULL; return ret; }
|
||||
|
@ -1257,7 +1258,11 @@ public:
|
|||
};
|
||||
|
||||
/** Non-refcounted RAII wrapper around a FILE* that implements a ring buffer to
|
||||
* deserialize from. It guarantees the ability to rewind a given number of bytes. */
|
||||
* deserialize from. It guarantees the ability to rewind a given number of bytes.
|
||||
*
|
||||
* Will automatically close the file when it goes out of scope if not null.
|
||||
* If you need to close the file early, use file.fclose() instead of fclose(file).
|
||||
*/
|
||||
class CBufferedFile
|
||||
{
|
||||
private:
|
||||
|
@ -1305,8 +1310,15 @@ public:
|
|||
|
||||
~CBufferedFile()
|
||||
{
|
||||
if (src)
|
||||
fclose(src);
|
||||
fclose();
|
||||
}
|
||||
|
||||
void fclose()
|
||||
{
|
||||
if (src) {
|
||||
::fclose(src);
|
||||
src = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
// check whether we're at the end of the source file
|
||||
|
|
Loading…
Add table
Reference in a new issue