/*
 * 		test des trucs
 */

#include  <stdio.h>
#include  <stdlib.h>
#include  <stdint.h>
#include  <unistd.h>
#include  <string.h>
#include  <glob.h>

#include  "../floatimg.h"
#include  "glitches.h"
#include  "sfx.h"
#include  "filterstack.h"
#include  "crapulator.h"
#include  "single.h"

/* ----------------------------------------------------------- */

int		verbosity;

#define		PNG	"out.png"
#define		W	800
#define		H	600
#define		LMAX	255.0
#define		TIMER	1

#define		STK	6

/* ----------------------------------------------------------- */

int essai_filterstack(char *fIname, char *fOname)
{
int		foo;
FloatImg	image;
double		debut, fin;

// filterstack_list(STK, __func__);

foo = fimg_create_from_dump(fIname, &image);
if (foo) {
	fprintf(stderr, "err %d create image\n", foo);
	exit(1);
	}

srand(getpid()); srand48(getpid());

debut = fimg_timer_set(TIMER);

foo = filterstack_run(STK, &image, 0);
if (foo) {
	fprintf(stderr, "filterstack run --> %d\n", foo);
	return foo;
	}

fin = fimg_timer_set(TIMER);

foo = fimg_export_picture(&image, fOname, 0);
if (foo) {
	fprintf(stderr, "erreur export %d\n", foo);
	}

fprintf(stderr, "elapsed %f\n", fin-debut);

fimg_destroy(&image);

return 0;
}
/* ----------------------------------------------------------- */
/*
 *		test-only function !

foo = essayer_single("capture/???42.fimg", "/tmp/x8/", STK);
fprintf(stderr, "essayer single -> %d\n", foo);


 */
int essayer_single(char *globpattern, char *destdir, int chain)
{
FloatImg	image = { 0 };
int		idx, foo;
glob_t		globbuf;
char		*fname;

#if DEBUG_LEVEL
fprintf(stderr, ">>> %s ( '%s' '%s' %d )\n", __func__,
			globpattern, destdir, chain);
#endif

filterstack_list(chain, "essai du single");

foo = single_init(0, destdir, chain, -1);
if (foo) {
	fprintf(stderr, "erreur %d single_init\n", foo);
	return foo;
	}
single_print_state("just after init", 0);

memset(&globbuf, 0, sizeof(glob_t));
foo = glob(globpattern, 0, NULL, &globbuf);
fprintf(stderr, "globbing '%s' -> %d, %d files found\n",
			globpattern, foo, (int)globbuf.gl_pathc);
if (0 == globbuf.gl_pathc) {
	fprintf(stderr, "%s : no file found, aborting\n", __func__);
	return -1;
	}

for (idx=0; idx<globbuf.gl_pathc; idx++) {

	fname = globbuf.gl_pathv[idx];		/* alias of filename */
	fprintf(stderr, "%s  %6d  %s\r", __func__, idx, fname);

	if (0==image.width && 0==image.height) {
		foo = fimg_create_from_dump(fname, &image);
		}
	else	{
		foo = fimg_load_from_dump(fname, &image);
		}
	if (foo) {
		fprintf(stderr, "get image -> %d\n", foo);
		return -1;
		}

	foo = filterstack_run(chain, &image, 0);
	if (foo) {
		fprintf(stderr, "%s: filterstack run --> %d\n",
				__func__,                 foo);
		return foo;
		}

	foo = single_push_picture(&image);
	if (foo) {
		fprintf(stderr, "erreur %d push picture\n", foo);
		return foo;
		}
	}

fprintf(stderr, "\n");

single_print_state("end of run :)", 0);

fimg_destroy(&image);

return 0;
}
/* ----------------------------------------------------------- */

int help(void)
{
puts("Yolo!");

puts("\t-F\tdefine:the:filter:chain");
puts("\t-g\tinput glob pattern");
puts("\t-i\tinfile.fimg");
puts("\t-L\tlist available filters");
puts("\t-o\toutfile.xxx");
puts("\t-O\t/output/directory");
puts("\t-s\tdo single test");

exit(0);
}
/* ----------------------------------------------------------- */
int experiment(void)
{
int		foo;
FloatImg	image, dest;

fprintf(stderr, "--------- EXPERIMENT ------------\n");

foo = fimg_create_from_dump("mire.fimg", &image);
if (foo) {
	fprintf(stderr, "%s: err %d on create_from_dump\n",
			__func__, foo);
	return -1;
	}

foo = fimg_clone(&image, &dest, 0);

foo = graylevel2popcolors(&image, &dest, 0);
fprintf(stderr, "POP COLOR- -> %d\n", foo);

fimg_export_picture(&dest, "foo.png", 0);

exit(0);		/* back to real world */
}
/* ----------------------------------------------------------- */

int main(int argc, char *argv[])
{
int		foo, opt;
int		do_xper = 0;
int		do_single = 0;
char		*filterchain = "0";
char		*infile = "mire.fimg";
char		*outfile = PNG;
char		*outdir = "/tmp/x8/";
char		*globstr = "capture/????7.fimg";

fprintf(stderr, "*** %s : compiled by tTh, %s %s\n", __FILE__,
			__DATE__, __TIME__);
fimg_print_version(2);

while ((opt = getopt(argc, argv, "hF:g:i:Lo:O:svx")) != -1) {
	switch(opt) {
		case 'h':	help();			break;
		case 'F':	filterchain = optarg;	break;
		case 'g':	globstr = optarg;	break;
		case 'i':	infile = optarg;	break;
		case 'L':
			list_crapulors("available filters");
			exit(0);
		case 'o':	outfile = optarg;	break;
		case 'O':	outdir  = optarg;	break;
		case 's':	do_single = 1;		break;
		case 'v':	verbosity++;		break;
		case 'x':	do_xper = 1;		break;
		default:	exit(1);
		}
	}

#if DEBUG_LEVEL
fprintf(stderr, "%s : argc = %d, optind = %d\n", argv[0], argc, optind);
#endif

foo = parse_filter_chain(STK, filterchain);
if (foo) {
	fprintf(stderr, "err %d in parse_filter_chain\n", foo);
	exit(1);
	}

if (do_xper) {
	experiment();
	return 0;
	}
if (do_single) {
	fprintf(stderr, "Globbing '%s'\n", globstr);
	essayer_single(globstr, outdir, STK);
	return 0;
	}

foo = essai_filterstack(infile, outfile);
if (foo) {
	fprintf(stderr, "err %d in essai_filterstack\n", foo);
	exit(1);
	}

return 0;
}

/* ----------------------------------------------------------- */