Template:If/doc: Difference between revisions

From Katawa Shoujo Wiki
imported>TheWallflower00
Created page with "{{Documentation subpage}}<includeonly>{{pp-template|small=yes}}</includeonly> With this template the parser functions of the [[mw:Help:Extension:Pars..."
 
imported>TheWallflower00
No edit summary
Line 1: Line 1:
{{Documentation subpage}}<includeonly>{{pp-template|small=yes}}</includeonly>
{{Notification
 
|bgcolor=#FF9933
With this template the [[Help:parser function|parser functions]] of the [[mw:Help:Extension:ParserFunctions|ParserFunctions]] collection with names starting with "#if" can be used in a way such that they do not [[m:Help:Newlines_and_spaces#Stripping_on_expansion|strip spaces and newlines]] from the "then" and "else" part. Spaces still do not affect the outcome of the condition. Parameter 1 selects the if-type as "eq", "expr", "exist" or "error" (for #iferror), or empty "||" for a simple if-there (for #if). The template can be repeatedly nested 6 or 7 levels, one inside the other, because the outer-most is completed before running either the then/else inner levels.
|image=Kenji.png|250px
 
|message='''This page has been accused of conspiring with the feminists!<br>Reason: {{{1|not specified}}}'''<br>If you believe this accusation is false, please voice your opinions on [[{{TALKPAGENAME}}|the talk page]] of this article, or on [[{{SITENAME}}:Administrators|an admin's talk page]]}}
This template can be substituted, when the expression or comparison will not change. Functionally, a lead-space character is stored, internally, as a simple blank character. Note, in many cases a null nowiki tag ("&lt;nowiki/>") could be used, without [[Template:If]], to allow a lead-space (such as "&lt;nowiki/>&nbsp;xx") anywhere, but the internal storage puts a 43-character marker for "&lt;nowiki/>" in string length. However, there is no extra expansion depth for a nowiki-tag, such as in trailing space, "zz&nbsp;&lt;nowiki/>".
<includeonly>[[Category:Candidates for deletion]]</includeonly><noinclude>
 
{{documentation}}</noinclude>
==Usage==
'''Where p is implemented in affirmation of the statement and q is implemented in negation of the statement'''
 
*<nowiki>{{if||x| p | q }}</nowiki> gives "{{if||x| p | q }}". Notice the ''pair'' of vertical bars surrounding the empty first parameter.
 
*<nowiki>{{if|expr|2<3| p | q }}</nowiki> gives " p "
*<nowiki>{{if|eq| u |u| p | q }}</nowiki> gives "{{if|eq| u |u| p | q }}"
*<nowiki>{{if|exist| Help:Link | p | q }}</nowiki> gives "{{if|exist| Help:Link | p | q }}"
*<nowiki>{{if|error|{{#expr:x}}| p | q }}</nowiki> gives "{{if|error|{{#expr:x}}| p | q }}"
 
Compare:
*<nowiki>{{#if:x| p | q }}</nowiki> gives "{{#if:x| p | q }}"
*<nowiki>{{#ifexpr:2<3| p | q }}</nowiki> gives "{{#ifexpr:2<3| p | q }}"
*<nowiki>{{#ifeq: u |u| p | q }}</nowiki> gives "{{#ifeq: u |u| p | q }}"
*<nowiki>{{#ifexist: Help:Link | p | q }}</nowiki> gives "{{#ifexist: Help:Link | p | q }}"
*<nowiki>{{#iferror:{{#expr:x}}| p | q }}</nowiki> gives "{{#iferror:{{#expr:x}}| p | q }}"
The text of either the then-clause or else-clause is only processed and expanded when triggered. Hence, any templates in use are only expanded once the then-clause or else-clause is matched, otherwise they are skipped as merely paired braces, "&#123;&#123;" with "}}".
 
'''Indentation:''' If indenting the markup, care must be taken to avoid extra newlines when indenting "}}" on the next line. An extra bar pipe "|" can be added after the else-clause to complete that text, and allow "}}" to then be placed anywhere without adding a newline into the else-clause. For example:
:::* <nowiki>{{if|{{{1|}}}</nowiki><br>&nbsp; &nbsp; |then found parameter 1|else no parameter 1| &larr; ''extra'' "|" ''ends else-clause''<br>}}
When the else-clause is indented to the next line, a newline (CR/LF) is added:
:::* <nowiki>{{if|{{{1|}}}</nowiki><br>&nbsp; &nbsp; |then found parameter 1 &larr; ''extra newline here''<br>&nbsp; &nbsp; |else noparameter 1|<br>}}
To indent the else-clause, split an [[HTML]]-form comment, as "&lt;!--" with next line as "--&gt;|else...". Unless each then-clause and else-clause is carefully tested, to watch for extra newlines, then the results are likely to cause broken lines, with extra line breaks for each newline. For that reason, a global edit with simple search-and-replace of "<code>{#if:</code>" to "<code>{if||</code>" is likely to leave newline problems, wherever the original markup was wrapped to indent either the else-clause or "}}" of each if-structure. Indenting the then-clause is not a problem.
 
==Performance considerations==
Because [[Template:If]] must prepare the parameters for <code>#if, #ifeq, #ifexpr,</code> (etc.) there is a slight overhead when using it. It has been timed to run at speeds of 290 instances per second, so 29 uses would take only 0.1&nbsp;s, a tenth of a second to run, to make 29 comparisons. Each nested use adds 5 levels to the template expansion depth, so 7 nested if-templates would use 35 levels (5*7) of the 41-level limit.
 
'''Using P-if syntax:''' A similar if-structure can be coded without '''Template:If''', by using the {P1} and {P2} templates in a "P-if" structure. [[Template:P1]] always returns parameter 1, and P2 returns the 2nd. So, a comparison of 4 versus 3 can be coded using P-if syntax form:
:: Example of <code>#ifexpr</code>: <nowiki>"{{P{{#ifexpr: 4 > 3|1|2}}| then 4 greater| else 4 lower}}"</nowiki>
:: Result for <code>#ifexpr</code>: &nbsp; "{{P{{#ifexpr: 4 > 3|1|2}}| then 4 greater| else 4 lower}}" &larr; ''the comparison invoked'' {<nowiki/>{P1}}.
The expansion depth of a P-if is only 4 levels deep, but nesting of the then-clause or else-clause might be more confusing than using nested levels of Template:if.
 
:: Example of <code>#if</code>: <nowiki>"{{P{{#if:{{{2|x}}}|1|2}}| then {2} set| else {2} empty}}"</nowiki>
:: Result for <code>#if</code>: "{{P{{#if:{{{2|}}}|1|2}}| then {2} set| else {2} empty}}" &larr; ''the comparison invoked'' {<nowiki/>{P2}}.
 
==See also==
*[[m:Template:If]]
*[[Template:Ifnotempty]] - for simplicity and to reduce the limitations due to the expansion depth limit, this is a separate template corresponding to #if only.
*[[Template:Switch]], for a default result
 
<includeonly>
[[Category:If-then-else templates]]
 
</includeonly>

Revision as of 17:04, 27 January 2017

This page has been accused of conspiring with the feminists!
Reason: not specified

If you believe this accusation is false, please voice your opinions on the talk page of this article, or on an admin's talk page


Template documentation (for the above template, sometimes hidden or invisible)

Visit Template:If/doc/doc to edit this text! (How does this work?)