[PATCH] D64979: [libc++] Set __file_ to 0 in basic_filebuf::close() even if fclose fails
Petr Hosek via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Jul 22 12:54:23 PDT 2019
This revision was automatically updated to reflect the committed changes.
Closed by commit rL366730: [libc++] Set __file_ to 0 in basic_filebuf::close() even if fclose fails (authored by phosek, committed by ).
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
Changed prior to commit:
https://reviews.llvm.org/D64979?vs=211170&id=211172#toc
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D64979/new/
https://reviews.llvm.org/D64979
Files:
libcxx/trunk/include/fstream
libcxx/trunk/test/std/input.output/file.streams/fstreams/filebuf.members/close.pass.cpp
Index: libcxx/trunk/include/fstream
===================================================================
--- libcxx/trunk/include/fstream
+++ libcxx/trunk/include/fstream
@@ -697,10 +697,9 @@
unique_ptr<FILE, int(*)(FILE*)> __h(__file_, fclose);
if (sync())
__rt = 0;
- if (fclose(__h.release()) == 0)
- __file_ = 0;
- else
+ if (fclose(__h.release()))
__rt = 0;
+ __file_ = 0;
setbuf(0, 0);
}
return __rt;
Index: libcxx/trunk/test/std/input.output/file.streams/fstreams/filebuf.members/close.pass.cpp
===================================================================
--- libcxx/trunk/test/std/input.output/file.streams/fstreams/filebuf.members/close.pass.cpp
+++ libcxx/trunk/test/std/input.output/file.streams/fstreams/filebuf.members/close.pass.cpp
@@ -0,0 +1,56 @@
+//===----------------------------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+// <fstream>
+
+// basic_filebuf<charT,traits>* close();
+
+#include <fstream>
+#include <cassert>
+#if defined(__unix__)
+#include <fcntl.h>
+#include <unistd.h>
+#endif
+#include "test_macros.h"
+#include "platform_support.h"
+
+int main(int, char**)
+{
+ std::string temp = get_temp_file_name();
+ {
+ std::filebuf f;
+ assert(!f.is_open());
+ assert(f.open(temp.c_str(), std::ios_base::out) != 0);
+ assert(f.is_open());
+ assert(f.close() != nullptr);
+ assert(!f.is_open());
+ assert(f.close() == nullptr);
+ assert(!f.is_open());
+ }
+#if defined(__unix__)
+ {
+ std::filebuf f;
+ assert(!f.is_open());
+ // Use open directly to get the file descriptor.
+ int fd = open(temp.c_str(), O_RDWR);
+ assert(fd >= 0);
+ // Use the internal method to create filebuf from the file descriptor.
+ assert(f.__open(fd, std::ios_base::out) != 0);
+ assert(f.is_open());
+ // Close the file descriptor directly to force filebuf::close to fail.
+ assert(close(fd) == 0);
+ // Ensure that filebuf::close handles the failure.
+ assert(f.close() == nullptr);
+ assert(!f.is_open());
+ assert(f.close() == nullptr);
+ }
+#endif
+ std::remove(temp.c_str());
+
+ return 0;
+}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D64979.211172.patch
Type: text/x-patch
Size: 2588 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190722/0307d04e/attachment.bin>
More information about the llvm-commits
mailing list