/*
* Copyright (C) 2009 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef PINYINIME_ANDPY_INCLUDE_LPICACHE_H__
#define PINYINIME_ANDPY_INCLUDE_LPICACHE_H__
#include <stdlib.h>
#include "./searchutility.h"
#include "./spellingtrie.h"
namespace ime_pinyin {
// Used to cache LmaPsbItem list for half spelling ids.
class LpiCache {
private:
static LpiCache *instance_;
static const int kMaxLpiCachePerId = 15;
LmaPsbItem *lpi_cache_;
uint16 *lpi_cache_len_;
public:
LpiCache();
~LpiCache();
static LpiCache& get_instance();
// Test if the LPI list of the given splid has been cached.
// If splid is a full spelling id, it returns false, because we only cache
// list for half ids.
bool is_cached(uint16 splid);
// Put LPI list to cahce. If the length of the list, lpi_num, is longer than
// the cache buffer. the list will be truncated, and function returns the
// maximum length of the cache buffer.
// Note: splid must be a half id, and lpi_items must be not NULL. The
// caller of this function should guarantee this.
size_t put_cache(uint16 splid, LmaPsbItem lpi_items[], size_t lpi_num);
// Get the cached list for the given half id.
// Return the length of the cached buffer.
// Note: splid must be a half id, and lpi_items must be not NULL. The
// caller of this function should guarantee this.
size_t get_cache(uint16 splid, LmaPsbItem lpi_items[], size_t lpi_max);
};
} // namespace
#endif // PINYINIME_ANDPY_INCLUDE_LPICACHE_H__