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
|
#include "mupdf/pdf.h"
static int
pdf_make_hash_key(fz_store_hash *hash, void *key_)
{
pdf_obj *key = (pdf_obj *)key_;
if (!pdf_is_indirect(key))
return 0;
hash->u.i.i0 = pdf_to_num(key);
hash->u.i.i1 = pdf_to_gen(key);
hash->u.i.ptr = pdf_get_indirect_document(key);
return 1;
}
static void *
pdf_keep_key(fz_context *ctx, void *key)
{
return (void *)pdf_keep_obj((pdf_obj *)key);
}
static void
pdf_drop_key(fz_context *ctx, void *key)
{
pdf_drop_obj((pdf_obj *)key);
}
static int
pdf_cmp_key(void *k0, void *k1)
{
return pdf_objcmp((pdf_obj *)k0, (pdf_obj *)k1);
}
#ifndef NDEBUG
static void
pdf_debug_key(FILE *out, void *key_)
{
pdf_obj *key = (pdf_obj *)key_;
if (pdf_is_indirect(key))
{
fprintf(out, "(%d %d R) ", pdf_to_num(key), pdf_to_gen(key));
} else
pdf_fprint_obj(out, key, 0);
}
#endif
static fz_store_type pdf_obj_store_type =
{
pdf_make_hash_key,
pdf_keep_key,
pdf_drop_key,
pdf_cmp_key,
#ifndef NDEBUG
pdf_debug_key
#endif
};
void
pdf_store_item(fz_context *ctx, pdf_obj *key, void *val, unsigned int itemsize)
{
void *existing;
existing = fz_store_item(ctx, key, val, itemsize, &pdf_obj_store_type);
assert(existing == NULL);
}
void *
pdf_find_item(fz_context *ctx, fz_store_free_fn *free, pdf_obj *key)
{
return fz_find_item(ctx, free, key, &pdf_obj_store_type);
}
void
pdf_remove_item(fz_context *ctx, fz_store_free_fn *free, pdf_obj *key)
{
fz_remove_item(ctx, free, key, &pdf_obj_store_type);
}
|