The three virtues of a programmer: Laziness, Impatience, and Hubris. – Larry Wall
Difference between revisions of "Template:Infobox class"
m (Protected "Template:Infobox class": high-risk template [edit=sysop:move=sysop]) |
m (added parameter to signal whether it's a dedicated class description page or an inline class description) |
||
Line 26: | Line 26: | ||
| notoc = {{{notoc|}}} | | notoc = {{{notoc|}}} | ||
| nocat = {{#ifeq:{{ARTICLESPACE}}|Template|1|{{{nocat|}}}}} | | nocat = {{#ifeq:{{ARTICLESPACE}}|Template|1|{{{nocat|}}}}} | ||
+ | | inline = {{#ifeq:{{ARTICLESPACE}}|Template|1|{{{class|}}}}} | ||
}}<noinclude> | }}<noinclude> | ||
{{documentation}} | {{documentation}} | ||
</noinclude> | </noinclude> |
Revision as of 00:33, 1 August 2009
Template:Template | [[Template:{{{cp10}}}|{{{cp10}}}]] >> [[Template:{{{cp9}}}|{{{cp9}}}]] >> [[Template:{{{cp8}}}|{{{cp8}}}]] >> [[Template:{{{cp7}}}|{{{cp7}}}]] >> [[Template:{{{cp6}}}|{{{cp6}}}]] >> [[Template:{{{cp5}}}|{{{cp5}}}]] >> [[Template:{{{cp4}}}|{{{cp4}}}]] >> [[Template:{{{cp3}}}|{{{cp3}}}]] >> [[Template:{{{cp2}}}|{{{cp2}}}]] >> [[Template:{{{cp1}}}|{{{cp1}}}]] >> Infobox_class |
Contents
- Within class:
- [[Template:{{{cw}}}|{{{cw}}}]]
- Implemented interfaces:
- , [[Template:{{{i6}}}|{{{i6}}}]], [[Template:{{{i7}}}|{{{i7}}}]][[Template:{{{ci1}}}|{{{ci1}}}]], [[Template:{{{ci2}}}|{{{ci2}}}]], [[Template:{{{ci3}}}|{{{ci3}}}]], [[Template:{{{ci4}}}|{{{ci4}}}]], [[Template:{{{ci5}}}|{{{ci5}}}]], [[Template:{{{ci6}}}|{{{ci6}}}]], [[Template:{{{ci7}}}|{{{ci7}}}]]
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.)