1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
22 #include <sal/config.h>
29 #include <sal/types.h>
35 enum { size
= 256, ignore
= 0xFFFF };
39 template< typename T
> class Cache
{
41 typedef sal_uInt16 IdxType
;
43 explicit Cache(std::size_t size
):
46 assert(size
< cache::ignore
);
49 IdxType
add( const T
& rContent
, bool* pbFound
) {
50 assert( pbFound
!= nullptr);
55 // try to insert into the map
56 list_
.push_front( rContent
); // create a temp entry
57 auto const [it
, inserted
] = map_
.emplace( list_
.begin(), 0 );
60 if( !inserted
) { // insertion not needed => found the entry
61 list_
.pop_front(); // remove the temp entry
62 list_
.splice( list_
.begin(), list_
, it
->first
); // the found entry is moved to front
66 // test insertion successful => it was new so we keep it
67 IdxType n
= static_cast<IdxType
>( map_
.size() - 1);
68 if( n
>= size_
) { // cache full => replace the LRU entry
69 // find the least recently used element in the map
70 typename
LruItMap::iterator lru
= map_
.find( --list_
.end());
72 map_
.erase( lru
); // remove it from the map
73 list_
.pop_back(); // remove from the list
80 Cache(const Cache
&) = delete;
81 Cache
& operator=(const Cache
&) = delete;
83 typedef std::list
<T
> LruList
; // last recently used list
84 typedef typename
LruList::iterator LruListIt
;
85 struct CmpT
{ bool operator()( const LruListIt
& rA
, const LruListIt
& rB
) const { return (*rA
<*rB
);}};
86 typedef std::map
< LruListIt
, IdxType
, CmpT
> LruItMap
; // a map into a LruList
95 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */