X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FFileHandle.ih;h=e87e3192b829a8ea618dd5b858df95d0ebe1ce5a;hb=e9db10951ae84696e2c287c22c86add276213281;hp=cdc775debde9ff512edad6add84ad132f6ee781e;hpb=a1a6c76a214ad1935032826713cabaf9ac57bf07;p=senf.git diff --git a/Socket/FileHandle.ih b/Socket/FileHandle.ih index cdc775d..e87e319 100644 --- a/Socket/FileHandle.ih +++ b/Socket/FileHandle.ih @@ -83,7 +83,10 @@ namespace senf { constructor not some arbitrary id even if you overload all the virtual members. If the file descriptor is -1 the resulting body/handle is not valid() */ - virtual ~FileBody(); + + // NO DESTRUCTOR HERE - 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 +101,7 @@ namespace senf { void close(); void terminate(); + void destroyClose(); bool readable() const; void waitReadable() const;