Fixed broken submsg support in upb_streamdata.

pull/13171/head
Joshua Haberman 15 years ago
parent af9d691a34
commit b77db14646
  1. 10
      core/upb_stream.c
  2. 2
      stream/upb_textprinter.c

@ -14,11 +14,14 @@
void upb_streamdata(upb_src *src, upb_sink *sink, upb_status *status) {
upb_fielddef *f;
upb_string *str = NULL;
int depth = 0;
while(1) {
while((f = upb_src_getdef(src)) != NULL) {
CHECKSINK(upb_sink_putdef(sink, f));
if(upb_issubmsg(f)) {
// We always recurse into submessages, but the putdef above already told
// the sink that.
upb_src_startmsg(src);
upb_sink_startmsg(sink);
++depth;
} else if(upb_isstring(f)) {
str = upb_string_tryrecycle(str);
CHECKSRC(upb_src_getstr(src, str));
@ -32,6 +35,9 @@ void upb_streamdata(upb_src *src, upb_sink *sink, upb_status *status) {
}
// If we're not EOF now, the loop terminated due to an error.
CHECKSRC(upb_src_eof(src));
if (depth == 0) break;
--depth;
}
return;
src_err:

@ -79,7 +79,7 @@ static bool upb_textprinter_putdef(upb_textprinter *p, upb_fielddef *f)
{
upb_textprinter_indent(p);
upb_bytesink_put(p->bytesink, f->name);
upb_bytesink_put(p->bytesink, UPB_STRLIT(":"));
upb_bytesink_put(p->bytesink, UPB_STRLIT(": "));
p->f = f;
return upb_ok(upb_bytesink_status(p->bytesink));
}

Loading…
Cancel
Save