annotate generator/docparser.cpp @ 379:a795eeb3b21f

example minor change
author Eldar Insafutdinov
date Sat, 10 Jul 2010 22:16:33 +0100
parents e78566595089
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
e78566595089 initial import
mandel
parents:
diff changeset
1 /****************************************************************************
e78566595089 initial import
mandel
parents:
diff changeset
2 **
e78566595089 initial import
mandel
parents:
diff changeset
3 ** Copyright (C) 1992-2008 Nokia. All rights reserved.
e78566595089 initial import
mandel
parents:
diff changeset
4 **
e78566595089 initial import
mandel
parents:
diff changeset
5 ** This file is part of Qt Jambi.
e78566595089 initial import
mandel
parents:
diff changeset
6 **
e78566595089 initial import
mandel
parents:
diff changeset
7 ** * Commercial Usage
e78566595089 initial import
mandel
parents:
diff changeset
8 * Licensees holding valid Qt Commercial licenses may use this file in
e78566595089 initial import
mandel
parents:
diff changeset
9 * accordance with the Qt Commercial License Agreement provided with the
e78566595089 initial import
mandel
parents:
diff changeset
10 * Software or, alternatively, in accordance with the terms contained in
e78566595089 initial import
mandel
parents:
diff changeset
11 * a written agreement between you and Nokia.
e78566595089 initial import
mandel
parents:
diff changeset
12 *
e78566595089 initial import
mandel
parents:
diff changeset
13 *
e78566595089 initial import
mandel
parents:
diff changeset
14 * GNU General Public License Usage
e78566595089 initial import
mandel
parents:
diff changeset
15 * Alternatively, this file may be used under the terms of the GNU
e78566595089 initial import
mandel
parents:
diff changeset
16 * General Public License versions 2.0 or 3.0 as published by the Free
e78566595089 initial import
mandel
parents:
diff changeset
17 * Software Foundation and appearing in the file LICENSE.GPL included in
e78566595089 initial import
mandel
parents:
diff changeset
18 * the packaging of this file. Please review the following information
e78566595089 initial import
mandel
parents:
diff changeset
19 * to ensure GNU General Public Licensing requirements will be met:
e78566595089 initial import
mandel
parents:
diff changeset
20 * http://www.fsf.org/licensing/licenses/info/GPLv2.html and
e78566595089 initial import
mandel
parents:
diff changeset
21 * http://www.gnu.org/copyleft/gpl.html. In addition, as a special
e78566595089 initial import
mandel
parents:
diff changeset
22 * exception, Nokia gives you certain additional rights. These rights
e78566595089 initial import
mandel
parents:
diff changeset
23 * are described in the Nokia Qt GPL Exception version 1.2, included in
e78566595089 initial import
mandel
parents:
diff changeset
24 * the file GPL_EXCEPTION.txt in this package.
e78566595089 initial import
mandel
parents:
diff changeset
25 *
e78566595089 initial import
mandel
parents:
diff changeset
26 * Qt for Windows(R) Licensees
e78566595089 initial import
mandel
parents:
diff changeset
27 * As a special exception, Nokia, as the sole copyright holder for Qt
e78566595089 initial import
mandel
parents:
diff changeset
28 * Designer, grants users of the Qt/Eclipse Integration plug-in the
e78566595089 initial import
mandel
parents:
diff changeset
29 * right for the Qt/Eclipse Integration to link to functionality
e78566595089 initial import
mandel
parents:
diff changeset
30 * provided by Qt Designer and its related libraries.
e78566595089 initial import
mandel
parents:
diff changeset
31 *
e78566595089 initial import
mandel
parents:
diff changeset
32 *
e78566595089 initial import
mandel
parents:
diff changeset
33 * If you are unsure which license is appropriate for your use, please
e78566595089 initial import
mandel
parents:
diff changeset
34 * contact the sales department at qt-sales@nokia.com.
e78566595089 initial import
mandel
parents:
diff changeset
35
e78566595089 initial import
mandel
parents:
diff changeset
36 **
e78566595089 initial import
mandel
parents:
diff changeset
37 ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
e78566595089 initial import
mandel
parents:
diff changeset
38 ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
e78566595089 initial import
mandel
parents:
diff changeset
39 **
e78566595089 initial import
mandel
parents:
diff changeset
40 ****************************************************************************/
e78566595089 initial import
mandel
parents:
diff changeset
41
e78566595089 initial import
mandel
parents:
diff changeset
42 #include "docparser.h"
e78566595089 initial import
mandel
parents:
diff changeset
43
e78566595089 initial import
mandel
parents:
diff changeset
44 #include "metajava.h"
e78566595089 initial import
mandel
parents:
diff changeset
45 #include "reporthandler.h"
e78566595089 initial import
mandel
parents:
diff changeset
46
e78566595089 initial import
mandel
parents:
diff changeset
47 #include <QtCore/QFileInfo>
e78566595089 initial import
mandel
parents:
diff changeset
48 #include <QtCore/QFile>
e78566595089 initial import
mandel
parents:
diff changeset
49
e78566595089 initial import
mandel
parents:
diff changeset
50 #include <QtXml>
e78566595089 initial import
mandel
parents:
diff changeset
51
e78566595089 initial import
mandel
parents:
diff changeset
52 DocParser::DocParser(const QString &name)
e78566595089 initial import
mandel
parents:
diff changeset
53 : m_doc_file(name),
e78566595089 initial import
mandel
parents:
diff changeset
54 m_dom(0)
e78566595089 initial import
mandel
parents:
diff changeset
55 {
e78566595089 initial import
mandel
parents:
diff changeset
56 build();
e78566595089 initial import
mandel
parents:
diff changeset
57 }
e78566595089 initial import
mandel
parents:
diff changeset
58
e78566595089 initial import
mandel
parents:
diff changeset
59 DocParser::~DocParser()
e78566595089 initial import
mandel
parents:
diff changeset
60 {
e78566595089 initial import
mandel
parents:
diff changeset
61 delete m_dom;
e78566595089 initial import
mandel
parents:
diff changeset
62 }
e78566595089 initial import
mandel
parents:
diff changeset
63
e78566595089 initial import
mandel
parents:
diff changeset
64 QString DocParser::documentation(const AbstractMetaClass *meta_class) const
e78566595089 initial import
mandel
parents:
diff changeset
65 {
e78566595089 initial import
mandel
parents:
diff changeset
66 if (!m_dom)
e78566595089 initial import
mandel
parents:
diff changeset
67 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
68
e78566595089 initial import
mandel
parents:
diff changeset
69 QDomElement root_node = m_dom->documentElement();
e78566595089 initial import
mandel
parents:
diff changeset
70
e78566595089 initial import
mandel
parents:
diff changeset
71 QString class_name = root_node.attribute("name");
e78566595089 initial import
mandel
parents:
diff changeset
72 QString doc = root_node.attribute("doc");
e78566595089 initial import
mandel
parents:
diff changeset
73
e78566595089 initial import
mandel
parents:
diff changeset
74 if (class_name != meta_class->name()) {
e78566595089 initial import
mandel
parents:
diff changeset
75 ReportHandler::warning("Documentelement file contains unexpected class: " + class_name + ", file=" + m_doc_file);
e78566595089 initial import
mandel
parents:
diff changeset
76 }
e78566595089 initial import
mandel
parents:
diff changeset
77
e78566595089 initial import
mandel
parents:
diff changeset
78 return doc;
e78566595089 initial import
mandel
parents:
diff changeset
79 }
e78566595089 initial import
mandel
parents:
diff changeset
80
e78566595089 initial import
mandel
parents:
diff changeset
81 QString DocParser::documentationForFunction(const QString &signature, const QString &tag) const
e78566595089 initial import
mandel
parents:
diff changeset
82 {
e78566595089 initial import
mandel
parents:
diff changeset
83 if (!m_dom)
e78566595089 initial import
mandel
parents:
diff changeset
84 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
85
e78566595089 initial import
mandel
parents:
diff changeset
86 QDomElement root_node = m_dom->documentElement();
e78566595089 initial import
mandel
parents:
diff changeset
87 QDomNodeList functions = root_node.elementsByTagName(tag);
e78566595089 initial import
mandel
parents:
diff changeset
88
e78566595089 initial import
mandel
parents:
diff changeset
89 for (int i=0; i<functions.size(); ++i) {
e78566595089 initial import
mandel
parents:
diff changeset
90 QDomNode node = functions.item(i);
e78566595089 initial import
mandel
parents:
diff changeset
91
e78566595089 initial import
mandel
parents:
diff changeset
92 QDomElement *e = (QDomElement *) &node;
e78566595089 initial import
mandel
parents:
diff changeset
93
e78566595089 initial import
mandel
parents:
diff changeset
94 Q_ASSERT(e->isElement());
e78566595089 initial import
mandel
parents:
diff changeset
95
e78566595089 initial import
mandel
parents:
diff changeset
96 if (e->attribute("name") == signature)
e78566595089 initial import
mandel
parents:
diff changeset
97 return e->attribute("doc");
e78566595089 initial import
mandel
parents:
diff changeset
98 }
e78566595089 initial import
mandel
parents:
diff changeset
99
e78566595089 initial import
mandel
parents:
diff changeset
100 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
101 }
e78566595089 initial import
mandel
parents:
diff changeset
102
e78566595089 initial import
mandel
parents:
diff changeset
103
e78566595089 initial import
mandel
parents:
diff changeset
104 QString DocParser::documentationForSignal(const QString &signature) const
e78566595089 initial import
mandel
parents:
diff changeset
105 {
e78566595089 initial import
mandel
parents:
diff changeset
106 return documentationForFunction(signature, "signal");
e78566595089 initial import
mandel
parents:
diff changeset
107 }
e78566595089 initial import
mandel
parents:
diff changeset
108
e78566595089 initial import
mandel
parents:
diff changeset
109 QString DocParser::documentationForFunction(const QString &signature) const
e78566595089 initial import
mandel
parents:
diff changeset
110 {
e78566595089 initial import
mandel
parents:
diff changeset
111 return documentationForFunction(signature, "method");
e78566595089 initial import
mandel
parents:
diff changeset
112 }
e78566595089 initial import
mandel
parents:
diff changeset
113
e78566595089 initial import
mandel
parents:
diff changeset
114 QString DocParser::documentation(const AbstractMetaEnum *java_enum) const
e78566595089 initial import
mandel
parents:
diff changeset
115 {
e78566595089 initial import
mandel
parents:
diff changeset
116 if (!m_dom)
e78566595089 initial import
mandel
parents:
diff changeset
117 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
118
e78566595089 initial import
mandel
parents:
diff changeset
119 QDomElement root_node = m_dom->documentElement();
e78566595089 initial import
mandel
parents:
diff changeset
120
e78566595089 initial import
mandel
parents:
diff changeset
121 QDomNodeList enums = root_node.elementsByTagName("enum");
e78566595089 initial import
mandel
parents:
diff changeset
122
e78566595089 initial import
mandel
parents:
diff changeset
123 for (int i=0; i<enums.size(); ++i) {
e78566595089 initial import
mandel
parents:
diff changeset
124 QDomNode node = enums.item(i);
e78566595089 initial import
mandel
parents:
diff changeset
125 QDomElement *e = (QDomElement *) &node;
e78566595089 initial import
mandel
parents:
diff changeset
126
e78566595089 initial import
mandel
parents:
diff changeset
127 Q_ASSERT(e->isElement());
e78566595089 initial import
mandel
parents:
diff changeset
128
e78566595089 initial import
mandel
parents:
diff changeset
129 if (e->attribute("name") == java_enum->name()) {
e78566595089 initial import
mandel
parents:
diff changeset
130 return e->attribute("doc");
e78566595089 initial import
mandel
parents:
diff changeset
131 }
e78566595089 initial import
mandel
parents:
diff changeset
132 }
e78566595089 initial import
mandel
parents:
diff changeset
133
e78566595089 initial import
mandel
parents:
diff changeset
134 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
135 }
e78566595089 initial import
mandel
parents:
diff changeset
136
e78566595089 initial import
mandel
parents:
diff changeset
137
e78566595089 initial import
mandel
parents:
diff changeset
138 QString DocParser::documentation(const AbstractMetaEnumValue *java_enum_value) const
e78566595089 initial import
mandel
parents:
diff changeset
139 {
e78566595089 initial import
mandel
parents:
diff changeset
140 if (!m_dom)
e78566595089 initial import
mandel
parents:
diff changeset
141 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
142
e78566595089 initial import
mandel
parents:
diff changeset
143 QDomElement root_node = m_dom->documentElement();
e78566595089 initial import
mandel
parents:
diff changeset
144
e78566595089 initial import
mandel
parents:
diff changeset
145 QDomNodeList enums = root_node.elementsByTagName("enum");
e78566595089 initial import
mandel
parents:
diff changeset
146
e78566595089 initial import
mandel
parents:
diff changeset
147 for (int i=0; i<enums.size(); ++i) {
e78566595089 initial import
mandel
parents:
diff changeset
148 QDomNode node = enums.item(i);
e78566595089 initial import
mandel
parents:
diff changeset
149 QDomElement *e = (QDomElement *) &node;
e78566595089 initial import
mandel
parents:
diff changeset
150 Q_ASSERT(e->isElement());
e78566595089 initial import
mandel
parents:
diff changeset
151
e78566595089 initial import
mandel
parents:
diff changeset
152 QDomNodeList enumValues = e->elementsByTagName("enum-value");
e78566595089 initial import
mandel
parents:
diff changeset
153 for (int j=0; j<enumValues.size(); ++j) {
e78566595089 initial import
mandel
parents:
diff changeset
154 QDomNode node = enumValues.item(j);
e78566595089 initial import
mandel
parents:
diff changeset
155 QDomElement *ev = (QDomElement *) &node;
e78566595089 initial import
mandel
parents:
diff changeset
156 if (ev->attribute("name") == java_enum_value->name()) {
e78566595089 initial import
mandel
parents:
diff changeset
157 return ev->attribute("doc");
e78566595089 initial import
mandel
parents:
diff changeset
158 }
e78566595089 initial import
mandel
parents:
diff changeset
159 }
e78566595089 initial import
mandel
parents:
diff changeset
160 }
e78566595089 initial import
mandel
parents:
diff changeset
161
e78566595089 initial import
mandel
parents:
diff changeset
162 return QString();
e78566595089 initial import
mandel
parents:
diff changeset
163 }
e78566595089 initial import
mandel
parents:
diff changeset
164
e78566595089 initial import
mandel
parents:
diff changeset
165
e78566595089 initial import
mandel
parents:
diff changeset
166
e78566595089 initial import
mandel
parents:
diff changeset
167 void DocParser::build()
e78566595089 initial import
mandel
parents:
diff changeset
168 {
e78566595089 initial import
mandel
parents:
diff changeset
169 if (!QFileInfo(m_doc_file).exists()) {
e78566595089 initial import
mandel
parents:
diff changeset
170 ReportHandler::warning("Missing documentation file: " + m_doc_file);
e78566595089 initial import
mandel
parents:
diff changeset
171 return;
e78566595089 initial import
mandel
parents:
diff changeset
172 }
e78566595089 initial import
mandel
parents:
diff changeset
173
e78566595089 initial import
mandel
parents:
diff changeset
174 QFile f(m_doc_file);
e78566595089 initial import
mandel
parents:
diff changeset
175 if (!f.open(QFile::ReadOnly | QFile::Text)) {
e78566595089 initial import
mandel
parents:
diff changeset
176 ReportHandler::warning("Failed to open documentation file: " + m_doc_file);
e78566595089 initial import
mandel
parents:
diff changeset
177 return;
e78566595089 initial import
mandel
parents:
diff changeset
178 }
e78566595089 initial import
mandel
parents:
diff changeset
179
e78566595089 initial import
mandel
parents:
diff changeset
180 m_dom = new QDomDocument();
e78566595089 initial import
mandel
parents:
diff changeset
181
e78566595089 initial import
mandel
parents:
diff changeset
182 QString error;
e78566595089 initial import
mandel
parents:
diff changeset
183 int line, column;
e78566595089 initial import
mandel
parents:
diff changeset
184
e78566595089 initial import
mandel
parents:
diff changeset
185 if (!m_dom->setContent(&f, &error, &line, &column)) {
e78566595089 initial import
mandel
parents:
diff changeset
186 ReportHandler::warning(QString("Failed to parse the documentation file:"
e78566595089 initial import
mandel
parents:
diff changeset
187 " '%1' %2 line=%3 column=%4")
e78566595089 initial import
mandel
parents:
diff changeset
188 .arg(m_doc_file)
e78566595089 initial import
mandel
parents:
diff changeset
189 .arg(error)
e78566595089 initial import
mandel
parents:
diff changeset
190 .arg(line)
e78566595089 initial import
mandel
parents:
diff changeset
191 .arg(column));
e78566595089 initial import
mandel
parents:
diff changeset
192
e78566595089 initial import
mandel
parents:
diff changeset
193 delete m_dom;
e78566595089 initial import
mandel
parents:
diff changeset
194 m_dom = 0;
e78566595089 initial import
mandel
parents:
diff changeset
195
e78566595089 initial import
mandel
parents:
diff changeset
196 return;
e78566595089 initial import
mandel
parents:
diff changeset
197 }
e78566595089 initial import
mandel
parents:
diff changeset
198
e78566595089 initial import
mandel
parents:
diff changeset
199
e78566595089 initial import
mandel
parents:
diff changeset
200 }