Jacek Caban : msident: Added IUserIdentityManager:: EnumIdentities implementation.

Alexandre Julliard julliard at winehq.org
Mon Mar 12 12:00:00 CDT 2012


Module: wine
Branch: master
Commit: 7b6498314c4216723b43d8d8542c021f1e2ed12d
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=7b6498314c4216723b43d8d8542c021f1e2ed12d

Author: Jacek Caban <jacek at codeweavers.com>
Date:   Mon Mar 12 13:02:32 2012 +0100

msident: Added IUserIdentityManager::EnumIdentities implementation.

---

 dlls/msident/msident.c |  127 +++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 125 insertions(+), 2 deletions(-)

diff --git a/dlls/msident/msident.c b/dlls/msident/msident.c
index 4c688b8..c12c19b 100644
--- a/dlls/msident/msident.c
+++ b/dlls/msident/msident.c
@@ -27,8 +27,120 @@
 
 WINE_DEFAULT_DEBUG_CHANNEL(msident);
 
+static inline void *heap_alloc(size_t len)
+{
+    return HeapAlloc(GetProcessHeap(), 0, len);
+}
+
+static inline BOOL heap_free(void *mem)
+{
+    return HeapFree(GetProcessHeap(), 0, mem);
+}
+
 static HINSTANCE msident_instance;
 
+typedef struct {
+    IEnumUserIdentity IEnumUserIdentity_iface;
+    LONG ref;
+} EnumUserIdentity;
+
+static inline EnumUserIdentity *impl_from_IEnumUserIdentity(IEnumUserIdentity *iface)
+{
+    return CONTAINING_RECORD(iface, EnumUserIdentity, IEnumUserIdentity_iface);
+}
+
+static HRESULT WINAPI EnumUserIdentity_QueryInterface(IEnumUserIdentity *iface, REFIID riid, void **ppv)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+
+    if(IsEqualGUID(&IID_IUnknown, riid)) {
+        TRACE("(IID_IUnknown %p)\n", ppv);
+        *ppv = &This->IEnumUserIdentity_iface;
+    }else if(IsEqualGUID(&IID_IEnumUserIdentity, riid)) {
+        TRACE("(IID_IEnumUserIdentity %p)\n", ppv);
+        *ppv = &This->IEnumUserIdentity_iface;
+    }else {
+        WARN("(%s %p)\n", debugstr_guid(riid), ppv);
+        *ppv = NULL;
+        return E_NOINTERFACE;
+    }
+
+    IUnknown_AddRef((IUnknown*)*ppv);
+    return S_OK;
+}
+
+static ULONG WINAPI EnumUserIdentity_AddRef(IEnumUserIdentity *iface)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+    LONG ref = InterlockedIncrement(&This->ref);
+
+    TRACE("(%p) ref=%d\n", This, ref);
+
+    return ref;
+}
+
+static ULONG WINAPI EnumUserIdentity_Release(IEnumUserIdentity *iface)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+    LONG ref = InterlockedDecrement(&This->ref);
+
+    TRACE("(%p) ref=%d\n", This, ref);
+
+    if(!ref)
+        heap_free(This);
+
+    return ref;
+}
+
+static HRESULT WINAPI EnumUserIdentity_Next(IEnumUserIdentity *iface, ULONG celt, IUnknown **rgelt, ULONG *pceltFetched)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+    FIXME("(%p)->(%u %p %p)\n", This, celt, rgelt, pceltFetched);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI EnumUserIdentity_Skip(IEnumUserIdentity *iface, ULONG celt)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+    FIXME("(%p)->(%u)\n", This, celt);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI EnumUserIdentity_Reset(IEnumUserIdentity *iface)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+    FIXME("(%p)->()\n", This);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI EnumUserIdentity_Clone(IEnumUserIdentity *iface, IEnumUserIdentity **ppenum)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+    FIXME("(%p)->(%p)\n", This, ppenum);
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI EnumUserIdentity_GetCount(IEnumUserIdentity *iface, ULONG *pnCount)
+{
+    EnumUserIdentity *This = impl_from_IEnumUserIdentity(iface);
+
+    FIXME("(%p)->(%p)\n", This, pnCount);
+
+    *pnCount = 0;
+    return S_OK;
+}
+
+static const IEnumUserIdentityVtbl EnumUserIdentityVtbl = {
+    EnumUserIdentity_QueryInterface,
+    EnumUserIdentity_AddRef,
+    EnumUserIdentity_Release,
+    EnumUserIdentity_Next,
+    EnumUserIdentity_Skip,
+    EnumUserIdentity_Reset,
+    EnumUserIdentity_Clone,
+    EnumUserIdentity_GetCount
+};
+
 static HRESULT WINAPI UserIdentityManager_QueryInterface(IUserIdentityManager *iface, REFIID riid, void **ppv)
 {
     if(IsEqualGUID(&IID_IUnknown, riid)) {
@@ -61,8 +173,19 @@ static ULONG WINAPI UserIdentityManager_Release(IUserIdentityManager *iface)
 
 static HRESULT WINAPI UserIdentityManager_EnumIdentities(IUserIdentityManager *iface, IEnumUserIdentity **ppEnumUser)
 {
-    FIXME("(%p)\n", ppEnumUser);
-    return E_NOTIMPL;
+    EnumUserIdentity *ret;
+
+    TRACE("(%p)\n", ppEnumUser);
+
+    ret = heap_alloc(sizeof(*ret));
+    if(!ret)
+        return E_OUTOFMEMORY;
+
+    ret->IEnumUserIdentity_iface.lpVtbl = &EnumUserIdentityVtbl;
+    ret->ref = 1;
+
+    *ppEnumUser = &ret->IEnumUserIdentity_iface;
+    return S_OK;
 }
 
 static HRESULT WINAPI UserIdentityManager_ManageIdentities(IUserIdentityManager *iface, HWND hwndParent, DWORD dwFlags)




More information about the wine-cvs mailing list