$SUBJ: qemu_monitor_json: Introduce qemuMonitorJSONBuildCPUModelInfoToJSON The corollary for qemuMonitorJSONBuildCPUModelInfoFromJSON is to build the JSON data from the qemuMonitorCPUModelInfoPtr. On 04/19/2018 12:06 AM, Chris Venteicher wrote: > Function qemuMonitorJSONBuildCPUModelInfoToJSON > builds and returns JSON of form > {"model": {"name": "IvyBridge", "props": {}}} > from qemuMonitorCPUModelInfo. > > Function qemuMonitorJSONBuildCPUModelInfoToJSON > returns virJsonValuePtr on success and NULL on failure. > --- > src/qemu/qemu_monitor_json.c | 48 ++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 48 insertions(+) > > diff --git a/src/qemu/qemu_monitor_json.c b/src/qemu/qemu_monitor_json.c > index 4368aaaa0..44c1b2f15 100644 > --- a/src/qemu/qemu_monitor_json.c > +++ b/src/qemu/qemu_monitor_json.c > @@ -5337,6 +5337,54 @@ qemuMonitorJSONParseCPUModelProperty(const char *key, > return 0; > } > Again 2 blank lines (at end too). > +/* model_json: {"model": {"name": "IvyBridge", "props": {}}} > + */ > +static virJSONValuePtr > +qemuMonitorJSONBuildCPUModelInfoToJSON(qemuMonitorCPUModelInfoPtr model) > +{ > + virJSONValuePtr cpu_props = NULL; > + virJSONValuePtr model_json = NULL; > + size_t i; > + > + if (!(cpu_props = virJSONValueNewObject())) > + goto cleanup; > + > + for (i = 0; i < model->nprops; i++) { > + qemuMonitorCPUPropertyPtr prop = model->props + i; or prop = model->props[i] - something I'm more used to seeing. > + > + switch (prop->type) { > + case QEMU_MONITOR_CPU_PROPERTY_BOOLEAN: > + if (virJSONValueObjectAppendBoolean(cpu_props, prop->name, prop->value.boolean) < 0) Long line - consider creating line break after prop->name Prefer to keep lines < 80 if possible unless it's just a character or two. > + goto cleanup; > + break; > + > + case QEMU_MONITOR_CPU_PROPERTY_STRING: > + if (virJSONValueObjectAppendString(cpu_props, prop->name, prop->value.string) < 0) > + goto cleanup; > + break; > + > + case QEMU_MONITOR_CPU_PROPERTY_NUMBER: > + if (virJSONValueObjectAppendNumberLong(cpu_props, prop->name, prop->value.number) < 0) > + goto cleanup; > + break; > + > + case QEMU_MONITOR_CPU_PROPERTY_LAST: > + default: > + virReportEnumRangeError(qemuMonitorCPUPropertyPtr, prop->type); > + goto cleanup; > + } > + } > + > + if (virJSONValueObjectCreate(&model_json, "s:name", model->name, > + "a:props", &cpu_props, NULL) < 0) { > + virJSONValueFree(cpu_props); > + goto cleanup; > + } I just know the above will cause Coverity to get all upset, but I think if you go with ignore_value(virJSONValueObjectCreate(&model_json, "s:name", model->name, "a:props", &cpu_props, NULL)); cleanup: virJSONValueFree(cpu_props); return model_json; Then things will be fine. In the long run since @model_json is the returned thing and it'd only be non NULL if virJSONValueObjectCreate succeeded and it woudl consume @cpu_props properly, thus we don't care about the return value because it's not changing what we do. But not having that @cpu_props Free makes coverity believe it's leaked even though it's passed by reference. John > + > + cleanup: > + return model_json; > +} > + > /* model_json: {"model": {"name": "IvyBridge", "props": {}}} > */ > static qemuMonitorCPUModelInfoPtr > -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list