blob: 5c33f059a9c76780856c93361cf8f36fe81cefa6 (
plain)
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
|
/***************************************************************************
**
** This file is part of Qt Creator
**
** Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
**
** Contact: Qt Software Information (qt-info@nokia.com)
**
**
** Non-Open Source Usage
**
** Licensees may use this file in accordance with the Qt Beta Version
** License Agreement, Agreement version 2.2 provided with the Software or,
** alternatively, in accordance with the terms contained in a written
** agreement between you and Nokia.
**
** GNU General Public License Usage
**
** Alternatively, this file may be used under the terms of the GNU General
** Public License versions 2.0 or 3.0 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the packaging
** of this file. Please review the following information to ensure GNU
** General Public Licensing requirements will be met:
**
** http://www.fsf.org/licensing/licenses/info/GPLv2.html and
** http://www.gnu.org/copyleft/gpl.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights. These rights are described in the Nokia Qt GPL Exception
** version 1.2, included in the file GPL_EXCEPTION.txt in this package.
**
***************************************************************************/
#ifndef CPPCODEMODELPART_H
#define CPPCODEMODELPART_H
#include <QtCore/QObject>
#include <QtCore/QHash>
#include <QtCore/QSet>
#include <QtCore/QStringList>
class CppCodeModel;
class CppFileModelItem;
class CppCodeModelPart : public QObject
{
Q_OBJECT
public:
CppCodeModelPart(const QString &path, QObject *parent = 0);
~CppCodeModelPart();
QString path() const;
void update();
protected:
// returns true if the given qualified name is known
bool hasScope(const QString &name) const;
// returns the contents of the file, this may be
// the current content of an open editor
// the byte array is deleted when no longer needed
QByteArray *contents(const QString &file);
// stores/replaces the parsed code model in the
// database or memory
void store(CppFileModelItem *item);
private:
QString m_path;
QSet<QString> m_files;
friend class CppCodeModel;
};
#endif // CPPCODEMODELPART_H
|