diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/devices/deviceObjectEnum.h | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/devices/deviceObjectEnum.h')
-rw-r--r-- | Src/devices/deviceObjectEnum.h | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/Src/devices/deviceObjectEnum.h b/Src/devices/deviceObjectEnum.h new file mode 100644 index 00000000..7efbcbb4 --- /dev/null +++ b/Src/devices/deviceObjectEnum.h @@ -0,0 +1,44 @@ +#ifndef _NULLSOFT_WINAMP_DEVICES_DEVICE_OBJECT_ENUMERATOR_HEADER +#define _NULLSOFT_WINAMP_DEVICES_DEVICE_OBJECT_ENUMERATOR_HEADER + +#if defined(_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include "./ifc_deviceobject.h" +#include "./ifc_deviceobjectenum.h" + +class DeviceObjectEnum : public ifc_deviceobjectenum +{ +protected: + DeviceObjectEnum(); + ~DeviceObjectEnum(); + +public: + static HRESULT CreateInstance(ifc_deviceobject **objects, + size_t count, + DeviceObjectEnum **instance); + +public: + /* Dispatchable */ + size_t AddRef(); + size_t Release(); + int QueryInterface(GUID interface_guid, void **object); + + /* ifc_deviceobjectenum */ + HRESULT Next(ifc_deviceobject **objects, size_t bufferMax, size_t *fetched); + HRESULT Reset(void); + HRESULT Skip(size_t count); + HRESULT GetCount(size_t *count); + +protected: + size_t ref; + ifc_deviceobject **buffer; + size_t size; + size_t cursor; + +protected: + RECVS_DISPATCH; +}; + +#endif // _NULLSOFT_WINAMP_DEVICES_DEVICE_OBJECT_ENUMERATOR_HEADER
\ No newline at end of file |