aboutsummaryrefslogtreecommitdiff
path: root/Src/Winamp/DataStoreCOM.cpp
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Winamp/DataStoreCOM.cpp
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Winamp/DataStoreCOM.cpp')
-rw-r--r--Src/Winamp/DataStoreCOM.cpp130
1 files changed, 130 insertions, 0 deletions
diff --git a/Src/Winamp/DataStoreCOM.cpp b/Src/Winamp/DataStoreCOM.cpp
new file mode 100644
index 00000000..3581f7a5
--- /dev/null
+++ b/Src/Winamp/DataStoreCOM.cpp
@@ -0,0 +1,130 @@
+#include "DataStoreCOM.h"
+
+enum
+{
+ DISP_DATASTORE_STORE,
+ DISP_DATASTORE_RETRIEVE,
+ DISP_DATASTORE_GENERATE_GUID,
+};
+
+#define CHECK_ID(str, id)\
+ if (CSTR_EQUAL == CompareStringW(lcid, NORM_IGNORECASE, rgszNames[i], -1, L##str, -1))\
+ { rgdispid[i] = id; continue; }
+
+HRESULT DataStoreCOM::GetIDsOfNames(REFIID riid, OLECHAR FAR* FAR* rgszNames, unsigned int cNames, LCID lcid, DISPID FAR* rgdispid)
+{
+ bool unknowns = false;
+ for (unsigned int i = 0;i != cNames;i++)
+ {
+ CHECK_ID("Store", DISP_DATASTORE_STORE);
+ CHECK_ID("Retrieve", DISP_DATASTORE_RETRIEVE);
+ CHECK_ID("GenerateGUID", DISP_DATASTORE_GENERATE_GUID);
+
+ rgdispid[i] = DISPID_UNKNOWN;
+ unknowns = true;
+
+ }
+ if (unknowns)
+ return DISP_E_UNKNOWNNAME;
+ else
+ return S_OK;
+}
+
+HRESULT DataStoreCOM::GetTypeInfo(unsigned int itinfo, LCID lcid, ITypeInfo FAR* FAR* pptinfo)
+{
+ return E_NOTIMPL;
+}
+
+HRESULT DataStoreCOM::GetTypeInfoCount(unsigned int FAR * pctinfo)
+{
+ return E_NOTIMPL;
+}
+
+HRESULT DataStoreCOM::Invoke(DISPID dispid, REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS FAR *pdispparams, VARIANT FAR *pvarResult, EXCEPINFO FAR * pexecinfo, unsigned int FAR *puArgErr)
+{
+ switch (dispid)
+ {
+ case DISP_DATASTORE_GENERATE_GUID:
+ {
+ GUID guid;
+ UuidCreate(&guid);
+ wchar_t *guid_string;
+ UuidToStringW(&guid, (unsigned short **)&guid_string);
+ BSTR tag = SysAllocString(guid_string);
+ RpcStringFreeW((unsigned short **)&guid_string);
+ VariantInit(pvarResult);
+ V_VT(pvarResult) = VT_BSTR;
+ V_BSTR(pvarResult) = tag;
+ return S_OK;
+ }
+ case DISP_DATASTORE_STORE:
+ if (pdispparams->cArgs == 2)
+ {
+ GUID guid;
+ UuidFromStringW((unsigned short *)pdispparams->rgvarg[1].bstrVal, &guid);
+
+ SAFEARRAY *bufferArray=pdispparams->rgvarg[0].parray;
+ SAFEARRAY *store;
+ HRESULT hr = SafeArrayCopy(bufferArray, &store);
+ dataStore[guid]=store;
+ return hr;
+
+ }
+ else
+ return DISP_E_BADPARAMCOUNT;
+ case DISP_DATASTORE_RETRIEVE:
+ if (pdispparams->cArgs == 1)
+ {
+ GUID guid;
+ UuidFromStringW((unsigned short *)pdispparams->rgvarg[0].bstrVal, &guid);
+
+ SAFEARRAY *store = dataStore[guid];
+ if (store)
+ {
+ SAFEARRAY *bufferArray;
+ SafeArrayCopy(store, &bufferArray);
+ VariantInit(pvarResult);
+ V_VT(pvarResult) = VT_ARRAY|VT_UI1;
+ V_ARRAY(pvarResult) = bufferArray;
+ return S_OK;
+ }
+ else
+ return E_FAIL;
+
+ }
+ else
+ return DISP_E_BADPARAMCOUNT;
+ }
+ return DISP_E_MEMBERNOTFOUND;
+}
+
+STDMETHODIMP DataStoreCOM::QueryInterface(REFIID riid, PVOID *ppvObject)
+{
+ if (!ppvObject)
+ return E_POINTER;
+
+ else if (IsEqualIID(riid, IID_IDispatch))
+ *ppvObject = (IDispatch *)this;
+ else if (IsEqualIID(riid, IID_IUnknown))
+ *ppvObject = this;
+ else
+ {
+ *ppvObject = NULL;
+ return E_NOINTERFACE;
+ }
+
+ AddRef();
+ return S_OK;
+}
+
+
+ULONG DataStoreCOM::AddRef(void)
+{
+ return 0;
+}
+
+
+ULONG DataStoreCOM::Release(void)
+{
+ return 0;
+}