[prev in list] [next in list] [prev in thread] [next in thread]
List: xen-devel
Subject: [Xen-devel] [PATCH] [libxen] serialize string string maps
From: Stefan Berger <stefanb () us ! ibm ! com>
Date: 2007-03-31 15:56:33
Message-ID: 1175356593.8930.6.camel () 941e-2 ! watson ! ibm ! com
[Download RAW message or body]
This patch adds the functionality to serialize string string maps --
serializing other maps should be easy to add. I'll need this for one of
my extensions (later).
Signed-off-by: Stefan Berger <stefanb@us.ibm.com>
["libxen_serialize_string_string_map.c" (libxen_serialize_string_string_map.c)]
Index: root/xen-unstable.hg/tools/libxen/src/xen_common.c
===================================================================
--- root.orig/xen-unstable.hg/tools/libxen/src/xen_common.c
+++ root/xen-unstable.hg/tools/libxen/src/xen_common.c
@@ -102,6 +102,9 @@ add_struct_value(const struct abstract_t
const char *),
const char *, xmlNode *);
+static xmlNode *
+add_container(xmlNode *parent, const char *name);
+
static void
call_raw(xen_session *, const char *, abstract_value [], int,
const abstract_type *, void *);
@@ -1290,6 +1293,48 @@ make_body_add_type(enum abstract_typenam
}
break;
+ case MAP:
+ {
+ const struct struct_member *member = v->type->members;
+ arbitrary_map *map_val = v->u.struct_val;
+ xmlNode *param_node = add_param_struct(params_node);
+ for (size_t i = 0; i < map_val->size; i++) {
+ enum abstract_typename typename_key = member[0].type->typename;
+ enum abstract_typename typename_val = member[1].type->typename;
+ int offset_key = member[0].offset;
+ int offset_val = member[1].offset;
+ int struct_size = v->type->struct_size;
+
+ switch (typename_key) {
+ case STRING: {
+ char **addr = (void *)(map_val + 1) +
+ (i * struct_size) +
+ offset_key;
+ char *key = *addr;
+
+ switch (typename_val) {
+ case STRING: {
+ char *val;
+ addr = (void *)(map_val + 1) +
+ (i * struct_size) +
+ offset_val;
+ val = *addr;
+ add_struct_member(param_node, key, "string", val);
+ break;
+ }
+ default:
+ assert(false);
+ }
+ break;
+ }
+ default:
+ assert(false);
+ }
+ }
+ }
+ break;
+
+
default:
assert(false);
}
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xensource.com
http://lists.xensource.com/xen-devel
[prev in list] [next in list] [prev in thread] [next in thread]
Configure |
About |
News |
Add a list |
Sponsored by KoreLogic