X-Git-Url: https://git.draconx.ca/gitweb/liblbx.git/blobdiff_plain/958926fd7382d2c44828cdc70ca6c27bb281ff0d..bbcffc80c95c69d02635b02d37e78912c7f12305:/src/lbximg.c diff --git a/src/lbximg.c b/src/lbximg.c index fe7ab58..7827a87 100644 --- a/src/lbximg.c +++ b/src/lbximg.c @@ -364,11 +364,11 @@ err: int main(int argc, char **argv) { - int mode = MODE_NONE; - FILE *inf = stdin, *palf = NULL, *overf = NULL; + int mode = MODE_NONE, opt, rc = EXIT_FAILURE; + struct lbx_pipe_state state = { .f = stdin }; + FILE *palf = NULL, *overf = NULL; const char *name = "stdin"; LBX_IMG *img; - int opt; static const char *sopts = "idvf:p:O:V"; static const struct option lopts[] = { @@ -407,8 +407,7 @@ int main(int argc, char **argv) name = strrchr(optarg, '/'); name = name ? name+1 : optarg; - inf = fopen(optarg, "rb"); - if (!inf) { + if (!freopen(optarg, "rb", state.f)) { errmsg("failed to open %s: %m\n", optarg); return EXIT_FAILURE; } @@ -448,7 +447,11 @@ int main(int argc, char **argv) return EXIT_FAILURE; } - img = lbximg_fopen(inf); + if (fseek(state.f, 0, SEEK_CUR) == 0) + img = lbximg_open(state.f, &lbx_default_fops, NULL); + else + img = lbximg_open(&state, &lbx_pipe_fops, NULL); + if (!img) { errmsg("failed to open image: %s.\n", lbx_strerror()); return EXIT_FAILURE; @@ -466,13 +469,10 @@ int main(int argc, char **argv) switch (mode) { case MODE_DECODE: - if (decode(img, palf, overf, &argv[optind])) { - lbximg_close(img); - return EXIT_FAILURE; - } + rc = decode(img, palf, overf, &argv[optind]); break; } lbximg_close(img); - return EXIT_SUCCESS; + return rc; }