|
1 /**************************************************************************** |
|
2 ** |
|
3 ** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). |
|
4 ** All rights reserved. |
|
5 ** Contact: Nokia Corporation (qt-info@nokia.com) |
|
6 ** |
|
7 ** This file is part of the documentation of the Qt Toolkit. |
|
8 ** |
|
9 ** $QT_BEGIN_LICENSE:LGPL$ |
|
10 ** No Commercial Usage |
|
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 ** Alternatively, this file may be used under the terms of the GNU Lesser |
|
18 ** General Public License version 2.1 as published by the Free Software |
|
19 ** Foundation and appearing in the file LICENSE.LGPL included in the |
|
20 ** packaging of this file. Please review the following information to |
|
21 ** ensure the GNU Lesser General Public License version 2.1 requirements |
|
22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. |
|
23 ** |
|
24 ** In addition, as a special exception, Nokia gives you certain additional |
|
25 ** rights. These rights are described in the Nokia Qt LGPL Exception |
|
26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. |
|
27 ** |
|
28 ** If you have questions regarding the use of this file, please contact |
|
29 ** Nokia at qt-info@nokia.com. |
|
30 ** |
|
31 ** |
|
32 ** |
|
33 ** |
|
34 ** |
|
35 ** |
|
36 ** |
|
37 ** |
|
38 ** $QT_END_LICENSE$ |
|
39 ** |
|
40 ****************************************************************************/ |
|
41 |
|
42 /*! |
|
43 \page moc.html |
|
44 \title Using the Meta-Object Compiler (moc) |
|
45 \ingroup qttools |
|
46 \keyword moc |
|
47 |
|
48 The Meta-Object Compiler, \c moc, is the program that handles |
|
49 \l{Meta-Object System}{Qt's C++ extensions}. |
|
50 |
|
51 The \c moc tool reads a C++ header file. If it finds one or more |
|
52 class declarations that contain the Q_OBJECT macro, it |
|
53 produces a C++ source file containing the meta-object code for |
|
54 those classes. Among other things, meta-object code is required |
|
55 for the signals and slots mechanism, the run-time type information, |
|
56 and the dynamic property system. |
|
57 |
|
58 The C++ source file generated by \c moc must be compiled and |
|
59 linked with the implementation of the class. |
|
60 |
|
61 If you use \l qmake to create your makefiles, build rules will be |
|
62 included that call the moc when required, so you will not need to |
|
63 use the moc directly. For more background information on \c moc, |
|
64 see \l{Why Doesn't Qt Use Templates for Signals and Slots?} |
|
65 |
|
66 \section1 Usage |
|
67 |
|
68 \c moc is typically used with an input file containing class |
|
69 declarations like this: |
|
70 |
|
71 \snippet doc/src/snippets/moc/myclass1.h 0 |
|
72 |
|
73 In addition to the signals and slots shown above, \c moc also |
|
74 implements object properties as in the next example. The |
|
75 Q_PROPERTY() macro declares an object property, while |
|
76 Q_ENUMS() declares a list of enumeration types within the class |
|
77 to be usable inside the \l{Qt's Property System}{property |
|
78 system}. |
|
79 |
|
80 In the following example, we declare a property of the |
|
81 enumeration type \c Priority that is also called \c priority and |
|
82 has a get function \c priority() and a set function \c |
|
83 setPriority(). |
|
84 |
|
85 \snippet doc/src/snippets/moc/myclass2.h 0 |
|
86 |
|
87 The Q_FLAGS() macro declares enums that are to be used |
|
88 as flags, i.e. OR'd together. Another macro, Q_CLASSINFO(), |
|
89 allows you to attach additional name/value pairs to the class's |
|
90 meta-object: |
|
91 |
|
92 \snippet doc/src/snippets/moc/myclass3.h 0 |
|
93 |
|
94 The output produced by \c moc must be compiled and linked, just |
|
95 like the other C++ code in your program; otherwise, the build |
|
96 will fail in the final link phase. If you use \c qmake, this is |
|
97 done automatically. Whenever \c qmake is run, it parses the |
|
98 project's header files and generates make rules to invoke \c moc |
|
99 for those files that contain a Q_OBJECT macro. |
|
100 |
|
101 If the class declaration is found in the file \c myclass.h, the |
|
102 moc output should be put in a file called \c moc_myclass.cpp. |
|
103 This file should then be compiled as usual, resulting in an |
|
104 object file, e.g., \c moc_myclass.obj on Windows. This object |
|
105 should then be included in the list of object files that are |
|
106 linked together in the final building phase of the program. |
|
107 |
|
108 \section1 Writing Make Rules for Invoking \c moc |
|
109 |
|
110 For anything but the simplest test programs, it is recommended |
|
111 that you automate running the \c{moc}. By adding some rules to |
|
112 your program's makefile, \c make can take care of running moc |
|
113 when necessary and handling the moc output. |
|
114 |
|
115 We recommend using the \l qmake makefile generation tool for |
|
116 building your makefiles. This tool generates a makefile that does |
|
117 all the necessary \c moc handling. |
|
118 |
|
119 If you want to create your makefiles yourself, here are some tips |
|
120 on how to include moc handling. |
|
121 |
|
122 For Q_OBJECT class declarations in header files, here is a |
|
123 useful makefile rule if you only use GNU make: |
|
124 |
|
125 \snippet doc/src/snippets/code/doc_src_moc.qdoc 0 |
|
126 |
|
127 If you want to write portably, you can use individual rules of |
|
128 the following form: |
|
129 |
|
130 \snippet doc/src/snippets/code/doc_src_moc.qdoc 1 |
|
131 |
|
132 You must also remember to add \c moc_foo.cpp to your \c SOURCES |
|
133 (substitute your favorite name) variable and \c moc_foo.o or \c |
|
134 moc_foo.obj to your \c OBJECTS variable. |
|
135 |
|
136 Both examples assume that \c $(DEFINES) and \c $(INCPATH) expand |
|
137 to the define and include path options that are passed to the C++ |
|
138 compiler. These are required by \c moc to preprocess the source |
|
139 files. |
|
140 |
|
141 While we prefer to name our C++ source files \c .cpp, you can use |
|
142 any other extension, such as \c .C, \c .cc, \c .CC, \c .cxx, and |
|
143 \c .c++, if you prefer. |
|
144 |
|
145 For Q_OBJECT class declarations in implementation (\c .cpp) |
|
146 files, we suggest a makefile rule like this: |
|
147 |
|
148 \snippet doc/src/snippets/code/doc_src_moc.qdoc 2 |
|
149 |
|
150 This guarantees that make will run the moc before it compiles |
|
151 \c foo.cpp. You can then put |
|
152 |
|
153 \snippet doc/src/snippets/code/doc_src_moc.qdoc 3 |
|
154 |
|
155 at the end of \c foo.cpp, where all the classes declared in that |
|
156 file are fully known. |
|
157 |
|
158 \section1 Command-Line Options |
|
159 |
|
160 Here are the command-line options supported by the moc: |
|
161 |
|
162 \table |
|
163 \header \o Option \o Description |
|
164 |
|
165 \row |
|
166 \o \c{-o<file>} |
|
167 \o Write output to \c <file> rather than to standard output. |
|
168 |
|
169 \row |
|
170 \o \c{-f[<file>]} |
|
171 \o Force the generation of an \c #include statement in the |
|
172 output. This is the default for header files whose extension |
|
173 starts with \c H or \c h. This option is useful if you have |
|
174 header files that do not follow the standard naming conventions. |
|
175 The \c <file> part is optional. |
|
176 |
|
177 \row |
|
178 \o \c -i |
|
179 \o Do not generate an \c #include statement in the output. |
|
180 This may be used to run the moc on on a C++ file containing one or |
|
181 more class declarations. You should then \c #include the meta-object |
|
182 code in the \c .cpp file. |
|
183 |
|
184 \row |
|
185 \o \c -nw |
|
186 \o Do not generate any warnings. (Not recommended.) |
|
187 |
|
188 \row |
|
189 \o \c {-p<path>} |
|
190 \o Makes the moc prepend \c {<path>/} to the file name in the |
|
191 generated \c #include statement. |
|
192 |
|
193 \row |
|
194 \o \c {-I<dir>} |
|
195 \o Add dir to the include path for header files. |
|
196 |
|
197 \row |
|
198 \o \c{-E} |
|
199 \o Preprocess only; do not generate meta-object code. |
|
200 |
|
201 \row |
|
202 \o \c {-D<macro>[=<def>]} |
|
203 \o Define macro, with optional definition. |
|
204 |
|
205 \row |
|
206 \o \c{-U<macro>} |
|
207 \o Undefine macro. |
|
208 |
|
209 \row |
|
210 \o \c{@<file>} |
|
211 \o Read additional command-line options from \c{<file>}. |
|
212 Each line of the file is treated as a single option. Empty lines |
|
213 are ignored. Note that this option is not supported within the |
|
214 options file itself (i.e. an options file can't "include" another |
|
215 file). |
|
216 |
|
217 \row |
|
218 \o \c{-h} |
|
219 \o Display the usage and the list of options. |
|
220 |
|
221 \row |
|
222 \o \c {-v} |
|
223 \o Display \c{moc}'s version number. |
|
224 |
|
225 \row |
|
226 \o \c{-Fdir} |
|
227 |
|
228 \o Mac OS X. Add the framework directory \c{dir} to the head of |
|
229 the list of directories to be searched for header files. These |
|
230 directories are interleaved with those specified by -I options |
|
231 and are scanned in a left-to-right order (see the manpage for |
|
232 gcc). Normally, use -F /Library/Frameworks/ |
|
233 |
|
234 \endtable |
|
235 |
|
236 You can explicitly tell the moc not to parse parts of a header |
|
237 file. \c moc defines the preprocessor symbol \c Q_MOC_RUN. Any |
|
238 code surrounded by |
|
239 |
|
240 \snippet doc/src/snippets/code/doc_src_moc.qdoc 4 |
|
241 |
|
242 is skipped by the \c moc. |
|
243 |
|
244 \section1 Diagnostics |
|
245 |
|
246 \c moc will warn you about a number of dangerous or illegal |
|
247 constructs in the Q_OBJECT class declarations. |
|
248 |
|
249 If you get linkage errors in the final building phase of your |
|
250 program, saying that \c YourClass::className() is undefined or |
|
251 that \c YourClass lacks a vtable, something has been done wrong. |
|
252 Most often, you have forgotten to compile or \c #include the |
|
253 moc-generated C++ code, or (in the former case) include that |
|
254 object file in the link command. If you use \c qmake, try |
|
255 rerunning it to update your makefile. This should do the trick. |
|
256 |
|
257 \section1 Limitations |
|
258 |
|
259 \c moc does not handle all of C++. The main problem is that class |
|
260 templates cannot have signals or slots. Here is an example: |
|
261 |
|
262 \snippet doc/src/snippets/code/doc_src_moc.qdoc 5 |
|
263 |
|
264 Another limitation is that moc does not expand macros, so you |
|
265 for example cannot use a macro to declare a signal/slot |
|
266 or use one to define a base class for a QObject. |
|
267 |
|
268 Less importantly, the following constructs are illegal. All of |
|
269 them have alternatives which we think are usually better, so |
|
270 removing these limitations is not a high priority for us. |
|
271 |
|
272 \section2 Multiple Inheritance Requires QObject to Be First |
|
273 |
|
274 If you are using multiple inheritance, \c moc assumes that the |
|
275 first inherited class is a subclass of QObject. Also, be sure |
|
276 that only the first inherited class is a QObject. |
|
277 |
|
278 \snippet doc/src/snippets/code/doc_src_moc.qdoc 6 |
|
279 |
|
280 Virtual inheritance with QObject is \e not supported. |
|
281 |
|
282 \section2 Function Pointers Cannot Be Signal or Slot Parameters |
|
283 |
|
284 In most cases where you would consider using function pointers as |
|
285 signal or slot parameters, we think inheritance is a better |
|
286 alternative. Here is an example of illegal syntax: |
|
287 |
|
288 \snippet doc/src/snippets/code/doc_src_moc.qdoc 7 |
|
289 |
|
290 You can work around this restriction like this: |
|
291 |
|
292 \snippet doc/src/snippets/code/doc_src_moc.qdoc 8 |
|
293 |
|
294 It may sometimes be even better to replace the function pointer |
|
295 with inheritance and virtual functions. |
|
296 |
|
297 \section2 Enums and Typedefs Must Be Fully Qualified for Signal and Slot Parameters |
|
298 |
|
299 When checking the signatures of its arguments, QObject::connect() |
|
300 compares the data types literally. Thus, |
|
301 \l{Qt::Alignment}{Alignment} and \l{Qt::Alignment} are treated as |
|
302 two distinct types. To work around this limitation, make sure to |
|
303 fully qualify the data types when declaring signals and slots, |
|
304 and when establishing connections. For example: |
|
305 |
|
306 \snippet doc/src/snippets/code/doc_src_moc.qdoc 9 |
|
307 |
|
308 \section2 Type Macros Cannot Be Used for Signal and Slot Parameters |
|
309 |
|
310 Since \c moc doesn't expand \c{#define}s, type macros that take |
|
311 an argument will not work in signals and slots. Here is an |
|
312 illegal example: |
|
313 |
|
314 \snippet doc/src/snippets/code/doc_src_moc.qdoc 10 |
|
315 |
|
316 A macro without parameters will work. |
|
317 |
|
318 \section2 Nested Classes Cannot Have Signals or Slots |
|
319 |
|
320 Here's an example of the offending construct: |
|
321 |
|
322 \snippet doc/src/snippets/code/doc_src_moc.qdoc 11 |
|
323 |
|
324 \section2 Signal/Slot return types cannot be references |
|
325 |
|
326 Signals and slots can have return types, but signals or slots returning references |
|
327 will be treated as returning void. |
|
328 |
|
329 \section2 Only Signals and Slots May Appear in the \c signals and \c slots Sections of a Class |
|
330 |
|
331 \c moc will complain if you try to put other constructs in the \c |
|
332 signals or \c slots sections of a class than signals and slots. |
|
333 |
|
334 \sa {Meta-Object System}, {Signals and Slots}, {Qt's Property System} |
|
335 */ |