diff options
Diffstat (limited to 'doc/man/man1/moc.1')
-rw-r--r-- | doc/man/man1/moc.1 | 449 |
1 files changed, 0 insertions, 449 deletions
diff --git a/doc/man/man1/moc.1 b/doc/man/man1/moc.1 deleted file mode 100644 index 24ed9690f..000000000 --- a/doc/man/man1/moc.1 +++ /dev/null @@ -1,449 +0,0 @@ -.TH moc 1 "24 June 2001" "Trolltech AS" \" -*- nroff -*- -.\" -.\" $Id: qt/moc.1 3.3.8 edited Jan 11 14:38 $ -.\" -.\" Copyright (C) 1992-2007 Trolltech ASA. All rights reserved. -.\" -.\" This file is part of TQt and may be distributed and used according to -.\" the terms and conditions described in the LICENSE file. -.\" -.nh -.SH NAME -moc \- generate TQt meta object support code -.SH SYNOPSIS -.B moc -[-o file] [-i] [-f] [-k] [-ldbg] [-nw] [-p path] [-q path] [-v] file -.SH DESCRIPTION -This page documents the -.B Meta Object Compiler -for the TQt GUI application framework. The -.B moc -reads one or more C++ class declarations from a C++ header or source -file and generates one C++ source file containing meta object -information for the classes. The C++ source file generated by the -.B moc -must be compiled and linked with the implementation of the class (or it -can be #included into the class's source file). -.PP -If you use -.B qmake -to create your Makefiles, build rules will be included that call the -.B moc -when required, so you will not need to use the -.B moc -directly. -.PP -In brief, the meta object system is a structure used by TQt (see -.BR http://doc.trolltech.com ")" -for component programming and run time type information. It adds -properties and inheritance information to (some) classes and -provides a new type of communication between those instances of those -classes, signal-slot -connections. -.SH OPTIONS -.TP -.I "-o file" -Write output to -.I file -rather than to stdout. -.TP -.I -f -Force the generation of an #include statement in the output. -This is the default for files whose name matches the regular -expression .[hH][^.]* (i.e. the extension starts with -.B H -or -.B h -). This -option is only useful if you have header files that do not follow the -standard naming conventions. -.TP -.I "-i" -Do not generate an #include statement in the output. This may be used -to run -.B moc -on a C++ file containing one or more class declarations. You should then -#include the meta object code in the .cpp file (see USAGE below). If both -.I -f -and -.I -i -are present, the last one wins. -.TP -.I "-nw" -Do not generate any warnings. Not recommended. -.TP -.I "-ldbg" -Write a flood of lex debug information to stdout. -.TP -.I "-p path" -Makes -.B moc -prepend -.IR path / -to the file name in the generated #include statement (if one is generated). -.TP -.I "-q path" -Makes -.B moc -prepend -.IR path / -to the file name of qt #include files in the generated code. -.TP -.I "-v" -Displays the version of -.B moc -and Qt. -.PP -You can explicitly tell the -.B moc -not to parse parts of a header -file. It recognizes any C++ comment (//) that contains the substrings -MOC_SKIP_BEGIN or MOC_SKIP_END. They work as you would expect and you -can have several levels of them. The net result as seen by the -.B moc -is as if you had removed all lines between a MOC_SKIP_BEGIN and a -MOC_SKIP_END -.SH USAGE -.B moc -is almost always invoked by -.BR make (1), -not by hand. -.PP -.B moc -is typically used with an input file containing class declarations -like this: -.PP -.in +4 -.nf -class YourClass : public QObject { - TQ_OBJECT - TQ_PROPERTY( ... ) - TQ_CLASSINFO( ... ) - -public: - YourClass( QObject * parent=0, const char * name=0 ); - ~YourClass(); - -signals: - -public slots: - -}; -.fi -.in -4 -.PP -Here is a useful makefile rule if you only use GNU make: -.PP -.in +4 -.nf -m%.cpp: %.h - moc $< -o $@ -.fi -.in -4 -.PP -If you want to write portably, you can use individual rules of the -following form: -.PP -.in +4 -.nf -mNAME.cpp: NAME.h - moc $< -o $@ -.fi -.in -4 -.PP -You must also remember to add -.I mNAME.cpp -to your SOURCES (substitute your favorite name) variable and -.I mNAME.o -to your OBJECTS variable. -.PP -(While we prefer to name our C++ source files .cpp, the -.B moc -doesn't know that, so you can use .C, .cc, .CC, .cxx or even .c++ if -you prefer.) -.PP -If you have class declarations in C++ files, we recommend that you use -a makefile rule like this: -.PP -.in +4 -.nf -NAME.o: mNAME.cpp - -mNAME.cpp: NAME.cpp - moc -i $< -o $@ -.fi -.in -4 -.PP -This guarantees that -.BR make (1) -will run the -.B moc -before it compiles -.IR NAME.cpp . -You can then put -.PP -.ti +4 -#include "nNAME.cpp" -.PP -at the end of -.IR NAME.cpp , -where all the classes declared in that file are fully known. -.SH DIAGNOSTICS -Sometimes you may get linkage errors, saying that -YourClass::className() is undefined or that YourClass lacks a vtbl. -Those errors happen most often when you forget to compile the -moc-generated C++ code or include that object file in the link -command. -.PP -The -.B moc -will warn you about a number of dangerous or illegal constructs. -.SH BUGS - -The -.B moc -does not expand #include or #define, it simply skips any preprocessor -directives it encounters. This is regrettable, but is normally not a -problem in practice. - -The -.B moc -does not handle all of C++. The main problem is that class templates -cannot have signals or slots. This is an important bug. Here is an -example: -.PP -.in +4 -.nf -class SomeTemplate<int> : public QFrame { - TQ_OBJECT - .... -signals: - void bugInMocDetected( int ); -}; -.fi -.in -4 -.PP -Less importantly, the following constructs are illegal. All of them -have have alternatives which we think are usually better, so removing -these limitations is not a high priority for us. -.SS "Multiple inheritance requires QObject to be first." -If you are using multiple inheritance, -.B moc -assumes that the -.B first -inherited class is a subclass of QObject. Also, be sure that -.B only -the first inherited class is a QObject. -.PP -.in +4 -.nf -class SomeClass : public QObject, public OtherClass { - ... -}; -.fi -.in -4 -.PP -This bug is almost impossible to fix; since the -.B moc -does not expand -#include or #define, it cannot find out which one of the base classes is a -QObject. -.SS "Function pointers cannot be arguments to signals or slots." -In most cases where you would consider that, we think inheritance is a -better alternative. Here is an example of illegal syntax: -.PP -.in +4 -.nf -class SomeClass : public QObject { - TQ_OBJECT - ... -public slots: - // illegal - void apply( void (*apply)(List *, void *), void * ); -}; -.fi -.in -4 -.PP -You can work around this restriction like this: -.PP -.in +4 -.nf -typedef void (*ApplyFunctionType)( List *, void * ); - -class SomeClass : public QObject { - TQ_OBJECT - ... -public slots: - void apply( ApplyFunctionType, char * ); -}; -.fi -.in -4 -.PP -It may sometimes be even better to replace the function pointer with -inheritance and virtual functions, signals or slots. -.SS "Friend declarations cannot be placed in signals or slots sections" -Sometimes it will work, but in general, friend declarations cannot be -placed in -.B signals -or -.B slots -sections. Put them in the good old -.BR private ", " protected -or -.B public -sections instead. Here is an example of the illegal syntax: -.PP -.in +4 -.nf -class SomeClass : public QObject { - TQ_OBJECT - ... -signals: - friend class ClassTemplate<char>; // illegal -}; -.fi -.in -4 -.SS "Signals and slots cannot be upgraded" -The C++ feature of upgrading an inherited member function to -.B public -status is not extended to cover signals and slots. Here is an illegal -example: -.PP -.in +4 -.nf -class Whatever : public QButtonGroup { - ... -public slots: - QButtonGroup::buttonPressed; // illegal - ... -}; -.fi -.in -4 -.PP -The QButtonGroup::buttonPressed() slot is protected. -.PP -C++ quiz: What happens if you try to upgrade a protected member -function which is overloaded? -.IP -- All the functions are upgraded. -.IP -- That is not legal C++. -.\" Good idea, but look in the SEE ALSO section... -.SS "Type macros cannot be used for signal and slot arguments" - -Since the -.B moc -does not expand #define, type macros that take an argument -will not work in signals and slots. Here is an illegal example: -.PP -.in +4 -.nf -#ifdef ultrix -#define SIGNEDNESS(a) unsigned a -#else -#define SIGNEDNESS(a) a -#endif -class Whatever : public QObject { - ... -signals: - void someSignal( SIGNEDNESS(int) ); // illegal -}; -.PP -A #define without arguments works. -.fi -.in -4 -.SS "Nested classes cannot be in the signals or slots sections nor have signals or slots" -Here's an example: -.PP -.in +4 -.nf -class A { - TQ_OBJECT -public: - class B { - public slots: // illegal - void b(); - ... - }; -signals: - class B { // illegal - void b(); - ... - }: -}; -.fi -.in -4 -.PP -.SS "Constructors cannot be used in signals or slots sections" -It is a mystery to us why anyone would put a constructor on either the -.B signals -or -.B slots -sections. You can't, anyway (except that it happens to work in some -cases). Put them in -.BR private ", " protected -or -.B public -sections, where they belong. Here is an example of the illegal syntax: -.PP -.in +4 -.nf -class SomeClass : public QObject { - TQ_OBJECT -public slots: - SomeClass( QObject *parent, const char *name ) - : QObject( parent, name ) {} // illegal - ... -}; -.fi -.in -4 -.SS "Properties need to be declared before the public section that contains the respective get and set functions" -.PP -Declaring the first property within or after the public section that -contains the type definition and the respective get and set functions -does not work as expected. The -.B moc -will complain that it can neither -find the functions nor resolve the type. Here is an example of the -illegal syntax: -.PP -.in +4 -.nf -class SomeClass : public QObject { - TQ_OBJECT -public: - ... - // illegal - TQ_PROPERTY( Priority priority READ priority WRITE setPriority ) - TQ_ENUMS( Priority ) - enum Priority { High, Low, VeryHigh, VeryLow }; - void setPriority( Priority ); - Priority priority() const; - ... -}; -.fi -.in -4 -.PP -Work around this limitation by declaring all properties at the -beginning of the class declaration, right after TQ_OBJECT: -.PP -.in +4 -.nf -class SomeClass : public QObject { - TQ_OBJECT - TQ_PROPERTY( Priority priority READ priority WRITE setPriority ) - TQ_ENUMS( Priority ) -public: - ... - enum Priority { High, Low, VeryHigh, VeryLow }; - void setPriority( Priority ); - Priority priority() const; - ... -}; -.fi -.in -4 -.PP -.SH "SEE ALSO" -.BR http://www.trolltech.com ", " -.BR "C++ ARM, section r.11.3" " (for the answer to the quiz), and" -.BR http://doc.trolltech.com " (for complete TQt documentation)." |