]> granicus.if.org Git - libass/blob - libass/ass_cache.h
Introduce bitmap runs
[libass] / libass / ass_cache.h
1 /*
2  * Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
3  * Copyright (C) 2011 Grigori Goronzy <greg@chown.ath.cx>
4  *
5  * This file is part of libass.
6  *
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.
10  *
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.
18  */
19
20 #ifndef LIBASS_CACHE_H
21 #define LIBASS_CACHE_H
22
23 #include "ass.h"
24 #include "ass_font.h"
25 #include "ass_bitmap.h"
26
27 typedef struct cache Cache;
28
29 // cache values
30
31 typedef struct {
32     Bitmap *bm;               // the actual bitmaps
33     Bitmap *bm_o;
34     Bitmap *bm_s;
35 } BitmapHashValue;
36
37 typedef struct {
38     unsigned char *a;
39     unsigned char *b;
40 } CompositeHashValue;
41
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;
50
51 // Create definitions for bitmap, outline and composite hash keys
52 #define CREATE_STRUCT_DEFINITIONS
53 #include "ass_cache_template.h"
54
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);
60
61 // cache hash keys
62
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;
73
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;
84
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);
98
99 #endif                          /* LIBASS_CACHE_H */