X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=formats%2Fctf-text%2Ftypes%2Fvariant.c;h=a21197aa1b3ad35bdac68c980fe2cf7c4bed0d88;hp=b4b72e16afeadb33420ec4998416dd8512402a34;hb=d335f0f72a86c7cdcc18e524c74b82a51ad01b16;hpb=c5e74408f9786219f6b44400dcf2098ab9cc78fb diff --git a/formats/ctf-text/types/variant.c b/formats/ctf-text/types/variant.c index b4b72e16..a21197aa 100644 --- a/formats/ctf-text/types/variant.c +++ b/formats/ctf-text/types/variant.c @@ -19,7 +19,36 @@ #include #include -int ctf_text_variant_write(struct stream_pos *pos, struct definition *definition) +int ctf_text_variant_write(struct stream_pos *ppos, struct definition *definition) { - return variant_rw(pos, definition); + struct ctf_text_stream_pos *pos = ctf_text_pos(ppos); + int field_nr_saved; + int ret; + + if (!print_field(definition)) + return 0; + + if (!pos->dummy) { + if (pos->depth >= 0) { + if (pos->field_nr++ != 0) + fprintf(pos->fp, ","); + fprintf(pos->fp, " "); + if (pos->print_names) + fprintf(pos->fp, "%s = ", + g_quark_to_string(definition->name)); + fprintf(pos->fp, "{"); + } + pos->depth++; + } + field_nr_saved = pos->field_nr; + pos->field_nr = 0; + ret = variant_rw(ppos, definition); + if (!pos->dummy) { + pos->depth--; + if (pos->depth >= 0) { + fprintf(pos->fp, " }"); + } + } + pos->field_nr = field_nr_saved; + return ret; }