return 0;
 }
 
+static void update_submodule(struct update_clone_data *ucd)
+{
+       fprintf(stdout, "dummy %s %d\t%s\n",
+               oid_to_hex(&ucd->oid),
+               ucd->just_cloned,
+               ucd->sub->path);
+}
+
 static int update_submodules(struct submodule_update_clone *suc)
 {
        int i;
-       struct strbuf sb = STRBUF_INIT;
 
        run_processes_parallel(suc->max_jobs,
                               update_clone_get_next_task,
        if (suc->quickstop)
                return 1;
 
-       for (i = 0; i < suc->update_clone_nr; i++) {
-               strbuf_addf(&sb, "dummy %s %d\t%s\n",
-                       oid_to_hex(&suc->update_clone[i].oid),
-                       suc->update_clone[i].just_cloned,
-                       suc->update_clone[i].sub->path);
-               fprintf(stdout, "%s", sb.buf);
-               strbuf_reset(&sb);
-       }
+       for (i = 0; i < suc->update_clone_nr; i++)
+               update_submodule(&suc->update_clone[i]);
 
-       strbuf_release(&sb);
        return 0;
 }