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
This commit is contained in:
Chris Lattner 2003-12-30 02:45:16 +00:00
parent 6dea527b4a
commit 9899ae3ae8
3 changed files with 44 additions and 18 deletions

View File

@ -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

View File

@ -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

View File

@ -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;
}