-
Notifications
You must be signed in to change notification settings - Fork 123
/
Copy pathjpeg-hash.c
73 lines (61 loc) · 1.73 KB
/
jpeg-hash.c
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
/*
Hash a single JPEG file. The hash is based on tracking gradients
between pixels in the image. The larger the hash size, the less
likely you are to get collisions, but the more time it takes to
calculate.
*/
#include <getopt.h>
#include <stdio.h>
#include <stdlib.h>
#include "src/hash.h"
#include "src/util.h"
int size = 16;
void usage(void) {
printf("usage: %s [options] image.jpg\n\n", progname);
printf("options:\n\n");
printf(" -V, --version output program version\n");
printf(" -h, --help output program help\n");
printf(" -s, --size [arg] set fast comparison image hash size\n");
}
int main (int argc, char **argv) {
unsigned char *hash;
const char *optstring = "Vhs:";
static const struct option opts[] = {
{ "version", no_argument, 0, 'V' },
{ "help", no_argument, 0, 'h' },
{ "size", required_argument, 0, 's' },
{ 0, 0, 0, 0 }
};
int opt, longind = 0;
progname = "jpeg-hash";
while ((opt = getopt_long(argc, argv, optstring, opts, &longind)) != -1) {
switch (opt) {
case 'V':
version();
return 0;
case 'h':
usage();
return 0;
case 's':
size = atoi(optarg);
break;
};
}
if (argc - optind != 1) {
usage();
return 255;
}
// Generate the image hash
if (jpegHash(argv[optind], &hash, size)) {
error("error hashing image!");
return 1;
}
// Print out the hash a string of 1s and 0s
for (int x = 0; x < size * size; x++) {
printf("%c", hash[x] ? '1' : '0');
}
printf("\n");
// Cleanup
free(hash);
return 0;
}