From 9899ae3ae85e0d5cdb1a2fad0f527e5145da7f8c Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 30 Dec 2003 02:45:16 +0000 Subject: [PATCH] Further revisions of the FDHandle idea. In this version we use ownership semantics that are the same as those used by std::auto_ptr. This allows copying of FDHandle's, but copying transfers ownership. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10646 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/Support/FileUtilities.h | 27 ++++++++++++++++++++++----- include/llvm/Support/FileUtilities.h | 27 ++++++++++++++++++++++----- lib/Support/FileUtilities.cpp | 8 -------- 3 files changed, 44 insertions(+), 18 deletions(-) diff --git a/include/Support/FileUtilities.h b/include/Support/FileUtilities.h index 978b61bfd17..b17bca9e991 100644 --- a/include/Support/FileUtilities.h +++ b/include/Support/FileUtilities.h @@ -104,24 +104,41 @@ bool MakeFileReadable (const std::string & Filename); /// FDHandle - Simple handle class to make sure a file descriptor gets closed -/// when the object is destroyed. +/// when the object is destroyed. This handle acts similarly to an +/// std::auto_ptr, in that the copy constructor and assignment operators +/// transfer ownership of the handle. This means that FDHandle's do not have +/// value semantics. /// class FDHandle { int FD; - FDHandle(const FDHandle &); // DO NOT IMPLEMENT - void operator=(const FDHandle&); // DO NOT IMPLEMENT public: FDHandle() : FD(-1) {} FDHandle(int fd) : FD(fd) {} + FDHandle(FDHandle &RHS) : FD(RHS.FD) { + RHS.FD = -1; // Transfer ownership + } + ~FDHandle() throw(); + /// get - Get the current file descriptor, without releasing ownership of it. + int get() const { return FD; } operator int() const { return FD; } FDHandle &operator=(int fd) throw(); - /// take - Take ownership of the file descriptor away from the FDHandle + FDHandle &operator=(FDHandle &RHS) { + int fd = RHS.FD; + RHS.FD = -1; // Transfer ownership + return operator=(fd); + } + + /// release - Take ownership of the file descriptor away from the FDHandle /// object, so that the file is not closed when the FDHandle is destroyed. - int take() throw(); + int release() { + int Ret = FD; + FD = -1; + return Ret; + } }; } // End llvm namespace diff --git a/include/llvm/Support/FileUtilities.h b/include/llvm/Support/FileUtilities.h index 978b61bfd17..b17bca9e991 100644 --- a/include/llvm/Support/FileUtilities.h +++ b/include/llvm/Support/FileUtilities.h @@ -104,24 +104,41 @@ bool MakeFileReadable (const std::string & Filename); /// FDHandle - Simple handle class to make sure a file descriptor gets closed -/// when the object is destroyed. +/// when the object is destroyed. This handle acts similarly to an +/// std::auto_ptr, in that the copy constructor and assignment operators +/// transfer ownership of the handle. This means that FDHandle's do not have +/// value semantics. /// class FDHandle { int FD; - FDHandle(const FDHandle &); // DO NOT IMPLEMENT - void operator=(const FDHandle&); // DO NOT IMPLEMENT public: FDHandle() : FD(-1) {} FDHandle(int fd) : FD(fd) {} + FDHandle(FDHandle &RHS) : FD(RHS.FD) { + RHS.FD = -1; // Transfer ownership + } + ~FDHandle() throw(); + /// get - Get the current file descriptor, without releasing ownership of it. + int get() const { return FD; } operator int() const { return FD; } FDHandle &operator=(int fd) throw(); - /// take - Take ownership of the file descriptor away from the FDHandle + FDHandle &operator=(FDHandle &RHS) { + int fd = RHS.FD; + RHS.FD = -1; // Transfer ownership + return operator=(fd); + } + + /// release - Take ownership of the file descriptor away from the FDHandle /// object, so that the file is not closed when the FDHandle is destroyed. - int take() throw(); + int release() { + int Ret = FD; + FD = -1; + return Ret; + } }; } // End llvm namespace diff --git a/lib/Support/FileUtilities.cpp b/lib/Support/FileUtilities.cpp index 5b7f7b01c51..9471710b1d5 100644 --- a/lib/Support/FileUtilities.cpp +++ b/lib/Support/FileUtilities.cpp @@ -209,11 +209,3 @@ FDHandle &FDHandle::operator=(int fd) throw() { return *this; } - -/// take - Take ownership of the file descriptor away from the FDHandle -/// object, so that the file is not closed when the FDHandle is destroyed. -int FDHandle::take() throw() { - int Ret = FD; - FD = -1; - return Ret; -}