msasn1: Implement ASN1_CloseModule function.

Signed-off-by: Vijay Kiran Kamuju <infyquest@gmail.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Vijay Kiran Kamuju 2020-05-05 14:21:43 +02:00 committed by Alexandre Julliard
parent 84096382fc
commit 0d2f303700
3 changed files with 11 additions and 1 deletions

View File

@ -84,3 +84,10 @@ ASN1module_t WINAPI ASN1_CreateModule(ASN1uint32_t ver, ASN1encodingrule_e rule,
return module; return module;
} }
void WINAPI ASN1_CloseModule(ASN1module_t module)
{
TRACE("(%p)\n", module);
heap_free(module);
}

View File

@ -219,7 +219,7 @@
@ stub ASN1_CloseDecoder @ stub ASN1_CloseDecoder
@ stub ASN1_CloseEncoder2 @ stub ASN1_CloseEncoder2
@ stub ASN1_CloseEncoder @ stub ASN1_CloseEncoder
@ stub ASN1_CloseModule @ stdcall ASN1_CloseModule(ptr)
@ stub ASN1_CreateDecoder @ stub ASN1_CreateDecoder
@ stub ASN1_CreateDecoderEx @ stub ASN1_CreateDecoderEx
@ stub ASN1_CreateEncoder @ stub ASN1_CreateEncoder

View File

@ -55,6 +55,7 @@ static void test_CreateModule(void)
ok(mod->acbStructSize==size, "Struct size = %p.\n",mod->acbStructSize); ok(mod->acbStructSize==size, "Struct size = %p.\n",mod->acbStructSize);
ok(!mod->PER.apfnEncoder, "Encoder function should not be s et.\n"); ok(!mod->PER.apfnEncoder, "Encoder function should not be s et.\n");
ok(!mod->PER.apfnDecoder, "Decoder function should not be set.\n"); ok(!mod->PER.apfnDecoder, "Decoder function should not be set.\n");
ASN1_CloseModule(mod);
mod = ASN1_CreateModule(ASN1_THIS_VERSION, ASN1_BER_RULE_DER, ASN1FLAGS_NOASSERT, 1, encfn, decfn, freefn, size, name); mod = ASN1_CreateModule(ASN1_THIS_VERSION, ASN1_BER_RULE_DER, ASN1FLAGS_NOASSERT, 1, encfn, decfn, freefn, size, name);
ok(!!mod, "Failed to create module.\n"); ok(!!mod, "Failed to create module.\n");
@ -66,6 +67,7 @@ static void test_CreateModule(void)
ok(mod->acbStructSize==size, "Struct size = %p.\n",mod->acbStructSize); ok(mod->acbStructSize==size, "Struct size = %p.\n",mod->acbStructSize);
ok(mod->BER.apfnEncoder==(ASN1BerEncFun_t *)encfn, "Encoder function = %p.\n",mod->BER.apfnEncoder); ok(mod->BER.apfnEncoder==(ASN1BerEncFun_t *)encfn, "Encoder function = %p.\n",mod->BER.apfnEncoder);
ok(mod->BER.apfnDecoder==(ASN1BerDecFun_t *)decfn, "Decoder function = %p.\n",mod->BER.apfnDecoder); ok(mod->BER.apfnDecoder==(ASN1BerDecFun_t *)decfn, "Decoder function = %p.\n",mod->BER.apfnDecoder);
ASN1_CloseModule(mod);
mod = ASN1_CreateModule(ASN1_THIS_VERSION, ASN1_PER_RULE_ALIGNED, ASN1FLAGS_NOASSERT, 1, encfn, decfn, freefn, size, name); mod = ASN1_CreateModule(ASN1_THIS_VERSION, ASN1_PER_RULE_ALIGNED, ASN1FLAGS_NOASSERT, 1, encfn, decfn, freefn, size, name);
ok(!!mod, "Failed to create module.\n"); ok(!!mod, "Failed to create module.\n");
@ -79,6 +81,7 @@ static void test_CreateModule(void)
broken(!mod->PER.apfnEncoder), "Encoder function = %p.\n",mod->PER.apfnEncoder); broken(!mod->PER.apfnEncoder), "Encoder function = %p.\n",mod->PER.apfnEncoder);
ok(mod->PER.apfnDecoder==(ASN1PerDecFun_t *)decfn /* WINXP & WIN2008 */ || ok(mod->PER.apfnDecoder==(ASN1PerDecFun_t *)decfn /* WINXP & WIN2008 */ ||
broken(!mod->PER.apfnDecoder), "Decoder function = %p.\n",mod->PER.apfnDecoder); broken(!mod->PER.apfnDecoder), "Decoder function = %p.\n",mod->PER.apfnDecoder);
ASN1_CloseModule(mod);
} }
START_TEST(asn1) START_TEST(asn1)