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);
25 RHeap* hhh = (RHeap*)Dll::Tls();
26 fTableCache = (FontTableCacheEntry *)hhh->Alloc(sizeof(FontTableCacheEntry)*(fTableCacheSize));
28 if (fTableCache == NULL) {
33 for (int i = 0; i < fTableCacheSize; i += 1) {
34 fTableCache[i].tag = 0;
35 fTableCache[i].table = NULL;
39 FontTableCache::~FontTableCache()
41 for (int i = fTableCacheCurr - 1; i >= 0; i -= 1) {
42 LE_DELETE_ARRAY(fTableCache[i].table);
44 fTableCache[i].tag = 0;
45 fTableCache[i].table = NULL;
49 RHeap* hhh = (RHeap*)Dll::Tls();
50 hhh->Free(fTableCache);
51 // delete fTableCache; //Jas 23/06/2005
54 const void *FontTableCache::find(LETag tableTag) const
56 for (int i = 0; i < fTableCacheCurr; i += 1) {
57 if (fTableCache[i].tag == tableTag) {
58 return fTableCache[i].table;
62 const void *table = readFontTable(tableTag);
64 ((FontTableCache *) this)->add(tableTag, table);
69 void FontTableCache::add(LETag tableTag, const void *table)
71 if (fTableCacheCurr >= fTableCacheSize) {
72 le_int32 newSize = fTableCacheSize + TABLE_CACHE_GROW;
74 fTableCache = (FontTableCacheEntry *) LE_GROW_ARRAY(fTableCache, newSize);
76 for (le_int32 i = fTableCacheSize; i < newSize; i += 1) {
77 fTableCache[i].tag = 0;
78 fTableCache[i].table = NULL;
81 fTableCacheSize = newSize;
84 fTableCache[fTableCacheCurr].tag = tableTag;
85 fTableCache[fTableCacheCurr].table = table;