Patryk Obara <patryk.ob...@gmail.com> writes: > Junio C Hamano <gits...@pobox.com> wrote: >> >> If I were doing the two-pass thing, I'd probably write a for loop >> that runs exactly twice, where the first iteration parses into a >> single throw-away oid struct only to count, and the second iteration >> parses the same input into the allocated array of oid struct. That >> way, you do not have to worry about two phrases going out of sync. > > Two passes would still differ in error handling due to xmalloc between them…
I am not sure if I follow. What I meant was something along these lines: struct commit_graft *graft = NULL; char *line = ... what you read from the file ...; int phase; /* phase #0 counts, phase #1 fills */ for (phase = 0; phase < 2; phase++) { int count; char *scan; strucut object_id dummy_oid, *oid; for (scan = line, count = 0; *scan; count++) { oid = graft ? &graft->parent[count] : &dummy_oid; if (parse_oid_hex(scan, oid, &scan)) return error(...); switch (*scan) { case ' ': scan++; continue; /* there are more */ case '\0': break; /* we are done */ default: return error(...); } } if (!graft) graft = xmalloc(... with 'count' parentes ...); } /* now we have graft with parent[count] all filled */ return graft; The inner for() loop will do the same parsing for both passes, leaving little chance for programming errors to make the two passes decide there are different number of fake parents. I suspect I may have botched some details in that loop, but both passes will even share the same buggy counting when the code is structured that way ;-) That is what I meant by "not have to worry about two phases going out of sync".