File: projectitemquickopen.h

package info (click to toggle)
kdevelop 4%3A25.04.0-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 73,508 kB
  • sloc: cpp: 291,803; python: 4,322; javascript: 3,518; sh: 1,316; ansic: 703; xml: 414; php: 95; lisp: 66; makefile: 31; sed: 12
file content (112 lines) | stat: -rw-r--r-- 2,747 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
108
109
110
111
112
/*
    SPDX-FileCopyrightText: 2007 David Nolden <david.nolden.kdevelop@art-master.de>

    SPDX-License-Identifier: LGPL-2.0-only
*/

#ifndef PROJECT_ITEM_QUICKOPEN
#define PROJECT_ITEM_QUICKOPEN

#include "duchainitemquickopen.h"

#include <serialization/indexedstring.h>
#include <language/duchain/identifier.h>

#include <functional>
#include <type_traits>

template <typename Type>
class ResultCache
{
public:
    ResultCache(std::function<Type()> func)
        : m_func(func)
    {
    }

    /// Mark this cache dirty. A call to cachedResult() will need to refill the cache
    inline void markDirty() const
    {
        m_isDirty = true;
    }

    /**
     * If marked dirty, calls @p func and stores return value of @p func
     *
     * @return Cached result of @p func
     */
    inline Type cachedResult() const
    {
        if (m_isDirty) {
            m_result = m_func();
            m_isDirty = false;
        }
        return m_result;
    }
private:
    std::function<Type()> m_func;

    mutable Type m_result;
    mutable bool m_isDirty = true;
};

struct CodeModelViewItem
{
    CodeModelViewItem()
    {
    }
    CodeModelViewItem(const KDevelop::IndexedString& file, const KDevelop::QualifiedIdentifier& id)
        : m_file(file)
        , m_id(id)
    {
    }
    KDevelop::IndexedString m_file;
    KDevelop::QualifiedIdentifier m_id;
};

Q_DECLARE_TYPEINFO(CodeModelViewItem, Q_MOVABLE_TYPE);

using AddedItems = QMap<uint, QList<KDevelop::QuickOpenDataPointer>>;

class ProjectItemDataProvider
    : public KDevelop::QuickOpenDataProviderBase
{
    Q_OBJECT
public:
    enum ItemTypes {
        NoItems = 0,
        Classes = 1,
        Functions = 2,
        AllItemTypes = Classes + Functions
    };

    explicit ProjectItemDataProvider(KDevelop::IQuickOpen* quickopen);

    void enableData(const QStringList& items, const QStringList& scopes) override;

    void setFilterText(const QString& text) override;

    void reset() override;

    uint itemCount() const override;
    uint unfilteredItemCount() const override;

    static QStringList supportedItemTypes();
private:
    KDevelop::QuickOpenDataPointer data(uint pos) const override;

    ItemTypes m_itemTypes;
    KDevelop::IQuickOpen* m_quickopen;
    QSet<KDevelop::IndexedString> m_files;
    QVector<CodeModelViewItem> m_currentItems;
    QString m_currentFilter;
    QVector<CodeModelViewItem> m_filteredItems;

    //Maps positions to the additional items behind those positions
    //Here additional inserted items are stored, that are not represented in m_filteredItems.
    //This is needed at least to also show overloaded function declarations
    mutable AddedItems m_addedItems;
    ResultCache<uint> m_addedItemsCountCache;
};

#endif