~ubuntu-branches/ubuntu/karmic/mjpegtools/karmic

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*
 *  Copyright (C) 2001 Kawamata/Hitoshi <hitoshi.kawamata@nifty.ne.jp>
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */

#include <config.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include "yuvfilters.h"

#ifdef FILTER
#  define MODULE FILTER
#else
# ifdef READER
#  define MODULE READER
# else
#  define MODULE WRITER
# endif
#endif
#ifndef READER
#define READER yuvstdin
#endif
#ifndef WRITER
#define WRITER yuvstdout
#endif

DECLARE_YFTASKCLASS(READER);
DECLARE_YFTASKCLASS(WRITER);
#ifdef FILTER
DECLARE_YFTASKCLASS(FILTER);
#endif

int verbose = 1;

static void
usage(char **argv)
{
  char buf[1024];

  sprintf(buf, "Usage: %s %s", argv[0], (*MODULE.usage)());
  WERRORL(buf);
}

int
main(int argc, char **argv)
{
  YfTaskCore_t *h, *hreader;
  int ret;
  char *p;

  if (1 < argc && (!strcmp(argv[1], "-?") ||
		   !strcmp(argv[1], "-h") ||
		   !strcmp(argv[1], "--help"))) {
    usage(argv);
    return 0;
  }
  if ((p = getenv("MJPEG_VERBOSITY")))
    verbose = atoi(p);

  ret = 1;
#ifndef FILTER
  if (!(hreader = YfAddNewTask(&READER, argc, argv, NULL)))
    goto RETURN;
#else
  if (!(hreader = YfAddNewTask(&READER, argc, argv, NULL)))
    goto RETURN;
  if (!YfAddNewTask(&FILTER, argc, argv, hreader))
    goto FINI;
#endif
  if (!YfAddNewTask(&WRITER, argc, argv, hreader))
    goto FINI;

  ret = (*READER.frame)(hreader, NULL, NULL);
  if (ret == Y4M_ERR_EOF)
    ret = Y4M_OK;
  if (ret != Y4M_OK)
    WERRORL(y4m_strerr(ret));

 FINI:
  for (h = hreader; h; h = hreader) {
    hreader = h->handle_outgoing;
    (*h->method->fini)(h);
  }
 RETURN:
  return ret;
}