OSDN Git Service

8f6e990215e21b15c792505ac71f12f9181ddf79
[qt-creator-jp/qt-creator-jp.git] / src / plugins / designer / resourcehandler.h
1 /**************************************************************************
2 **
3 ** This file is part of Qt Creator
4 **
5 ** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
6 **
7 ** Contact: Nokia Corporation (qt-info@nokia.com)
8 **
9 ** No Commercial Usage
10 **
11 ** This file contains pre-release code and may not be distributed.
12 ** You may use this file in accordance with the terms and conditions
13 ** contained in the Technology Preview License Agreement accompanying
14 ** this package.
15 **
16 ** GNU Lesser General Public License Usage
17 **
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 2.1 as published by the Free Software
20 ** Foundation and appearing in the file LICENSE.LGPL included in the
21 ** packaging of this file.  Please review the following information to
22 ** ensure the GNU Lesser General Public License version 2.1 requirements
23 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24 **
25 ** In addition, as a special exception, Nokia gives you certain additional
26 ** rights.  These rights are described in the Nokia Qt LGPL Exception
27 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28 **
29 ** If you have questions regarding the use of this file, please contact
30 ** Nokia at qt-info@nokia.com.
31 **
32 **************************************************************************/
33
34 #ifndef RESOURCEHANDLER_H
35 #define RESOURCEHANDLER_H
36
37 #include <QtCore/QObject>
38 #include <QtCore/QStringList>
39
40 QT_BEGIN_NAMESPACE
41 namespace qdesigner_internal {
42     class FormWindowBase;
43 }
44 QT_END_NAMESPACE
45
46 namespace ProjectExplorer {
47 class SessionNode;
48 class NodesWatcher;
49 }
50
51 namespace Designer {
52 namespace Internal {
53
54 /* ResourceHandler: Constructed on a form window and activated on open/save as
55  * (see README.txt). The form can have 2 states:
56  * 1) standalone: Uses the form editor's list of resource files.
57  * 2) Within a project: Use the list of resources files of the projects.
58  *
59  * When initializing, store the original list of qrc files of the form and
60  * connect to various signals of the project explorer to re-check.
61  * In updateResources, check whether the form is part of a project and use
62  * the project's resource files or the stored ones. */
63
64 class ResourceHandler : public QObject
65 {
66     Q_OBJECT
67 public:
68     explicit ResourceHandler(qdesigner_internal::FormWindowBase *fw);
69     virtual ~ResourceHandler();
70
71 public slots:
72     void updateResources();
73
74 private:
75     void ensureInitialized();
76
77     qdesigner_internal::FormWindowBase * const m_form;
78
79     QStringList m_originalUiQrcPaths;
80     ProjectExplorer::SessionNode *m_sessionNode;
81     ProjectExplorer::NodesWatcher *m_sessionWatcher;
82 };
83
84 } // namespace Internal
85 } // namespace Designer
86
87 #endif // RESOURCEHANDLER_H