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
|
#include <getopt.h>
#include "dcp.h"
using namespace std;
using namespace libdcp;
static void
help (string n)
{
cerr << "Syntax: " << n << " [OPTION] <DCP> <DCP>\n"
<< " -v, --version show DVD-o-matic version\n"
<< " -h, --help show this help\n"
<< "\n"
<< "The <DCP>s are the DCP directories to compare.\n";
}
int
main (int argc, char* argv[])
{
int option_index = 0;
while (1) {
static struct option long_options[] = {
{ "version", no_argument, 0, 'v'},
{ "help", no_argument, 0, 'h'},
{ 0, 0, 0, 0 }
};
int c = getopt_long (argc, argv, "vh", long_options, &option_index);
if (c == -1) {
break;
}
switch (c) {
case 'v':
cout << "dcpdiff version " << LIBDCP_VERSION << "\n";
exit (EXIT_SUCCESS);
case 'h':
help (argv[0]);
exit (EXIT_SUCCESS);
}
}
if (argc <= optind || argc > (optind + 2)) {
help (argv[0]);
exit (EXIT_FAILURE);
}
DCP a (argv[optind]);
DCP b (argv[optind + 1]);
list<string> notes = a.equals (b, EqualityFlags (LIBDCP_METADATA | MXF_BITWISE));
if (notes.empty ()) {
cout << "DCPs identical\n";
exit (EXIT_SUCCESS);
}
for (list<string>::iterator i = notes.begin(); i != notes.end(); ++i) {
cout << " " << *i << "\n";
}
exit (EXIT_FAILURE);
}
|