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
|
#include "mupdf/pdf.h"
static int
pdf_make_hash_key(fz_context *ctx, fz_store_hash *hash, void *key_)
{
pdf_obj *key = (pdf_obj *)key_;
if (!pdf_is_indirect(ctx, key))
return 0;
hash->u.pi.i = pdf_to_num(ctx, key);
hash->u.pi.ptr = pdf_get_indirect_document(ctx, key);
return 1;
}
static void *
pdf_keep_key(fz_context *ctx, void *key)
{
return (void *)pdf_keep_obj(ctx, (pdf_obj *)key);
}
static void
pdf_drop_key(fz_context *ctx, void *key)
{
pdf_drop_obj(ctx, (pdf_obj *)key);
}
static int
pdf_cmp_key(fz_context *ctx, void *k0, void *k1)
{
return pdf_objcmp(ctx, (pdf_obj *)k0, (pdf_obj *)k1);
}
static void
pdf_print_key(fz_context *ctx, fz_output *out, void *key_)
{
pdf_obj *key = (pdf_obj *)key_;
if (pdf_is_indirect(ctx, key))
fz_printf(ctx, out, "(%d 0 R) ", pdf_to_num(ctx, key));
else
pdf_print_obj(ctx, out, key, 0);
}
static fz_store_type pdf_obj_store_type =
{
pdf_make_hash_key,
pdf_keep_key,
pdf_drop_key,
pdf_cmp_key,
pdf_print_key
};
void
pdf_store_item(fz_context *ctx, pdf_obj *key, void *val, size_t itemsize)
{
void *existing;
existing = fz_store_item(ctx, key, val, itemsize, &pdf_obj_store_type);
assert(existing == NULL);
(void)existing; /* Silence warning in release builds */
}
void *
pdf_find_item(fz_context *ctx, fz_store_drop_fn *drop, pdf_obj *key)
{
return fz_find_item(ctx, drop, key, &pdf_obj_store_type);
}
void
pdf_remove_item(fz_context *ctx, fz_store_drop_fn *drop, pdf_obj *key)
{
fz_remove_item(ctx, drop, key, &pdf_obj_store_type);
}
|