Hans Leidekker : snmpapi: Implement SnmpUtilOidCpy,
SnmpUtilOidFree and SnmpUtilVarBindFree.
Alexandre Julliard
julliard at wine.codeweavers.com
Mon Jan 15 07:43:13 CST 2007
Module: wine
Branch: master
Commit: f1fc35de3872c5e07b55df988d1c6f6bdf3b2fbd
URL: http://source.winehq.org/git/wine.git/?a=commit;h=f1fc35de3872c5e07b55df988d1c6f6bdf3b2fbd
Author: Hans Leidekker <hans at it.vu.nl>
Date: Sun Jan 14 19:19:52 2007 +0100
snmpapi: Implement SnmpUtilOidCpy, SnmpUtilOidFree and SnmpUtilVarBindFree.
---
dlls/snmpapi/main.c | 60 +++++++++++++++++++++++++++++++++++++++++++++
dlls/snmpapi/snmpapi.spec | 6 ++--
include/snmp.h | 3 ++
3 files changed, 66 insertions(+), 3 deletions(-)
diff --git a/dlls/snmpapi/main.c b/dlls/snmpapi/main.c
index 114aa92..71c793c 100644
--- a/dlls/snmpapi/main.c
+++ b/dlls/snmpapi/main.c
@@ -24,6 +24,8 @@
#include "windef.h"
#include "winbase.h"
+#include "snmp.h"
+
#include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL(snmpapi);
@@ -50,3 +52,61 @@ BOOL WINAPI DllMain(
return TRUE;
}
+
+INT WINAPI SnmpUtilOidCpy(AsnObjectIdentifier *dst, AsnObjectIdentifier *src)
+{
+ unsigned int i, size;
+
+ TRACE("(%p, %p)\n", dst, src);
+
+ size = sizeof(AsnObjectIdentifier);
+ if ((dst = HeapAlloc(GetProcessHeap(), 0, size)))
+ {
+ size = src->idLength * sizeof(UINT);
+ if (!(dst->ids = HeapAlloc(GetProcessHeap(), 0, size)))
+ {
+ HeapFree(GetProcessHeap(), 0, dst);
+ return SNMPAPI_ERROR;
+ }
+ dst->idLength = src->idLength;
+ for (i = 0; i < dst->idLength; i++) dst->ids[i] = src->ids[i];
+ return SNMPAPI_NOERROR;
+ }
+ return SNMPAPI_ERROR;
+}
+
+void WINAPI SnmpUtilOidFree(AsnObjectIdentifier *oid)
+{
+ TRACE("(%p)\n", oid);
+
+ HeapFree(GetProcessHeap(), 0, oid->ids);
+ HeapFree(GetProcessHeap(), 0, oid);
+}
+
+void WINAPI SnmpUtilVarBindFree(SnmpVarBind *vb)
+{
+ TRACE("(%p)\n", vb);
+
+ switch (vb->value.asnType)
+ {
+ case ASN_OCTETSTRING:
+ case ASN_BITS:
+ case ASN_SEQUENCE:
+ case ASN_IPADDRESS:
+ case ASN_OPAQUE:
+ {
+ if (vb->value.asnValue.string.dynamic)
+ HeapFree(GetProcessHeap(), 0, vb->value.asnValue.string.stream);
+ break;
+ }
+ case ASN_OBJECTIDENTIFIER:
+ {
+ HeapFree(GetProcessHeap(), 0, vb->value.asnValue.object.ids);
+ break;
+ }
+ default: break;
+ }
+
+ HeapFree(GetProcessHeap(), 0, vb->name.ids);
+ HeapFree(GetProcessHeap(), 0, vb);
+}
diff --git a/dlls/snmpapi/snmpapi.spec b/dlls/snmpapi/snmpapi.spec
index 1452ad7..ec59e9c 100644
--- a/dlls/snmpapi/snmpapi.spec
+++ b/dlls/snmpapi/snmpapi.spec
@@ -25,8 +25,8 @@
@ stub SnmpUtilMemReAlloc
@ stub SnmpUtilOidAppend
@ stub SnmpUtilOidCmp
-@ stub SnmpUtilOidCpy
-@ stub SnmpUtilOidFree
+@ stdcall SnmpUtilOidCpy(ptr ptr)
+@ stdcall SnmpUtilOidFree(ptr)
@ stub SnmpUtilOidNCmp
@ stub SnmpUtilOidToA
@ stub SnmpUtilPrintAsnAny
@@ -34,6 +34,6 @@
@ stub SnmpUtilStrlenW
@ stub SnmpUtilUnicodeToAnsi
@ stub SnmpUtilVarBindCpy
-@ stub SnmpUtilVarBindFree
+@ stdcall SnmpUtilVarBindFree(ptr)
@ stub SnmpUtilVarBindListCpy
@ stub SnmpUtilVarBindListFree
diff --git a/include/snmp.h b/include/snmp.h
index e453b72..aaece6c 100644
--- a/include/snmp.h
+++ b/include/snmp.h
@@ -201,6 +201,9 @@ typedef struct {
#define SNMP_AUTHAPI_INVALID_MSG_TYPE 31
#define SNMP_AUTHAPI_TRIV_AUTH_FAILED 32
+#define SNMPAPI_NOERROR TRUE
+#define SNMPAPI_ERROR FALSE
+
#ifdef __cplusplus
extern "C" {
#endif
More information about the wine-cvs
mailing list