File: cachemanager.h

package info (click to toggle)
umbrello 4%3A25.12.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 46,212 kB
  • sloc: cpp: 144,235; php: 2,405; sh: 855; xml: 354; cs: 309; java: 91; python: 68; makefile: 11; sql: 7
file content (107 lines) | stat: -rw-r--r-- 2,264 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107

/*
    SPDX-FileCopyrightText: 2006 David Nolden <david.nolden.kdevelop@art-master.de>
    SPDX-License-Identifier: GPL-2.0-or-later
*/

#ifndef CACHEMANAGER_H
#define CACHEMANAGER_H
#include <cstdlib>
#include <set>
#include <limits>

class CacheManager;

#ifndef inline
#define inline __inline
#endif

class CacheNode
{
    typedef CacheManager Manager;
public:
    explicit CacheNode(Manager* manager);

    virtual ~CacheNode();

    void access() const;

    inline unsigned int value() const
    {
        return m_value;
    }

    inline void setValue(const unsigned int v) const
    {
        m_value = v;
    }

    inline void addValue(const unsigned int diff) const
    {
        m_value += diff;
    }

private:
    Manager* m_manager;
    mutable unsigned int m_value; //This value stands for the priority of the node(higher is better)
};

class CacheNodeCompare
{
public:
    bool operator() (const CacheNode* lhs, const CacheNode* rhs) const
    {
        if (lhs->value() != rhs->value())
            return lhs->value() < rhs->value();
        else
            return lhs < rhs; //To be able to identify nodes precisely
    }
};


class CacheManager
{
    typedef std::set< const CacheNode*, CacheNodeCompare > SetType;
public:
    CacheManager(int maxNodes = 1000) : m_currentFrame(1), m_maxNodes(maxNodes), m_currentMax(1)
    {
    };
    virtual ~CacheManager() {}

    inline int currentFrame() const
    {
        return m_currentFrame;
    }

    void access(const CacheNode* node);

    ///Can be used from outside to set the maximum count of nodes to keep.
    void setMaxNodes (int maxNodes);

    void increaseFrame();

    ///Can be used on a regular basis(time-triggered) to save memory: Removes half of all triggered
    void removeLowerHalf();

    virtual void saveMemory();

    int currentMax() const
    {
        return m_currentMax;
    }

    ///This triggered function should erase the given node.
    virtual void erase(const CacheNode* node) = 0;
private:
    void restart(unsigned int normalizeby);
    friend class CacheNode;
    void remove(const CacheNode* node);
    void add(const CacheNode* node);
    int m_currentFrame;
    unsigned int m_maxNodes;
    unsigned int m_currentMax;
    SetType m_set;
};


#endif