FloatImg4PythonBinding/tools/fimg2pnm.c

129 lines
2.8 KiB
C
Raw Normal View History

2019-07-03 18:51:42 +02:00
/*
* conversion vers le format PNM
*
*/
2019-03-03 16:22:55 +01:00
#include <stdio.h>
#include <stdlib.h>
2021-05-20 09:31:28 +02:00
#include <stdint.h>
2019-03-03 16:22:55 +01:00
#include <unistd.h>
#include "../floatimg.h"
int verbosity;
/* --------------------------------------------------------------------- */
int convertir_fimg_en_pnm(char *srcname, char *dstname, int to_gray)
2019-03-03 16:22:55 +01:00
{
int foo, infos[3];
FloatImg fimg, gris, *outptr;
2019-03-03 16:22:55 +01:00
#if DEBUG_LEVEL
fprintf(stderr, ">>> %25s ( '%s' '%s' %d )\n", __func__,
srcname, dstname, to_gray);
2019-03-03 16:22:55 +01:00
#endif
foo = fimg_fileinfos(srcname, infos);
if (foo) { fprintf(stderr, "'%s' get dims -> %d\n", srcname, foo); }
if (verbosity) {
2019-09-10 12:18:02 +02:00
fprintf(stderr, "image '%s' is %d x %d %s\n",
srcname, infos[0], infos[1],
fimg_str_type(infos[2]));
2019-03-03 16:22:55 +01:00
}
foo = fimg_create_from_dump(srcname, &fimg);
if (foo) {
fprintf(stderr, "create fimg from '%s' -> %d\n", srcname, foo);
return -1;
}
outptr = &fimg; /* safe default value */
if (to_gray) {
2019-09-11 19:17:03 +02:00
if (verbosity) puts("converting to gray...");
foo = fimg_create(&gris, fimg.width, fimg.height, FIMG_TYPE_GRAY);
if (foo) {
fprintf(stderr, "err create gray %d\n", foo);
return -2;
}
foo = fimg_mk_gray_from(&fimg, &gris, 0);
if (foo) {
fprintf(stderr, "err mk gray %d\n", foo);
return -4;
}
outptr = &gris;
}
2019-03-03 16:22:55 +01:00
#if DEBUG_LEVEL > 1
print_floatimg(outptr, "created fimg");
2019-03-03 16:22:55 +01:00
#endif
foo = fimg_save_as_pnm(outptr, dstname, 0);
2019-03-03 16:22:55 +01:00
if(foo) { fprintf(stderr, "%p to '%s' -> %d\n", &fimg, dstname, foo); }
if (to_gray) {
fimg_destroy(&gris);
outptr = NULL;
/* please run valgrind every hour */
}
2019-03-03 16:22:55 +01:00
return 0;
}
/* --------------------------------------------------------------------- */
2019-09-10 12:18:02 +02:00
static void help(int flag)
{
if (flag) {
fprintf(stderr, "conversion FIMG -> PNM 16 bits\n");
fimg_print_version(1);
}
puts("usage :");
puts("\tfimg2pnm [flags] infile.fimg outfile.pnm");
2020-04-02 14:49:10 +02:00
puts("flags :");
puts("\t-g\tconvert to gray");
puts("\t-v\tenhance your verbosity");
2019-09-10 12:18:02 +02:00
}
/* --------------------------------------------------------------------- */
2019-03-03 16:22:55 +01:00
int main(int argc, char *argv[])
{
2019-09-10 12:18:02 +02:00
int foo, opt;
int to_gray = 0;
2019-03-03 16:22:55 +01:00
2019-09-10 12:18:02 +02:00
if (argc == 1) {
help(0);
exit(0);
}
while ((opt = getopt(argc, argv, "ghv")) != -1) {
2019-09-10 12:18:02 +02:00
switch(opt) {
2019-09-11 19:17:03 +02:00
case 'g': to_gray = 1; break;
2019-09-10 12:18:02 +02:00
case 'v': verbosity++; break;
case 'h': help(1); exit(1);
2023-05-29 09:06:57 +02:00
default: exit(1);
2019-09-10 12:18:02 +02:00
}
}
#if DEBUG_LEVEL
/* mmmm, is it the good way ? */
printf("argc %d -> %d\n", argc, argc-optind);
for (foo=optind; foo<argc; foo++) {
printf(" %d %s\n", foo, argv[foo]);
}
#endif
if (2 != argc-optind) {
fprintf(stderr, "error: %s need two filenames\n", argv[0]);
2019-03-03 16:22:55 +01:00
exit(1);
}
2019-09-10 12:18:02 +02:00
if ( 0 != access(argv[optind], R_OK) ) { /* fimg is NOT readable */
fprintf(stderr, "%s: %s don't exist.\n", argv[0], argv[optind]);
2019-03-03 16:22:55 +01:00
exit(2);
}
foo = convertir_fimg_en_pnm(argv[optind], argv[optind+1], to_gray);
2019-03-03 16:22:55 +01:00
if (foo) fprintf(stderr, "conversion -> %d\n", foo);
return 0;
}
2019-07-03 18:51:42 +02:00
/* --------------------------------------------------------------------- */