1
// Copyright 2012 Google Inc. All Rights Reserved.
3
// Use of this source code is governed by a BSD-style license
4
// that can be found in the COPYING file in the root of the source
5
// tree. An additional intellectual property rights grant can be found
6
// in the file PATENTS. All contributing project authors may
7
// be found in the AUTHORS file in the root of the source tree.
8
// -----------------------------------------------------------------------------
10
// Color Cache for WebP Lossless
12
// Authors: Jyrki Alakuijala (jyrki@google.com)
13
// Urvang Joshi (urvang@google.com)
15
#ifndef WEBP_UTILS_COLOR_CACHE_H_
16
#define WEBP_UTILS_COLOR_CACHE_H_
18
#include "../webp/types.h"
24
// Main color cache struct.
26
uint32_t *colors_; // color entries
27
int hash_shift_; // Hash shift: 32 - hash_bits.
30
static const uint32_t kHashMul = 0x1e35a7bd;
32
static WEBP_INLINE uint32_t VP8LColorCacheLookup(
33
const VP8LColorCache* const cc, uint32_t key) {
34
assert(key <= (~0U >> cc->hash_shift_));
35
return cc->colors_[key];
38
static WEBP_INLINE void VP8LColorCacheInsert(const VP8LColorCache* const cc,
40
const uint32_t key = (kHashMul * argb) >> cc->hash_shift_;
41
cc->colors_[key] = argb;
44
static WEBP_INLINE int VP8LColorCacheGetIndex(const VP8LColorCache* const cc,
46
return (kHashMul * argb) >> cc->hash_shift_;
49
static WEBP_INLINE int VP8LColorCacheContains(const VP8LColorCache* const cc,
51
const uint32_t key = (kHashMul * argb) >> cc->hash_shift_;
52
return cc->colors_[key] == argb;
55
//------------------------------------------------------------------------------
57
// Initializes the color cache with 'hash_bits' bits for the keys.
58
// Returns false in case of memory error.
59
int VP8LColorCacheInit(VP8LColorCache* const color_cache, int hash_bits);
61
// Delete the memory associated to color cache.
62
void VP8LColorCacheClear(VP8LColorCache* const color_cache);
64
//------------------------------------------------------------------------------
70
#endif // WEBP_UTILS_COLOR_CACHE_H_