# HG changeset patch
# User Dan Smith <danms(a)us.ibm.com>
# Date 1202834758 28800
# Node ID 9fce57574cea5d9c9dd00ba2606e671c139b9fad
# Parent 4675887c96e72b9869d2924326cfe4e7370dc8f7
[CU] Integrate the CIMXML EO parser with the libcmpiutil interface
Signed-off-by: Dan Smith <danms(a)us.ibm.com>
diff -r 4675887c96e7 -r 9fce57574cea eo_parser.c
--- a/eo_parser.c Tue Feb 12 08:45:51 2008 -0800
+++ b/eo_parser.c Tue Feb 12 08:45:58 2008 -0800
@@ -31,13 +31,14 @@
#include "libcmpiutil.h"
#include "eo_util_parser.h"
+#include "eo_parser_xml.h"
#define TEMPLATE "/tmp/tmp_eo_parse.XXXXXX"
void eo_parse_restart(FILE *);
int eo_parse_parseinstance(const CMPIBroker *, CMPIInstance **, const char *ns);
-static int write_temp(char *eo)
+static int write_temp(const char *eo)
{
int fd;
int ret;
@@ -62,13 +63,13 @@ static int write_temp(char *eo)
return fd;
}
-int cu_parse_embedded_instance(const char *eo,
- const CMPIBroker *broker,
- const char *ns,
- CMPIInstance **instance)
+#ifdef HAVE_EOPARSER
+static int parse_ei_mof(const CMPIBroker *broker,
+ const char *ns,
+ const char *eo,
+ CMPIInstance **instance)
{
int ret;
-#ifdef HAVE_EOPARSER
int fd;
FILE *fp;
@@ -81,10 +82,29 @@ int cu_parse_embedded_instance(const cha
ret = eo_parse_parseinstance(broker, instance, ns);
close(fd);
+
+ return ret;
+}
+#endif
+
+int cu_parse_embedded_instance(const char *eo,
+ const CMPIBroker *broker,
+ const char *ns,
+ CMPIInstance **instance)
+{
+ if (strcasestr(eo, "<instance")) {
+ CU_DEBUG("Parsing CIMXML-style EI");
+ return cu_parse_ei_xml(broker, ns, eo, instance);
+ } else {
+#ifdef HAVE_EOPARSER
+ CU_DEBUG("Parsing MOF-style EI");
+ return parse_ei_mof(broker, ns, eo, instance);
#else
- ret = 0;
+ CU_DEBUG("EI parser did not see `<instance', "
+ "assuming not CIMXML");
+ return 0;
#endif
- return ret;
+ }
}
/*