cache: unified bitmap cache
[libass.git] / libass / ass_cache.h
blob077e081c5e7f4550223ffb95bda41b27a3018024
1 /*
2 * Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
3 * Copyright (C) 2011 Grigori Goronzy <greg@chown.ath.cx>
5 * This file is part of libass.
7 * Permission to use, copy, modify, and distribute this software for any
8 * purpose with or without fee is hereby granted, provided that the above
9 * copyright notice and this permission notice appear in all copies.
11 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
20 #ifndef LIBASS_CACHE_H
21 #define LIBASS_CACHE_H
23 #include "ass.h"
24 #include "ass_font.h"
25 #include "ass_bitmap.h"
27 typedef struct cache Cache;
29 // cache values
31 typedef struct {
32 Bitmap *bm; // the actual bitmaps
33 Bitmap *bm_o;
34 Bitmap *bm_s;
35 } BitmapHashValue;
37 typedef struct {
38 unsigned char *a;
39 unsigned char *b;
40 } CompositeHashValue;
42 typedef struct {
43 FT_Library lib;
44 FT_Outline *outline;
45 FT_Outline *border;
46 FT_BBox bbox_scaled; // bbox after scaling, but before rotation
47 FT_Vector advance; // 26.6, advance distance to the next outline in line
48 int asc, desc; // ascender/descender
49 } OutlineHashValue;
51 // Create definitions for bitmap, outline and composite hash keys
52 #define CREATE_STRUCT_DEFINITIONS
53 #include "ass_cache_template.h"
55 // Type-specific function pointers
56 typedef unsigned(*HashFunction)(void *key, size_t key_size);
57 typedef size_t(*ItemSize)(void *value, size_t value_size);
58 typedef unsigned(*HashCompare)(void *a, void *b, size_t key_size);
59 typedef void(*CacheItemDestructor)(void *key, void *value);
61 // cache hash keys
63 typedef struct outline_hash_key {
64 enum {
65 OUTLINE_GLYPH,
66 OUTLINE_DRAWING,
67 } type;
68 union {
69 GlyphHashKey glyph;
70 DrawingHashKey drawing;
71 } u;
72 } OutlineHashKey;
74 typedef struct bitmap_hash_key {
75 enum {
76 BITMAP_OUTLINE,
77 BITMAP_CLIP,
78 } type;
79 union {
80 OutlineBitmapHashKey outline;
81 ClipMaskHashKey clip;
82 } u;
83 } BitmapHashKey;
85 Cache *ass_cache_create(HashFunction hash_func, HashCompare compare_func,
86 CacheItemDestructor destruct_func, ItemSize size_func,
87 size_t key_size, size_t value_size);
88 void *ass_cache_put(Cache *cache, void *key, void *value);
89 void *ass_cache_get(Cache *cache, void *key);
90 int ass_cache_empty(Cache *cache, size_t max_size);
91 void ass_cache_stats(Cache *cache, size_t *size, unsigned *hits,
92 unsigned *misses, unsigned *count);
93 void ass_cache_done(Cache *cache);
94 Cache *ass_font_cache_create(void);
95 Cache *ass_outline_cache_create(void);
96 Cache *ass_bitmap_cache_create(void);
97 Cache *ass_composite_cache_create(void);
99 #endif /* LIBASS_CACHE_H */