X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fio%2Fhandle.h;h=6140e116d74fb497d83085d921e11b515084616a;hp=4b311f545f3212ff8755b7dbbf51c2889991d1b5;hb=HEAD;hpb=ea8bf8f588310b0d7fd3297d74907602705bba1d diff --git a/source/io/handle.h b/source/io/handle.h index 4b311f5..06c2034 100644 --- a/source/io/handle.h +++ b/source/io/handle.h @@ -1,16 +1,19 @@ #ifndef MSP_IO_HANDLE_H_ #define MSP_IO_HANDLE_H_ +#include +#include + namespace Msp { namespace IO { -class Handle +class MSPCORE_API Handle { public: struct Private; private: - Private *priv; + Private *priv = nullptr; public: Handle(); @@ -21,17 +24,14 @@ public: Private &operator*() { return *priv; } const Private &operator*() const { return *priv; } - /** This is effectively a boolean conversion, but avoids accidental - conversion to OS native handles. Unix-based systems use int and win32 uses - void *; const void * is not implicitly convertible to either. */ - operator const void *() const; + explicit operator bool() const; }; void sys_set_blocking(Handle &, bool); void sys_set_inherit(Handle &, bool); -unsigned sys_read(Handle &, char *, unsigned); -unsigned sys_write(Handle &, const char *, unsigned); +std::size_t sys_read(Handle &, char *, std::size_t); +std::size_t sys_write(Handle &, const char *, std::size_t); void sys_close(Handle &); } // namespace IO