@@ -38,6 +38,8 @@ struct Visitor
size_t elem_count, size_t elem_size, Error **errp);
void (*next_carray)(Visitor *v, Error **errp);
void (*end_carray)(Visitor *v, Error **errp);
+ void (*type_sized_buffer)(Visitor *v, uint8_t **obj, size_t size,
+ const char *name, Error **errp);
/* May be NULL */
void (*start_optional)(Visitor *v, bool *present, const char *name,
@@ -55,5 +55,7 @@ void visit_start_carray(Visitor *v, void **obj, const char *name,
size_t elem_count, size_t elem_size, Error **errp);
void visit_next_carray(Visitor *v, Error **errp);
void visit_end_carray(Visitor *v, Error **errp);
+void visit_type_sized_buffer(Visitor *v, uint8_t **obj, size_t len,
+ const char *name, Error **errp);
#endif
@@ -338,3 +338,11 @@ void visit_end_carray(Visitor *v, Error **errp)
v->end_carray(v, errp);
}
}
+
+void visit_type_sized_buffer(Visitor *v, uint8_t **obj, size_t len,
+ const char *name, Error **errp)
+{
+ if (!error_is_set(errp)) {
+ v->type_sized_buffer(v, obj, len, name, errp);
+ }
+}