2007-04-09 04:02:40 +02:00
|
|
|
/*
|
2008-12-28 09:09:59 +01:00
|
|
|
* Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
|
|
|
|
*
|
|
|
|
* This file is part of libass.
|
|
|
|
*
|
|
|
|
* libass is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* libass is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with libass; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
2007-04-09 04:02:40 +02:00
|
|
|
|
2008-03-21 06:32:23 +01:00
|
|
|
#ifndef LIBASS_CACHE_H
|
|
|
|
#define LIBASS_CACHE_H
|
|
|
|
|
|
|
|
#include "ass.h"
|
|
|
|
#include "ass_font.h"
|
|
|
|
#include "ass_bitmap.h"
|
2007-04-09 04:02:40 +02:00
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
typedef void (*HashmapItemDtor) (void *key, size_t key_size,
|
|
|
|
void *value, size_t value_size);
|
|
|
|
typedef int (*HashmapKeyCompare) (void *key1, void *key2,
|
|
|
|
size_t key_size);
|
|
|
|
typedef unsigned (*HashmapHash) (void *key, size_t key_size);
|
2009-07-11 17:48:50 +02:00
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
typedef struct hashmap_item {
|
2009-07-11 17:48:50 +02:00
|
|
|
void *key;
|
|
|
|
void *value;
|
2009-09-06 00:30:15 +02:00
|
|
|
struct hashmap_item *next;
|
|
|
|
} HashmapItem;
|
|
|
|
typedef HashmapItem *hashmap_item_p;
|
2009-07-11 17:48:50 +02:00
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
typedef struct {
|
2009-07-11 17:48:50 +02:00
|
|
|
int nbuckets;
|
|
|
|
size_t key_size, value_size;
|
|
|
|
hashmap_item_p *root;
|
2009-09-06 00:30:15 +02:00
|
|
|
HashmapItemDtor item_dtor; // a destructor for hashmap key/value pairs
|
|
|
|
HashmapKeyCompare key_compare;
|
|
|
|
HashmapHash hash;
|
|
|
|
size_t cache_size;
|
2009-07-11 17:48:50 +02:00
|
|
|
// stats
|
|
|
|
int hit_count;
|
|
|
|
int miss_count;
|
|
|
|
int count;
|
2009-09-06 00:30:15 +02:00
|
|
|
ASS_Library *library;
|
|
|
|
} Hashmap;
|
|
|
|
|
|
|
|
Hashmap *hashmap_init(ASS_Library *library, size_t key_size,
|
|
|
|
size_t value_size, int nbuckets,
|
|
|
|
HashmapItemDtor item_dtor,
|
|
|
|
HashmapKeyCompare key_compare,
|
|
|
|
HashmapHash hash);
|
|
|
|
void hashmap_done(Hashmap *map);
|
|
|
|
void *hashmap_insert(Hashmap *map, void *key, void *value);
|
|
|
|
void *hashmap_find(Hashmap *map, void *key);
|
|
|
|
|
|
|
|
Hashmap *ass_font_cache_init(ASS_Library *library);
|
|
|
|
ASS_Font *ass_font_cache_find(Hashmap *, ASS_FontDesc *desc);
|
|
|
|
void *ass_font_cache_add(Hashmap *, ASS_Font *font);
|
|
|
|
void ass_font_cache_done(Hashmap *);
|
2007-04-09 04:02:40 +02:00
|
|
|
|
2009-05-04 08:48:21 +02:00
|
|
|
// Create definitions for bitmap_hash_key and glyph_hash_key
|
|
|
|
#define CREATE_STRUCT_DEFINITIONS
|
2009-07-14 00:43:25 +02:00
|
|
|
#include "ass_cache_template.h"
|
2007-04-09 04:02:40 +02:00
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
typedef struct {
|
|
|
|
Bitmap *bm; // the actual bitmaps
|
|
|
|
Bitmap *bm_o;
|
|
|
|
Bitmap *bm_s;
|
|
|
|
} BitmapHashValue;
|
2008-01-17 17:50:19 +01:00
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
Hashmap *ass_bitmap_cache_init(ASS_Library *library);
|
|
|
|
void *cache_add_bitmap(Hashmap *, BitmapHashKey *key,
|
|
|
|
BitmapHashValue *val);
|
|
|
|
BitmapHashValue *cache_find_bitmap(Hashmap *bitmap_cache,
|
|
|
|
BitmapHashKey *key);
|
|
|
|
Hashmap *ass_bitmap_cache_reset(Hashmap *bitmap_cache);
|
|
|
|
void ass_bitmap_cache_done(Hashmap *bitmap_cache);
|
2009-03-12 04:46:44 +01:00
|
|
|
|
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
typedef struct {
|
2009-07-11 17:48:50 +02:00
|
|
|
unsigned char *a;
|
|
|
|
unsigned char *b;
|
2009-09-06 00:30:15 +02:00
|
|
|
} CompositeHashValue;
|
2009-03-12 04:46:44 +01:00
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
Hashmap *ass_composite_cache_init(ASS_Library *library);
|
|
|
|
void *cache_add_composite(Hashmap *, CompositeHashKey *key,
|
|
|
|
CompositeHashValue *val);
|
|
|
|
CompositeHashValue *cache_find_composite(Hashmap *composite_cache,
|
|
|
|
CompositeHashKey *key);
|
|
|
|
Hashmap *ass_composite_cache_reset(Hashmap *composite_cache);
|
|
|
|
void ass_composite_cache_done(Hashmap *composite_cache);
|
2009-03-12 04:46:44 +01:00
|
|
|
|
|
|
|
|
2009-09-06 00:30:15 +02:00
|
|
|
typedef struct {
|
2009-07-11 17:48:50 +02:00
|
|
|
FT_Glyph glyph;
|
|
|
|
FT_Glyph outline_glyph;
|
|
|
|
FT_BBox bbox_scaled; // bbox after scaling, but before rotation
|
|
|
|
FT_Vector advance; // 26.6, advance distance to the next bitmap in line
|
|
|
|
int asc, desc; // ascender/descender of a drawing
|
2009-09-06 00:30:15 +02:00
|
|
|
} GlyphHashValue;
|
|
|
|
|
|
|
|
Hashmap *ass_glyph_cache_init(ASS_Library *library);
|
|
|
|
void *cache_add_glyph(Hashmap *, GlyphHashKey *key,
|
|
|
|
GlyphHashValue *val);
|
|
|
|
GlyphHashValue *cache_find_glyph(Hashmap *glyph_cache,
|
|
|
|
GlyphHashKey *key);
|
|
|
|
Hashmap *ass_glyph_cache_reset(Hashmap *glyph_cache);
|
|
|
|
void ass_glyph_cache_done(Hashmap *glyph_cache);
|
2009-07-11 17:48:50 +02:00
|
|
|
|
|
|
|
#endif /* LIBASS_CACHE_H */
|