source: trunk/doc/src/examples/globalVariables.qdoc@ 33

Last change on this file since 33 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 9.3 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information (qt-info@nokia.com)
5**
6** This file is part of the documentation of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at qt-sales@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42/*!
43 \example xmlpatterns/xquery/globalVariables
44 \title C++ Source Code Analyzer Example
45
46 This example uses XQuery and the \c xmlpatterns command line utility to
47 query C++ source code.
48
49 \tableofcontents
50
51 \section1 Introduction
52
53 Suppose we want to analyze C++ source code to find coding standard
54 violations and instances of bad or inefficient patterns. We can do
55 it using the common searching and pattern matching utilities to
56 process the C++ files (e.g., \c{grep}, \c{sed}, and \c{awk}). Now
57 we can also use XQuery with the QtXmlPatterns module.
58
59 An extension to the \c{g++} open source C++ compiler
60 (\l{http://public.kitware.com/GCC_XML/HTML/Index.html} {GCC-XML})
61 generates an XML description of C++ source code declarations. This
62 XML description can then be processed by QtXmlPatterns using
63 XQueries to navigate the XML description of the C++ source and
64 produce a report. Consider the problem of finding mutable global
65 variables:
66
67 \section2 Reporting Uses of Mutable Global Variables
68
69 Suppose we want to introduce threading to a C++ application that
70 was originally written without threading. In a threaded program,
71 mutable global variables can cause bugs, because one thread might
72 change a global variable that other threads are reading, or two
73 threads might try to set the same global variable. So when
74 converting our program to use threading, one of the things we must
75 do is protect the global variables to prevent the bugs described
76 above. How can we use XQuery and
77 \l{http://public.kitware.com/GCC_XML/HTML/Index.html} {GCC-XML} to
78 find the variables that need protecting?
79
80 \section3 A C++ application
81
82 Consider the declarations in this hypothetical C++ application:
83
84 \snippet examples/xmlpatterns/xquery/globalVariables/globals.cpp 0
85
86 \section3 The XML description of the C++ application
87
88 Submitting this C++ source to
89 \l{http://public.kitware.com/GCC_XML/HTML/Index.html} {GCC-XML}
90 produces this XML description:
91
92 \quotefromfile examples/xmlpatterns/xquery/globalVariables/globals.gccxml
93 \printuntil
94
95 \section3 The XQuery for finding global variables
96
97 We need an XQuery to find the global variables in the XML
98 description. Here is our XQuery source. We walk through it in
99 \l{XQuery Code Walk-Through}.
100
101 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
102 \printuntil
103
104 \section3 Running the XQuery
105
106 To run the XQuery using the \c xmlpatterns command line utility,
107 enter the following command:
108
109 \code
110 xmlpatterns reportGlobals.xq -param fileToOpen=globals.gccxml -output globals.html
111 \endcode
112
113 \section3 The XQuery output
114
115 The \c xmlpatterns command loads and parses \c globals.gccxml,
116 runs the XQuery \c reportGlobals.xq, and generates this report:
117
118 \raw HTML
119<html xmlns="http://www.w3.org/1999/xhtml/" xml:lang="en" lang="en">
120 <head>
121 <title>Global variables report for globals.gccxml</title>
122 </head>
123 <style type="text/css">
124 .details
125 {
126 text-align: left;
127 font-size: 80%;
128 color: blue
129 }
130 .variableName
131 {
132 font-family: courier;
133 color: blue
134 }
135 </style>
136 <body>
137 <p class="details">Start report: 2008-12-16T13:43:49.65Z</p>
138 <p>Global variables with complex types:</p>
139 <ol>
140 <li>
141 <span class="variableName">mutableComplex1</span> in globals.cpp at line 14</li>
142 <li>
143 <span class="variableName">mutableComplex2</span> in globals.cpp at line 15</li>
144 <li>
145 <span class="variableName">constComplex1</span> in globals.cpp at line 16</li>
146 <li>
147 <span class="variableName">constComplex2</span> in globals.cpp at line 17</li>
148 </ol>
149 <p>Mutable global variables with primitives types:</p>
150 <ol>
151 <li>
152 <span class="variableName">mutablePrimitive1</span> in globals.cpp at line 1</li>
153 <li>
154 <span class="variableName">mutablePrimitive2</span> in globals.cpp at line 2</li>
155 </ol>
156 <p class="details">End report: 2008-12-16T13:43:49.65Z</p>
157 </body>
158</html>
159 \endraw
160
161 \section1 XQuery Code Walk-Through
162
163 The XQuery source is in
164 \c{examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq}
165 It begins with two variable declarations that begin the XQuery:
166
167 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
168 \skipto declare variable
169 \printto (:
170
171 The first variable, \c{$fileToOpen}, appears in the \c xmlpatterns
172 command shown earlier, as \c{-param fileToOpen=globals.gccxml}.
173 This binds the variable name to the file name. This variable is
174 then used in the declaration of the second variable, \c{$inDoc},
175 as the parameter to the
176 \l{http://www.w3.org/TR/xpath-functions/#func-doc} {doc()}
177 function. The \c{doc()} function returns the document node of
178 \c{globals.gccxml}, which is assigned to \c{$inDoc} to be used
179 later in the XQuery as the root node of our searches for global
180 variables.
181
182 Next skip to the end of the XQuery, where the \c{<html>} element
183 is constructed. The \c{<html>} will contain a \c{<head>} element
184 to specify a heading for the html page, followed by some style
185 instructions for displaying the text, and then the \c{<body>}
186 element.
187
188 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
189 \skipto <html xmlns
190 \printuntil
191
192 The \c{<body>} element contains a call to the \c{local:report()}
193 function, which is where the query does the "heavy lifting." Note
194 the two \c{return} clauses separated by the \e {comma operator}
195 about halfway down:
196
197 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
198 \skipto declare function local:report()
199 \printuntil };
200
201 The \c{return} clauses are like two separate queries. The comma
202 operator separating them means that both \c{return} clauses are
203 executed and both return their results, or, rather, both output
204 their results. The first \c{return} clause searches for global
205 variables with complex types, and the second searches for mutable
206 global variables with primitive types.
207
208 Here is the html generated for the \c{<body>} element. Compare
209 it with the XQuery code above:
210
211 \quotefromfile examples/xmlpatterns/xquery/globalVariables/globals.html
212 \skipto <body>
213 \printuntil </body>
214
215 The XQuery declares three more local functions that are called in
216 turn by the \c{local:report()} function. \c{isComplexType()}
217 returns true if the variable has a complex type. The variable can
218 be mutable or const.
219
220 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
221 \skipto declare function local:isComplexType
222 \printuntil };
223
224 \c{isPrimitive()} returns true if the variable has a primitive
225 type. The variable must be mutable.
226
227 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
228 \skipto declare function local:isPrimitive
229 \printuntil };
230
231 \c{location()} returns a text constructed from the variable's file
232 and line number attributes.
233
234 \quotefromfile examples/xmlpatterns/xquery/globalVariables/reportGlobals.xq
235 \skipto declare function local:location
236 \printuntil };
237
238 */
Note: See TracBrowser for help on using the repository browser.