X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FFileHandle.ih;h=b1940c69e34c9896db4027cf218511b24e5eab18;hb=69bcc009d679b71b816b9a1bfd11dfaf6c980fd1;hp=cdc775debde9ff512edad6add84ad132f6ee781e;hpb=a1a6c76a214ad1935032826713cabaf9ac57bf07;p=senf.git diff --git a/Socket/FileHandle.ih b/Socket/FileHandle.ih index cdc775d..b1940c6 100644 --- a/Socket/FileHandle.ih +++ b/Socket/FileHandle.ih @@ -24,8 +24,8 @@ \brief FileHandle internal header */ -#ifndef IH_FileHandle_ -#define IH_FileHandle_ 1 +#ifndef IH_SENF_Socket_FileHandle_ +#define IH_SENF_Socket_FileHandle_ 1 // Custom includes #include @@ -85,6 +85,10 @@ namespace senf { resulting body/handle is not valid() */ virtual ~FileBody(); + // NO DESTRUCTOR HERE (that is, only an empty virtual destructor) - destructors and virtual + // functions don't mix. What would be in the the destructor is in 'destroyClose()' which is + // called from FileHandle::~FileHandle() *before* the last handle dies. + // no copy // no conversion constructors @@ -98,6 +102,7 @@ namespace senf { void close(); void terminate(); + void destroyClose(); bool readable() const; void waitReadable() const;