194 |
|
/* write out each object group */ |
195 |
|
for (i = 0; i < sc->ngrps; i++) { |
196 |
|
if (verbose) |
197 |
< |
fprintf(stderr, " Writing faces %s \r", |
197 |
> |
fprintf(stderr, " Writing faces %-50s\r", |
198 |
|
sc->grpname[i]); |
199 |
|
write_group(sc, i, fp); |
200 |
|
} |
202 |
|
error(SYSTEM, "Error flushing .OBJ output"); |
203 |
|
return(-1); |
204 |
|
} |
205 |
+ |
if (verbose) |
206 |
+ |
fprintf(stderr, "Wrote %d faces \n", |
207 |
+ |
sc->nfaces); |
208 |
|
return(sc->nfaces); |
209 |
|
} |
210 |
|
|
223 |
|
if ((fp = popen(fspec+1, "w")) == NULL) { |
224 |
|
sprintf(errmsg, "%s: cannot execute", fspec); |
225 |
|
error(SYSTEM, errmsg); |
226 |
< |
return(0); |
226 |
> |
return(-1); |
227 |
|
} |
228 |
|
} else |
229 |
|
#endif |
230 |
|
if ((fp = fopen(fspec, "w")) == NULL) { |
231 |
|
sprintf(errmsg, "%s: cannot open for writing", fspec); |
232 |
|
error(SYSTEM, errmsg); |
233 |
< |
return(0); |
233 |
> |
return(-1); |
234 |
|
} |
235 |
|
/* start off header */ |
236 |
|
fprintf(fp, "# Wavefront .OBJ file created by %s\n#\n", progname); |
237 |
|
n = toOBJ(sc, fp); /* write scene */ |
238 |
|
#if POPEN_SUPPORT |
239 |
< |
if (fspec[0] == '!') |
240 |
< |
pclose(fp); |
241 |
< |
else |
239 |
> |
if (fspec[0] == '!') { |
240 |
> |
if (pclose(fp)) { |
241 |
> |
sprintf(errmsg, "%s: error writing to command\n", fspec); |
242 |
> |
error(SYSTEM, errmsg); |
243 |
> |
return(-1); |
244 |
> |
} |
245 |
> |
} else |
246 |
|
#endif |
247 |
< |
fclose(fp); /* close it */ |
247 |
> |
fclose(fp); /* close it (already flushed) */ |
248 |
|
return(n); |
249 |
|
} |