Update contrib.
2 **********************************************************************
3 * Copyright (C) 2003, International Business Machines
4 * Corporation and others. All Rights Reserved.
5 **********************************************************************
8 #include "layout/LETypes.h"
10 #include "FontTableCache.h"
12 #define TABLE_CACHE_INIT 5
13 #define TABLE_CACHE_GROW 5
15 struct FontTableCacheEntry
21 FontTableCache::FontTableCache()
22 : fTableCacheCurr(0), fTableCacheSize(TABLE_CACHE_INIT)
24 fTableCache = LE_NEW_ARRAY(FontTableCacheEntry, fTableCacheSize);
26 if (fTableCache == NULL) {
31 for (int i = 0; i < fTableCacheSize; i += 1) {
32 fTableCache[i].tag = 0;
33 fTableCache[i].table = NULL;
37 FontTableCache::~FontTableCache()
39 for (int i = fTableCacheCurr - 1; i >= 0; i -= 1) {
40 LE_DELETE_ARRAY(fTableCache[i].table);
42 fTableCache[i].tag = 0;
43 fTableCache[i].table = NULL;
47 /* Nokia defect fix for memory leak - Jas: 23/06/2005 */
48 LE_DELETE_ARRAY(fTableCache);
51 const void *FontTableCache::find(LETag tableTag) const
53 for (int i = 0; i < fTableCacheCurr; i += 1) {
54 if (fTableCache[i].tag == tableTag) {
55 return fTableCache[i].table;
59 const void *table = readFontTable(tableTag);
62 ((FontTableCache *) this)->add(tableTag, table);
68 void FontTableCache::add(LETag tableTag, const void *table)
70 if (fTableCacheCurr >= fTableCacheSize) {
71 le_int32 newSize = fTableCacheSize + TABLE_CACHE_GROW;
73 FontTableCacheEntry *newTableCache =
74 (FontTableCacheEntry *) LE_GROW_ARRAY(fTableCache, newSize);
76 // could not grow the cache, so we won't cache the table.
79 fTableCache = newTableCache;
81 for (le_int32 i = fTableCacheSize; i < newSize; i += 1) {
82 fTableCache[i].tag = 0;
83 fTableCache[i].table = NULL;
86 fTableCacheSize = newSize;
89 fTableCache[fTableCacheCurr].tag = tableTag;
90 fTableCache[fTableCacheCurr].table = table;