aboutsummaryrefslogtreecommitdiffstats
path: root/alc/backends/wasapi.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'alc/backends/wasapi.cpp')
-rw-r--r--alc/backends/wasapi.cpp64
1 files changed, 1 insertions, 63 deletions
diff --git a/alc/backends/wasapi.cpp b/alc/backends/wasapi.cpp
index b594aebe..3dd08613 100644
--- a/alc/backends/wasapi.cpp
+++ b/alc/backends/wasapi.cpp
@@ -59,6 +59,7 @@
#include "alcmain.h"
#include "alu.h"
#include "compat.h"
+#include "comptr.h"
#include "converter.h"
#include "core/logging.h"
#include "ringbuffer.h"
@@ -129,69 +130,6 @@ inline uint RefTime2Samples(const ReferenceTime &val, uint srate)
}
-template<typename T>
-class ComPtr {
- T *mPtr{nullptr};
-
-public:
- ComPtr() noexcept = default;
- ComPtr(const ComPtr &rhs) : mPtr{rhs.mPtr} { if(mPtr) mPtr->AddRef(); }
- ComPtr(ComPtr&& rhs) noexcept : mPtr{rhs.mPtr} { rhs.mPtr = nullptr; }
- ComPtr(std::nullptr_t) noexcept { }
- explicit ComPtr(T *ptr) noexcept : mPtr{ptr} { }
- ~ComPtr() { if(mPtr) mPtr->Release(); }
-
- ComPtr& operator=(const ComPtr &rhs)
- {
- if(!rhs.mPtr)
- {
- if(mPtr)
- mPtr->Release();
- mPtr = nullptr;
- }
- else
- {
- rhs.mPtr->AddRef();
- try {
- if(mPtr)
- mPtr->Release();
- mPtr = rhs.mPtr;
- }
- catch(...) {
- rhs.mPtr->Release();
- throw;
- }
- }
- return *this;
- }
- ComPtr& operator=(ComPtr&& rhs)
- {
- if(mPtr)
- mPtr->Release();
- mPtr = rhs.mPtr;
- rhs.mPtr = nullptr;
- return *this;
- }
-
- operator bool() const noexcept { return mPtr != nullptr; }
-
- T& operator*() const noexcept { return *mPtr; }
- T* operator->() const noexcept { return mPtr; }
- T* get() const noexcept { return mPtr; }
- T** getPtr() noexcept { return &mPtr; }
-
- T* release() noexcept
- {
- T *ret{mPtr};
- mPtr = nullptr;
- return ret;
- }
-
- void swap(ComPtr &rhs) noexcept { std::swap(mPtr, rhs.mPtr); }
- void swap(ComPtr&& rhs) noexcept { std::swap(mPtr, rhs.mPtr); }
-};
-
-
class GuidPrinter {
char mMsg[64];