annotate liba52/compare.c @ 25778:15c5da485a77

Remove a broken and useless hack to avoid a memcpy
author reimar
date Sat, 19 Jan 2008 16:49:01 +0000
parents fd4b42040150
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25562
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
1 /*
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
2 * Simple file compare program, it finds the number of rounding errors
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
3 * and dies if there is too large an error ( ABS(a-b)>1 ).
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
4 *
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
5 * copyright (c) 2001 Michael Niedermayer
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
6 *
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
7 * This program is free software; you can redistribute it and/or modify
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
8 * it under the terms of the GNU General Public License as published by
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
9 * the Free Software Foundation; either version 2 of the License, or
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
10 * (at your option) any later version.
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
11 *
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
12 * This program is distributed in the hope that it will be useful,
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
15 * GNU General Public License for more details.
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
16 *
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
17 * You should have received a copy of the GNU General Public License
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
18 * along with this program; if not, write to the Free Software
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
fd4b42040150 Add proper license header.
diego
parents: 25475
diff changeset
20 */
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
21
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
22 #include <stdio.h>
25475
92162fd825d3 Add missing #include, fixes
diego
parents: 25474
diff changeset
23 #include <stdlib.h>
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
24
25473
6ade61b852eb cosmetics: spelling fixes
diego
parents: 3524
diff changeset
25 // FIXME: No checks but it is just for debugging so who cares ;)
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
26
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
27 int main(int argc, char **argv)
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
28 {
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
29 FILE *f0, *f1;
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
30 int dif=0;
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
31
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
32 if(argc!=3)
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
33 {
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
34 printf("compare <file1> <file2>\n");
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
35 exit(2);
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
36 }
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
37
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
38 f0= fopen(argv[1], "rb");
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
39 f1= fopen(argv[2], "rb");
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
40
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
41 for(;;)
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
42 {
3524
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
43 short c0;
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
44 short c1;
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
45 int d;
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
46
3524
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
47 int e0= fread(&c0, 2, 1, f0);
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
48 int e1= fread(&c1, 2, 1, f1);
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
49
3524
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
50 d=c0-c1;
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
51 if(e0==0 && e1==0) break;
aed9850ca011 oops, 8bit instead of 16
michael
parents: 3510
diff changeset
52 if(e0==0 || e1==0)
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
53 {
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
54 printf("FATAL error, files have different size!\n");
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
55 exit(1);
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
56 }
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
57
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
58 if(d<0) d=-d; // ABS
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
59 if(d>1)
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
60 {
25473
6ade61b852eb cosmetics: spelling fixes
diego
parents: 3524
diff changeset
61 printf("FATAL error, too large a difference found (%d)!\n", d);
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
62 exit(1);
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
63 }
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
64
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
65 if(d) dif++;
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
66 }
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
67
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
68 fclose(f0);
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
69 fclose(f1);
25474
39031de3757e cosmetics: Remove trailing whitespace.
diego
parents: 25473
diff changeset
70
3510
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
71 printf("%d (+/-1)differences found\n", dif);
0e5829f1fb75 gcc -O? thinks a*0.0 != 0.0 so we need a better cmp
michael
parents:
diff changeset
72 exit(0);
25473
6ade61b852eb cosmetics: spelling fixes
diego
parents: 3524
diff changeset
73 }
6ade61b852eb cosmetics: spelling fixes
diego
parents: 3524
diff changeset
74