crypt32: Implement CertDuplicateStore.
diff --git a/dlls/crypt32/crypt32.spec b/dlls/crypt32/crypt32.spec
index abeff35..7d40394 100644
--- a/dlls/crypt32/crypt32.spec
+++ b/dlls/crypt32/crypt32.spec
@@ -26,7 +26,7 @@
@ stub CertDuplicateCRLContext
@ stub CertDuplicateCTLContext
@ stdcall CertDuplicateCertificateContext(ptr)
-@ stub CertDuplicateStore
+@ stdcall CertDuplicateStore(ptr)
@ stub CertEnumCRLContextProperties
@ stdcall CertEnumCRLsInStore(ptr ptr)
@ stub CertEnumCTLContextProperties
diff --git a/dlls/crypt32/store.c b/dlls/crypt32/store.c
index 47e595c..b8a3d0f 100644
--- a/dlls/crypt32/store.c
+++ b/dlls/crypt32/store.c
@@ -2626,6 +2626,16 @@
return NULL;
}
+HCERTSTORE WINAPI CertDuplicateStore(HCERTSTORE hCertStore)
+{
+ WINECRYPT_CERTSTORE *hcs = (WINECRYPT_CERTSTORE *)hCertStore;
+
+ TRACE("(%p)\n", hCertStore);
+
+ if (hcs && hcs->dwMagic == WINE_CRYPTCERTSTORE_MAGIC)
+ InterlockedIncrement(&hcs->ref);
+ return hCertStore;
+}
BOOL WINAPI CertCloseStore(HCERTSTORE hCertStore, DWORD dwFlags)
{
diff --git a/include/wincrypt.h b/include/wincrypt.h
index 678f466..9784223 100644
--- a/include/wincrypt.h
+++ b/include/wincrypt.h
@@ -2605,6 +2605,8 @@
BOOL WINAPI CertControlStore(HCERTSTORE hCertStore, DWORD dwFlags,
DWORD dwCtrlType, void const *pvCtrlPara);
+HCERTSTORE WINAPI CertDuplicateStore(HCERTSTORE hCertStore);
+
BOOL WINAPI CertCloseStore( HCERTSTORE hCertStore, DWORD dwFlags );
BOOL WINAPI CertFreeCertificateContext( PCCERT_CONTEXT pCertContext );