I don't need to test my programs. I have an error-correcting modem.
Difference between revisions of "Template:Infobox class"
m (added more interface slots) |
m (added support for custom parent classes, within class and implemented interfaces) |
||
Line 26: | Line 26: | ||
| i7 = {{{interface7|}}} | | i7 = {{{interface7|}}} | ||
| custom = {{{custom|}}} | | custom = {{{custom|}}} | ||
+ | | cw = {{{customwithin|}}} | ||
+ | | cp1 = {{{customparent1|{{{customparent|}}}}}} | ||
+ | | cp2 = {{{customparent2|}}} | ||
+ | | cp3 = {{{customparent3|}}} | ||
+ | | cp4 = {{{customparent4|}}} | ||
+ | | cp5 = {{{customparent5|}}} | ||
+ | | cp6 = {{{customparent6|}}} | ||
+ | | cp7 = {{{customparent7|}}} | ||
+ | | cp8 = {{{customparent8|}}} | ||
+ | | cp9 = {{{customparent9|}}} | ||
+ | | cp10= {{{customparent10|}}} | ||
+ | | ci1 = {{{custominterface1|{{{custominterface|}}}}}} | ||
+ | | ci2 = {{{custominterface2|}}} | ||
+ | | ci3 = {{{custominterface3|}}} | ||
+ | | ci4 = {{{custominterface4|}}} | ||
+ | | ci5 = {{{custominterface5|}}} | ||
+ | | ci6 = {{{custominterface6|}}} | ||
+ | | ci7 = {{{custominterface7|}}} | ||
| notoc = {{{notoc|}}} | | notoc = {{{notoc|}}} | ||
| nocat = {{#ifeq:{{ARTICLESPACE}}|Template|1|{{{nocat|}}}}} | | nocat = {{#ifeq:{{ARTICLESPACE}}|Template|1|{{{nocat|}}}}} |
Latest revision as of 06:31, 17 March 2010
Template:Template | Infobox_class |
Contents
This template provides an info box for a class. The info box can contain relevant information like parent classes, implemented interfaces or the within class.
Usage
Example:
{{Infobox class | class = UTCheatManager | package = UTGame | within = PlayerController | game = UT3 | engine = UE3 | parent1 = CheatManager | parent2 = Object }}
Object >> CheatManager >> UTCheatManager |
- Package:
- UTGame
- Within class:
- PlayerController
- This class in other games:
- UT3, UDK
If class, game or engine are missing, they are derived from the current page name. (You can see this effect in the default output on the template page.) Engine and game are only used for linking pages and categories.
The classes and interfaces in the within, parentx and interfacex parameters are automatically linked. The list of parent classes should always be given as complete as possible. For Actor-derived classes the list should start with the Actor class, otherwise it should start with the Object class. Up to ten parent classes can be specified, but if the list gets too long, consider cutting it off at a "well-known" class, like in the following example:
{{infobox class | class = UIComp_DrawImage | package = Engine | within = UIObject | interface1 = UIStyleResolver | interface2 = CustomPropertyItemHandler | game = UT3 | engine = UE3 | parent1 = UIComp_DrawComponents | parent2 = UIComponent | parent3 = Component }}
Component >> UIComponent >> UIComp_DrawComponents >> UIComp_DrawImage |
- Package:
- Engine
- Within class:
- UIObject
- Implemented interfaces:
- UIStyleResolver, CustomPropertyItemHandler
- Direct subclasses:
- UIComp_DrawTeamColoredImage, UIComp_UTDrawStateImage
- This class in other games:
- UT3, UDK
Classes implementing one or more interfaces will automatically be added to relevant categories, which are also linked from the corresponding interface page if it contains an interface infobox.
You can also specify custom parent classes via customparentx instead of parentx, which will create the link based on the current page name and namespace instead of the engine and game name:
{{infobox class | class = CustomClass | customparent1 = CustomParent | parent2 = Actor | parent3 = Object | engine = | custom = yes }}
Object >> Actor >> CustomParent >> CustomClass (custom) |
Note how CustomParent links to the Template: namespace in this example, even though "engine=" makes the regular parent classes link to the main namespace. If the class description resides in a subpage, custom parents link to subpages of the same base page. (You can see this behavior by viewing this page, Template:Infobox class/doc, directly.)