mirror of
https://github.com/webmproject/libwebp.git
synced 2024-11-20 12:28:26 +01:00
69 lines
2.2 KiB
C
69 lines
2.2 KiB
C
|
// Copyright 2012 Google Inc. All Rights Reserved.
|
||
|
//
|
||
|
// This code is licensed under the same terms as WebM:
|
||
|
// Software License Agreement: http://www.webmproject.org/license/software/
|
||
|
// Additional IP Rights Grant: http://www.webmproject.org/license/additional/
|
||
|
// -----------------------------------------------------------------------------
|
||
|
//
|
||
|
// Color Cache for WebP Lossless
|
||
|
//
|
||
|
// Authors: jyrki@google.com (Jyrki Alakuijala)
|
||
|
// urvang@google.com (Urvang Joshi)
|
||
|
|
||
|
#ifndef WEBP_UTILS_COLOR_CACHE_H_
|
||
|
#define WEBP_UTILS_COLOR_CACHE_H_
|
||
|
|
||
|
#include "../webp/types.h"
|
||
|
|
||
|
#if defined(__cplusplus) || defined(c_plusplus)
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
// Main color cache struct.
|
||
|
typedef struct {
|
||
|
uint32_t *colors_; // color entries
|
||
|
int hash_shift_; // Hash shift: 32 - hash_bits.
|
||
|
} VP8LColorCache;
|
||
|
|
||
|
static const uint32_t kHashMul = 0x1e35a7bd;
|
||
|
|
||
|
static WEBP_INLINE uint32_t VP8LColorCacheLookup(
|
||
|
const VP8LColorCache* const cc, uint32_t key) {
|
||
|
assert(key <= (~0U >> cc->hash_shift_));
|
||
|
return cc->colors_[key];
|
||
|
}
|
||
|
|
||
|
static WEBP_INLINE void VP8LColorCacheInsert(const VP8LColorCache* const cc,
|
||
|
uint32_t argb) {
|
||
|
const uint32_t key = (kHashMul * argb) >> cc->hash_shift_;
|
||
|
cc->colors_[key] = argb;
|
||
|
}
|
||
|
|
||
|
static WEBP_INLINE int VP8LColorCacheGetIndex(const VP8LColorCache* const cc,
|
||
|
uint32_t argb) {
|
||
|
return (kHashMul * argb) >> cc->hash_shift_;
|
||
|
}
|
||
|
|
||
|
static WEBP_INLINE int VP8LColorCacheContains(const VP8LColorCache* const cc,
|
||
|
uint32_t argb) {
|
||
|
const uint32_t key = (kHashMul * argb) >> cc->hash_shift_;
|
||
|
return cc->colors_[key] == argb;
|
||
|
}
|
||
|
|
||
|
//------------------------------------------------------------------------------
|
||
|
|
||
|
// Initializes the color cache with 'hash_bits' bits for the keys.
|
||
|
// Returns false in case of memory error.
|
||
|
int VP8LColorCacheInit(VP8LColorCache* const color_cache, int hash_bits);
|
||
|
|
||
|
// Delete the color cache.
|
||
|
void VP8LColorCacheDelete(VP8LColorCache* const color_cache);
|
||
|
|
||
|
//------------------------------------------------------------------------------
|
||
|
|
||
|
#if defined(__cplusplus) || defined(c_plusplus)
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif // WEBP_UTILS_COLOR_CACHE_H_
|