Help:ParserFunctions

From Homestar Runner Wiki

(Difference between revisions)
Jump to: navigation, search
m (User:Techgeekmbg/ParserFunctions moved to Help:ParserFunctions: User requested that this be moved to the help namespace / I think this will be very helpful.)
(#expr:: add modulo operator ; examples should be evaluated)
 
(includes 48 intermediate revisions)
Line 1: Line 1:
-
<div style="border-top:1px solid #aaa;background:#f4f4f4;border-bottom:1px solid #aaa;font-size:80%;line-height:110%;padding: 0.5em;margin-top:1.5em;margin-bottom:2em">This page is created as a future help page, before it goes into the Help namespace. If you have any ideas for this page, please tell me on the [[{{TALKPAGENAME}}|talk page]].</div>
+
This wiki has an extension installed called [[meta:Help:ParserFunctions|ParserFunctions]]. ParserFunctions are operators that take strings of text or numbers and perform logical or mathematical operators on them. They are often used in templates, to display current times and dates, and to generate random information. Here's how to use them:
-
 
+
-
This wiki has an extension installed, called [[meta:Help:ParserFunctions|ParserFunctions]]. Here's how to use them:
+
==#expr:==
==#expr:==
<tt><nowiki>{{#expr:}}</nowiki></tt> solves mathematical expressions. It only works with numerical entries; if you want to use strings, see [[#.23ifeq:|#ifeq]].
<tt><nowiki>{{#expr:}}</nowiki></tt> solves mathematical expressions. It only works with numerical entries; if you want to use strings, see [[#.23ifeq:|#ifeq]].
-
{| width="100%" border="5" cellspacing="2" cellpadding="2" style="font-size:15px;text-align:center;"
+
{| width="100%" border="1" cellspacing="0" cellpadding="5" style="border-collapse:collapse; font-size:15px; text-align:center;"
|- bgcolor="#FFFF00"
|- bgcolor="#FFFF00"
! width="33%" | Operator !! width="33%" | Operation !! width="33%" | Example
! width="33%" | Operator !! width="33%" | Operation !! width="33%" | Example
|-
|-
-
| () || Grouping operators || <nowiki>{{#expr: (10+20) / 30 }} = 1</nowiki>
+
| () || Grouping operators || <nowiki>{{#expr: (10+20) / 30 }} =</nowiki>{{#expr: (10+20) / 30 }}
 +
|-
 +
| + || Positive || <nowiki>{{#expr: +30 - +30 }} = </nowiki>{{#expr: +30 - +30 }}
|-
|-
-
| + || Positive || <nowiki>{{#expr: +30 - +30 }} = 0</nowiki>
+
| - || Negative || <nowiki>{{#expr: -30 + 30 }} = </nowiki>{{#expr: -30 + 30 }}
|-
|-
-
| - || Negative || <nowiki>{{#expr: -30 + 30 }} = 0</nowiki>
+
| not || Unary NOT, logical NOT || <nowiki>{{#expr: not 30 + 0}} = </nowiki>{{#expr: not 30 + 0}}
|-
|-
-
| not || Unary NOT, logical NOT || <nowiki>{{#expr: not 30 + 0}} = 0</nowiki>
+
| * || Multiplication || <nowiki>{{#expr: 30 * 0 }} = </nowiki>{{#expr: 30 * 0 }}
|-
|-
-
| * || Multiplication || <nowiki>{{#expr: 30 * 0 }} = 0</nowiki>
+
| / OR div|| Division || <nowiki>{{#expr: -30 / 30 }} = </nowiki>{{#expr: -30 / 30 }}<br /><nowiki>{{#expr: -30 div 30 }} = </nowiki>{{#expr: -30 div 30 }}
|-
|-
-
| / OR '''div'''|| Division || <nowiki>{{#expr: -30 / 30 }} = -1</nowiki><br /><nowiki>{{#expr: -30 div 30 }} = -1</nowiki>
+
| mod || {{w|Modulo}} || <nowiki>{{#expr: 121 mod 60}} = </nowiki>{{#expr: 121 mod 60}}<br /><nowiki>{{#expr: 119 mod 60}} = </nowiki>{{#expr: 119 mod 60}}
|-
|-
-
| + || Addition || <nowiki>{{#expr: -30 + 30 }} = 0</nowiki>
+
| + || Addition || <nowiki>{{#expr: -30 + 30 }} = </nowiki>{{#expr: -30 + 30 }}
|-
|-
-
| - || Subtraction || <nowiki>{{#expr: 30 - 30 }} = 0</nowiki>
+
| - || Subtraction || <nowiki>{{#expr: 30 - 30 }} = </nowiki>{{#expr: 30 - 30 }}
|-
|-
-
| round || Rounds off the number on the left to the power of 1/10 given on the right  || <nowiki>{{#expr: 24 / 49 round 4}} = 0.4898</nowiki><br /><nowiki>{{#expr: 24 / 49 round 2}} = 0.49</nowiki><br /><nowiki>{{#expr: 24 / 49 round 0}} = 0</nowiki><br />
+
| round || Rounds off the number on the left to the power of 1/10 given on the right  || <nowiki>{{#expr: 24 / 49 round 4}} = </nowiki>{{#expr: 24 / 49 round 4}}<br /><nowiki>{{#expr: 24 / 49 round 2}} = </nowiki>{{#expr: 24 / 49 round 2}}<br /><nowiki>{{#expr: 24 / 49 round 0}} = </nowiki>{{#expr: 24 / 49 round 0}}<br />
|-
|-
-
| = || Equality (will be 1 or 0) || <nowiki>{{#expr: 30 = 0 }} = 0</nowiki><br /><nowiki>{{#expr: 30 = 30 }} = 1</nowiki>
+
| = || Equality (will be 1 or 0) || <nowiki>{{#expr: 30 = 0 }} = </nowiki>{{#expr: 30 = 0 }}<br /><nowiki>{{#expr: 30 = 30 }} = </nowiki>{{#expr: 30 = 30 }}
|-
|-
-
| <> OR  != || Inequality  (will be 1 or 0)|| <nowiki>{{#expr: 30 <> 0 }} = 1</nowiki><br /><nowiki>{{#expr: 30 <> 30 }} = 0</nowiki><br /><nowiki>{{#expr: 30 != 0 }} = 1</nowiki><br /><nowiki>{{#expr: 30 != 30 }} = 0</nowiki>
+
| <> OR  != || Inequality  (will be 1 or 0)|| <nowiki>{{#expr: 30 <> 0 }} = </nowiki>{{#expr: 30 <> 0 }}<br /><nowiki>{{#expr: 30 <> 30 }} = </nowiki>{{#expr: 30 <> 30 }}<br /><nowiki>{{#expr: 30 != 0 }} = </nowiki>{{#expr: 30 != 0 }}<br /><nowiki>{{#expr: 30 != 30 }} = </nowiki>{{#expr: 30 != 30 }}
|-
|-
-
| < || Less Than (will be 1 or 0) || <nowiki>{{#expr: 30 < 0 }} = 0</nowiki>
+
| < || Less Than (will be 1 or 0) || <nowiki>{{#expr: 30 < 0 }} = </nowiki>{{#expr: 30 < 0 }}
|-
|-
-
| > || Greater Than (will be 1 or 0) || <nowiki>{{#expr: 30 > 0 }} = 1</nowiki>
+
| > || Greater Than (will be 1 or 0) || <nowiki>{{#expr: 30 > 0 }} = </nowiki>{{#expr: 30 > 0 }}
|-
|-
-
| >= || Greater Than or Equal To (will be 1 or 0) || <nowiki>{{#expr: 30 >= 0 }} = 1</nowiki>
+
| >= || Greater Than or Equal To (will be 1 or 0) || <nowiki>{{#expr: 30 >= 0 }} = </nowiki>{{#expr: 30 >= 0 }}
|-
|-
-
| <= || Less Than or Equal To (will be 1 or 0) || <nowiki>{{#expr: 30 <= 0 }} = 0</nowiki>
+
| <= || Less Than or Equal To (will be 1 or 0) || <nowiki>{{#expr: 30 <= 0 }} = </nowiki>{{#expr: 30 <= 0 }}
|}<br>
|}<br>
Line 62: Line 62:
*'''<nowiki>{{#ifeq: 7 | +000007.0 | Seven = Seven | Seven is not equal to Seven }}</nowiki>''' shows up as '''{{#ifeq: 7 | +000007.0 | Seven = Seven | Seven is not equal to Seven }}'''
*'''<nowiki>{{#ifeq: 7 | +000007.0 | Seven = Seven | Seven is not equal to Seven }}</nowiki>''' shows up as '''{{#ifeq: 7 | +000007.0 | Seven = Seven | Seven is not equal to Seven }}'''
-
In this above example, notice that #ifeq can treat numbers as well as strings.
+
In this above example, notice that <tt><nowiki>{{#ifeq:}}</nowiki></tt> can treat numbers as well as strings.
<tt><nowiki>{{#ifeq:}}</nowiki></tt> is case-sensitive:
<tt><nowiki>{{#ifeq:}}</nowiki></tt> is case-sensitive:
Line 85: Line 85:
Some examples:
Some examples:
-
*'''<nowiki>{{#ifexpr: 30 / 40 = 120 | yes | no }}</nowiki>''' returns '''{{#ifexpr: 30 / 40 = 120 | yes | no }}'''.
+
*'''<nowiki>{{#ifexpr: 7 + 8 = 15 | yes | no }}</nowiki>''' returns '''{{#ifexpr: 7 + 8 = 15 | yes | no }}'''.
-
*'''<nowiki>{{#ifexpr: {{PAGENAME}} = ParserFunctions |  This is a help page | No}}</nowiki>''' returns '''{{#ifexpr: {{PAGENAME}} = ParserFunctions |  This is a help page | No}}''' because "ParserFunctions" (the text returned by <nowiki>{{PAGENAME}}</nowiki>) is a string, not a number.
+
*'''<nowiki>{{#ifexpr: 7 + 8 = 78 | yes | no }}</nowiki>''' returns '''{{#ifexpr: 7 + 8 = 78 | yes | no }}'''.
 +
*'''<nowiki>{{#ifexpr: {{PAGENAME}} = ParserFunctions |  This is a help page | No}}</nowiki>''' returns the error '''{{#ifexpr: {{PAGENAME}} = ParserFunctions |  This is a help page | No}}''' because "ParserFunctions" (the text returned by <nowiki>{{PAGENAME}}</nowiki>) is a string, not a number.
==#switch:==
==#switch:==
Line 114: Line 115:
}}</pre>
}}</pre>
<nowiki><result 1> and <result 2> do not have equal signs, and if <value> matches either of them, the text corresponding to <result 3> will be returned.</nowiki>
<nowiki><result 1> and <result 2> do not have equal signs, and if <value> matches either of them, the text corresponding to <result 3> will be returned.</nowiki>
 +
 +
Example:
 +
<br />'''<nowiki>{{#switch: {{</nowiki>[[#.23rand:|#rand:]]<nowiki> 1|10}}</nowiki><br /><nowiki>
 +
|1</nowiki><br /><nowiki>
 +
|2</nowiki><br /><nowiki>
 +
|3</nowiki><br /><nowiki>
 +
|4</nowiki><br /><nowiki>
 +
|5= This number is 1-5</nowiki><br /><nowiki>
 +
|6= This number is 6</nowiki><br /><nowiki>
 +
|7= This number is not 8</nowiki><br /><nowiki>
 +
|8= This number is 1 more than 7</nowiki><br /><nowiki>
 +
|9</nowiki><br /><nowiki>
 +
|10= This is either 9 or 10</nowiki><br /><nowiki>
 +
}}</nowiki>'''
 +
 +
turns out as '''{{#switch: {{#rand:1|5}}
 +
|1
 +
|2
 +
|3
 +
|4
 +
|5= This number is 1-5
 +
|6= This number is 6
 +
|7= This number is not 8
 +
|8= This number is 1 more than 7
 +
|9
 +
|10= This is either 9 or 10
 +
}}'''.
==#time:==
==#time:==
Line 119: Line 147:
<tt><nowiki>{{#time:}}</nowiki></tt> is used for time and date formatting. It can be used to show the current time or day, or a set time or day in a certain format. Either way, here are the codes (following UTC):
<tt><nowiki>{{#time:}}</nowiki></tt> is used for time and date formatting. It can be used to show the current time or day, or a set time or day in a certain format. Either way, here are the codes (following UTC):
-
{| width="100%" border="5" cellspacing="2" cellpadding="2" style="font-size:15px;text-align:center;"
+
{| width="100%" border="1" cellspacing="0" cellpadding="5" style="border-collapse:collapse; font-size:15px; text-align:center;"
|- bgcolor="#FFFF00"
|- bgcolor="#FFFF00"
! width="25%" | Code !! width="25%" | What it is !! width="25%" | Possible results !! width="25%" | Currently
! width="25%" | Code !! width="25%" | What it is !! width="25%" | Possible results !! width="25%" | Currently
Line 141: Line 169:
| d || Day of the month, with leading 0 || 01-31 || {{#time: d }}
| d || Day of the month, with leading 0 || 01-31 || {{#time: d }}
|-
|-
-
| z || Day of the year || 1-364, 365 on a leap year || {{#time: z }}
+
| z || Day of the year || 0-364, 365 on a leap year || {{#time: z }}
|-
|-
| D || Day of the week, abbreviated || Mon-Sun || {{#time: D }}
| D || Day of the week, abbreviated || Mon-Sun || {{#time: D }}
Line 149: Line 177:
| N || ISO 8601 day of the week || 1 (Monday) - 7 (Sunday) || {{#time: N }}
| N || ISO 8601 day of the week || 1 (Monday) - 7 (Sunday) || {{#time: N }}
|-
|-
-
| w || American day of the week || 0 (Monday - 6 (Sunday) || {{#time: w }}
+
| w || American day of the week || 0 (Sunday) - 6 (Saturday) || {{#time: w }}
|-
|-
| a || am or pm (lowercase) || am-pm || {{#time: a }}
| a || am or pm (lowercase) || am-pm || {{#time: a }}
Line 180: Line 208:
*'''<nowiki>{{#time: l Y-m-d }}</nowiki>''' generates '''{{#time: l Y-m-d }}'''.
*'''<nowiki>{{#time: l Y-m-d }}</nowiki>''' generates '''{{#time: l Y-m-d }}'''.
*'''<nowiki>{{#time: l }}</nowiki>''' generates '''{{#time: l }}'''.
*'''<nowiki>{{#time: l }}</nowiki>''' generates '''{{#time: l }}'''.
-
*'''<nowiki>{{#time: z | 20071031}}</nowiki>''' generates '''{{#time: z | 20071031 }}''', Halloween day in "z" format
+
*'''<nowiki>{{#time: z | 20071031}}</nowiki>''' generates '''{{#time: z | 20071031 }}''', Halloween in "z" format
==#rand:==
==#rand:==
-
<tt><nowiki>{{#rand:}}</nowiki></tt> generates a random integer. It has been deprecated in current versions of ParserFunctions, but the Homestar Runner Wiki currently uses an older version that still includes <tt><nowiki>{{#rand:}}</nowiki></tt>. Syntax:
+
<tt><nowiki>{{#rand:}}</nowiki></tt> generates a random integer. (It has been discontinued in standard versions of ParserFunctions, but the Homestar Runner Wiki uses a custom version that includes <tt><nowiki>{{#rand:}}</nowiki></tt>.) Syntax:
<pre>{{#rand: <minimum> | <maximum> }}</pre>
<pre>{{#rand: <minimum> | <maximum> }}</pre>
-
The minimum is the smallest ineteger it can generate, the maximum is the largest.  
+
The minimum is the smallest integer it can generate, the maximum is the largest.  
Examples:
Examples:
Line 196: Line 224:
*'''<nowiki>{{#rand: -10 | -1 }}</nowiki>''' generates '''{{#rand: -10 | -1 }}'''.
*'''<nowiki>{{#rand: -10 | -1 }}</nowiki>''' generates '''{{#rand: -10 | -1 }}'''.
*'''<nowiki>{{#rand: .1 | .9 }}</nowiki>''' generates '''{{#rand: .1 | .9 }}''', because it rounds the magnitude of the input down to the nearest integer (in this example, both the minimum and maximum values are '''0''').
*'''<nowiki>{{#rand: .1 | .9 }}</nowiki>''' generates '''{{#rand: .1 | .9 }}''', because it rounds the magnitude of the input down to the nearest integer (in this example, both the minimum and maximum values are '''0''').
 +
 +
==#count:==
 +
<tt><nowiki>{{#count:}}</nowiki></tt> is a parser function that returns an integer that increments each time the function is called. 
 +
 +
:''For more information please read the [[HRWiki:Counter|Counter help page]].''
 +
 +
==#var:==
 +
<tt><nowiki>{{#var:}}</nowiki></tt> is a parser function that allows text to be stored and retrieved.
 +
 +
To set a variable's value use <tt><nowiki>{{#setvar:}}</nowiki></tt>. Syntax:
 +
<pre>{{#setvar: <variable name> | <new value>}}</pre>
 +
This will overwrite any previous value that may have been set.  It ''does not'' return a value.  To retrieve a variable's value use <tt><nowiki>{{#var:}}</nowiki></tt>. Syntax:
 +
<pre>{{#var: <variable name>}}</pre>
 +
This replaces the text of the function with the actual text of the variable.
 +
 +
A variable may be conditionally initialized using <tt><nowiki>{{#if:}}</nowiki></tt>, <tt><nowiki>{{#var:}}</nowiki></tt> and <tt><nowiki>{{#setvar:}}</nowiki></tt>. Syntax:
 +
<pre>{{#if: {{#var: <variable name>}}||{{#setvar: <variable name>|<new value>}}}}</pre>
 +
 +
An example (the following lines produce this result when entered in order):
 +
*'''<nowiki>{{#var: help_Variable_Test}}</nowiki>''' returns '''<nowiki></nowiki>{{#var: help_Variable_Test}}''' nothing (an empty string) because the variable has not been set.
 +
*'''<nowiki>{{#if: {{#var: help_Variable_Test}}||{{#setvar: help_Variable_Test|Initialized}}}}{{#var: help_Variable_Test}}</nowiki>''' returns '''{{#if: {{#var: help_Variable_Test}}||{{#setvar: help_Variable_Test|Initialized}}}}{{#var: help_Variable_Test}}'''.
 +
*'''<nowiki>{{#var: help_Variable_Test}}</nowiki>''' still returns '''{{#var: help_Variable_Test}}'''.
 +
*'''<nowiki>{{#setvar: help_Variable_Test|New Value}}{{#var: help_Variable_Test}}</nowiki>''' returns '''{{#setvar: help_Variable_Test|New Value}}{{#var: help_Variable_Test}}'''.
 +
*'''<nowiki>{{#if: {{#var: help_Variable_Test}}||{{#setvar: help_Variable_Test|Initialized}}}}{{#var: help_Variable_Test}}</nowiki>''' still returns '''{{#if: {{#var: help_Variable_Test}}||{{#setvar: help_Variable_Test|Initialized}}}}{{#var: help_Variable_Test}}''' since the variable was already initialized.
 +
 +
==#urlformat:==
 +
<tt><nowiki>{{#urlformat:}}</nowiki></tt> is a parser function that formats text to be used in a link to the official site.
 +
 +
<pre>{{#urlformat: <text> }}</pre>
 +
 +
* <code>text</code> {{--}} ''Optional'' (''default:'' the name of the page on which the parser function [or a containing template] is placed).
 +
 +
The function makes the following conversions (in order):
 +
 +
* All multiple space is collapsed to single spaces and trimmed off the ends.
 +
* The disambiguation "(toon)" is ignored at the end of the text.
 +
* The text is converted to lowercase.
 +
* Anything that is not a letter, number, underscore, or space is removed.
 +
* Spaces and underscores are converted to hyphens. (Consecutive spaces or underscores are converted to a single hyphen.)
 +
 +
The function currently has one special case: <code><nowiki>{{#urlformat:bottom 10}}</nowiki></code> returns <code>{{#urlformat:bottom 10}}</code> (with a hyphen at the end) because the official site erroneously includes one in the URL.
 +
 +
This function was built to accommodate [[Strong Bad Emails]] but may be useful for other toons too. To make a valid link, other elements such a path or a number may be necessary.
 +
 +
Please note any oddities or requests on the talk page.
 +
 +
Some examples:
 +
 +
* '''<nowiki>{{#urlformat:</nowiki> {{sbemail|1}}<nowiki>}} </nowiki>''' generates '''{{#urlformat:{{sbemail|1}}}}'''.
 +
* '''<nowiki>{{#urlformat:</nowiki> {{sbemail|133}}<nowiki>}} </nowiki>''' generates '''{{#urlformat:{{sbemail|133}}}}''' (see special case above).
 +
* '''<nowiki>{{#urlformat:</nowiki> {{sbemail|145}}<nowiki>}} </nowiki>''' generates '''{{#urlformat:{{sbemail|145}}}}'''.
 +
* '''<nowiki>{{#urlformat: Cheat Commandos (toon) }}</nowiki>''' generates '''{{#urlformat:Cheat Commandos (toon)}}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
* '''<nowiki>{{#urlformat:}}</nowiki>''' generates '''{{#urlformat:{{sbemail|1}}}}''' if the parser function (or a containing template) is placed on the [[{{sbemail|1}}]] page.
 +
* '''<nowiki>{{#urlformat:}}</nowiki>''' generates '''{{#urlformat:{{sbemail|133}}}}''' if the parser function (or a containing template) is placed on the [[{{sbemail|133}}]] page.
 +
* '''<nowiki>{{#urlformat:}}</nowiki>''' generates '''{{#urlformat:{{sbemail|145}}}}''' if the parser function (or a containing template) is placed on the [[{{sbemail|145}}]] page.
 +
* '''<nowiki>{{#urlformat:}}</nowiki>''' generates '''{{#urlformat:Cheat Commandos (toon)}}''' if the parser function (or a containing template) is placed on the [[Cheat Commandos (toon)]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
* '''<nowiki>[[HR:sbemails/1-{{#urlformat:</nowiki> {{sbemail|1}} <nowiki>}}]]</nowiki>''' generates [[HR:sbemails/1-{{#urlformat:{{sbemail|1}}}}]].
 +
* '''<nowiki>[[HR:sbemails/50-{{#urlformat:</nowiki> {{sbemail|50} }<nowiki>}}]]</nowiki>''' generates [[HR:sbemails/50-{{#urlformat:{{sbemail|50}}}}]].
 +
* '''<nowiki>[[HR:sbemails/145-{{#urlformat:</nowiki> {{sbemail|145}} <nowiki>}}]]</nowiki>''' generates [[HR:sbemails/145-{{#urlformat:{{sbemail|145}}}}]].
 +
* '''<nowiki>[[HR:toons/{{#urlformat: Cheat Commandos (toon) }}]]</nowiki>''' generates [[HR:toons/{{#urlformat:Cheat Commandos (toon)}}]].
 +
<hr style="width:1200px; margin: 1em 0;">
 +
* '''<nowiki>[[HR:sbemails/1-{{#urlformat:}}]]</nowiki>''' generates [[HR:sbemails/1-{{#urlformat:{{sbemail|1}}}}]] if the parser function (or a containing template) is placed on the [[{{sbemail|1}}]] page.
 +
* '''<nowiki>[[HR:sbemails/50-{{#urlformat:}}]]</nowiki>''' generates [[HR:sbemails/50-{{#urlformat:{{sbemail|50}}}}]] if the parser function (or a containing template) is placed on the [[{{sbemail|50}}]] page.
 +
* '''<nowiki>[[HR:sbemails/145-{{#urlformat:}}]]</nowiki>''' generates [[HR:sbemails/145-{{#urlformat:{{sbemail|145}}}}]] if the parser function (or a containing template) is placed on the [[{{sbemail|145}}]] page.
 +
* '''<nowiki>[[HR:toons/{{#urlformat:}}]]</nowiki>''' generates [[HR:toons/{{#urlformat:Cheat Commandos (toon)}}]] if the parser function (or a containing template) is placed on the [[Cheat Commandos (toon)]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
 +
==#navlist:==
 +
 +
<tt><nowiki>{{#navlist:}}</nowiki></tt> looks up a value from a list on a template and returns a value from the list, usually the next or previous value in the list, for use in navigation templates.
 +
 +
<pre>{{#navlist: <template name> | <action> | <lookup value> | <flag> }}</pre>
 +
 +
* <code>template name</code> {{--}} Must be a name of a valid wiki template (<code>Template:</code> prefix not necessary). A malformed template name or nonexistent template will cause an error.
 +
* <code>action</code> {{--}} ''Optional'' (''default:'' <code>0</code>). Can be <code>next</code>, <code>prev</code>, <code>first</code>, <code>last</code>, <code>size</code>, an integer, or <code>#</code> (literal number sign).
 +
* <code>lookup value</code> (''action not ''<code>#</code>) {{--}} ''Not case sensitive; optional'' (''default:'' the name of the page on which the parser function [or a containing template] is placed). If specified, must be a valid list item. If not specified, the name of the page on which the parser function (or a containing template) is placed must be a valid list item.
 +
* <code>lookup value</code> (''action ''<code>#</code>) {{--}} Must be an integer.
 +
* <code>flag</code> {{--}} ''Optional'' (''default:'' no flag). Can be <code>target</code>, <code>pipe</code>, or <code>#</code> (literal number sign).
 +
 +
=== Action ===
 +
 +
* <code>next</code> or <code>1</code> or <code>+1</code> returns the value in the list immediately after the lookup value. If there is no value after the lookup value, it returns the first value in the list.
 +
* <code>prev</code> or <code>-1</code> returns the value in the list immediately before the lookup value. If there is no value before the lookup value, it returns the last value in the list.
 +
* <code>first</code> returns the first value in the list. In this case the lookup value has no effect.
 +
* <code>last</code> returns the last value in the list. In this case the lookup value has no effect.
 +
* <code>size</code> returns the total number of items in the list. In this case the lookup value and flags have no effect.
 +
* <code>''n''</code> or <code>+''n''</code> returns the ''n''th item after the lookup value (converted to an integer, ''limit:'' 1000). If it reaches the end of the list, it will wrap around to the beginning.
 +
* <code>-''n''</code> returns the ''n''th item before the lookup value (converted to an integer, ''limit:'' -1000). If it reaches the beginning of the list, it will wrap around to the end.
 +
* <code>0</code> or a numeric value that converts to 0 returns the lookup value itself.
 +
* <code>#</code> (literal number sign) with required lookup value integer <code>''n''</code> returns the ''n''th item in the list (converted to an integer, ''limit:'' ±1000). Lookup value <code>0</code> returns the last item in the list. The list repeats backward and forward to accommodate a negative lookup value or a lookup value greater than the size of the list (lookup value <code>-1</code> returns the next-to-last item in the list; lookup value <code><total size + 1></code> returns the first item in the list; etc.).
 +
* An invalid action or a numeric value that's out of range returns an error.
 +
 +
=== Flag ===
 +
Refer to the template setup below.
 +
 +
* <code>#</code> (literal number sign) returns the order in the list (index) of the lookup value.
 +
* Otherwise, if no pipe or no return value, then the flags below have no effect. The function returns the page name.
 +
* A pipe with a return value and:
 +
** no flag (or unrecognized flag) returns the return value.
 +
** <code>target</code> returns the page name.
 +
** <code>pipe</code> returns "Page name|Return value".
 +
 +
=== Template setup ===
 +
 +
The template should consist of a simple bulleted list. A template without a list will cause an error. Each item in the list must potentially be a valid wiki title (although it doesn't necessarily have to be a valid wiki ''page''). Do not use brackets. Any invalid characters in the page name portion of a list item will cause an error.
 +
 +
A pipe can be used to return a value other than the page name.
 +
 +
The template can have other paragraphs or explanatory text. Only list items (wherever they appear outside <code><nowiki><noinclude></nowiki></code> sections) are parsed.
 +
 +
<pre>
 +
* List of
 +
* Page
 +
* Names
 +
* Page name | Return value
 +
 +
<noinclude>
 +
 +
Explanatory text.
 +
 +
* This list
 +
* Will NOT be included
 +
 +
</noinclude>
 +
</pre>
 +
 +
=== Examples ===
 +
 +
The '''{{t|charnav-lookup}}''' template contains the following list:
 +
 +
<div class="pre_with_template">{{raw:Template:charnav-lookup}}</div>
 +
 +
*'''<nowiki>{{#navlist: charnav-lookup | next | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | next }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Homestar Runner }}''' if the parser function (or a containing template) is placed on the [[Homestar Runner]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | prev | Strong Bad }}</nowiki>''' generates '''{{#navlist: charnav-lookup | prev | Strong Bad }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | prev }}</nowiki>''' generates '''{{#navlist: charnav-lookup | prev | Strong Bad }}''' if the parser function (or a containing template) is placed on the [[Strong Bad]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | next | Homsar }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Homsar }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | next }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Homsar }}''' if the parser function (or a containing template) is placed on the [[Homsar]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | prev | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | prev | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | prev }}</nowiki>''' generates '''{{#navlist: charnav-lookup | prev | Homestar Runner }}''' if the parser function (or a containing template) is placed on the [[Homestar Runner]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | +2 | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | +2 | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | 2.9 | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | 2.9 | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | -2 | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | -2 | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | 954 | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | 954 | Homestar Runner }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | 0 | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | 0 | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | Homestar Runner }}''' if the parser function (or a containing template) is placed on the [[Homestar Runner]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: Template:charnav-lookup | next | Homestar Runner }}</nowiki>''' generates '''{{#navlist: Template:charnav-lookup | next | Homestar Runner }}'''. (Using the <code>Template:</code> prefix is valid.)
 +
*'''<nowiki>{{#navlist: not-a-real-tempate | next | Homestar Runner }}</nowiki>''' generates '''{{#navlist: not-a-real-template | next | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav | next | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav | next | Homestar Runner }}'''. (Note that {{t|charnav}} is a valid template but doesn't contain a list.)
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | invalid | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | invalid | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | 10000 | Homestar Runner }}</nowiki>''' generates '''{{#navlist: charnav-lookup | 10000 | Homestar Runner }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | next | Not in the List }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Not in the List }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | next }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next }}''' if the parser function (or a containing template) is not placed on a page in the list.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | first }}</nowiki>''' generates '''{{#navlist: charnav-lookup | first }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | first }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | first | Homestar Runner }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | 1 }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | 1 }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | last }}</nowiki>''' generates '''{{#navlist: charnav-lookup | last }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | last }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | last }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | 0 }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | 0 }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | 5 }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | 5 }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | -5 }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | -5 }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | 500 }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | 500 }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | 5000 }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | 5000 }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # | five }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # | five }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | # }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | 0 | Homestar Runner | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | 0 | Homestar Runner | # }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | | Homestar Runner | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | Homestar Runner | # }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | | | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | Homestar Runner | # }}''' if the parser function (or a containing template) is placed on the [[Homestar Runner]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | next | Homestar Runner | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Homestar Runner | # }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | next | | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | next | Homestar Runner | # }}''' if the parser function (or a containing template) is placed on the [[Homestar Runner]] page.
 +
*'''<nowiki>{{#navlist: charnav-lookup | prev | Homestar Runner | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | prev | Homestar Runner | # }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | prev | | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | prev | Homestar Runner | # }}''' if the parser function (or a containing template) is placed on the [[Homestar Runner]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | | Pom Pom | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | Pom Pom | # }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | | the king of town | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | the king of town | # }}'''.
 +
*'''<nowiki>{{#navlist: charnav-lookup | | Not in the List | # }}</nowiki>''' generates '''{{#navlist: charnav-lookup | | Not in the List | # }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: charnav-lookup | size }}</nowiki>''' generates '''{{#navlist: charnav-lookup | size }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
 +
The '''{{t|hrenav-lookup}}''' template contains the following list:
 +
 +
<div class="pre_with_template">{{raw:Template:hrenav-lookup}}</div>
 +
*'''<nowiki>{{#navlist: hrenav-lookup | prev | Hremail 49 }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | prev | Hremail 49 }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | prev | Hremail 49 | target }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | prev | Hremail 49 | target }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>[[{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}]]</nowiki>''' generates '''<nowiki>[[</nowiki>{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}<nowiki>]]</nowiki>''', which generates the piped link '''[[{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}]]'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: hrenav-lookup | prev | }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | prev | Hremail 49 }}''' if the parser function (or a containing template) is placed on the [[Hremail 49]] page.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | prev | | target }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | prev | Hremail 49 | target }}''' if the parser function (or a containing template) is placed on the [[Hremail 49]] page.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | prev | | pipe }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}''' if the parser function (or a containing template) is placed on the [[Hremail 49]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: hrenav-lookup | next | Hremail 49 }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | next | Hremail 49 }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | next | Hremail 49 | target }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | next | Hremail 49 | target }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: hrenav-lookup | next | }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | next | Hremail 49 }}''' if the parser function (or a containing template) is placed on the [[Hremail 49]] page.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | next | | target }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | next | Hremail 49 | target }}''' if the parser function (or a containing template) is placed on the [[Hremail 49]] page.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | next | | pipe }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}''' if the parser function (or a containing template) is placed on the [[Hremail 49]] page.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>[[{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}]]</nowiki>''' generates '''<nowiki>[[</nowiki>{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}<nowiki>]]</nowiki>''', which generates the regular link '''[[{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}]]''' because there is no pipe.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>{{#navlist: hrenav-lookup | # | last }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | # | last }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | # | 6 }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | # | 6 }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | # | 6 | target }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | # | 6 | target }}'''.
 +
*'''<nowiki>{{#navlist: hrenav-lookup | # | 6 | pipe }}</nowiki>''' generates '''{{#navlist: hrenav-lookup | # | 6 | pipe }}'''.
 +
<hr style="width:1200px; margin: 1em 0;">
 +
*'''<nowiki>[[{{#navlist: hrenav-lookup | # | 6 | pipe }}]]</nowiki>''' generates '''<nowiki>[[</nowiki>{{#navlist: hrenav-lookup | # | 6 | pipe }}<nowiki>]]</nowiki>''', which  generates the piped link '''[[{{#navlist: hrenav-lookup | # | 6 | pipe }}]]'''.
 +
<hr style="width:1200px; margin: 1em 0;">
==See Also==
==See Also==
-
[[meta:Help:Parserfunctions|Meta's page on ParserFunctions]]
+
*[[meta:Help:ParserFunctions|Meta's page on ParserFunctions]]
 +
*{{pl|l=https://www.mediawiki.org/wiki/Special:MyLanguage/Help:Parser_functions_in_templates Parser functions in templates}}
[[Category:Help|{{PAGENAME}}]]
[[Category:Help|{{PAGENAME}}]]

Current revision as of 22:19, 1 January 2025

This wiki has an extension installed called ParserFunctions. ParserFunctions are operators that take strings of text or numbers and perform logical or mathematical operators on them. They are often used in templates, to display current times and dates, and to generate random information. Here's how to use them:

Contents

[edit] #expr:

{{#expr:}} solves mathematical expressions. It only works with numerical entries; if you want to use strings, see #ifeq.

Operator Operation Example
() Grouping operators {{#expr: (10+20) / 30 }} =1
+ Positive {{#expr: +30 - +30 }} = 0
- Negative {{#expr: -30 + 30 }} = 0
not Unary NOT, logical NOT {{#expr: not 30 + 0}} = 0
* Multiplication {{#expr: 30 * 0 }} = 0
/ OR div Division {{#expr: -30 / 30 }} = -1
{{#expr: -30 div 30 }} = -1
mod Modulo {{#expr: 121 mod 60}} = 1
{{#expr: 119 mod 60}} = 59
+ Addition {{#expr: -30 + 30 }} = 0
- Subtraction {{#expr: 30 - 30 }} = 0
round Rounds off the number on the left to the power of 1/10 given on the right {{#expr: 24 / 49 round 4}} = 0.4898
{{#expr: 24 / 49 round 2}} = 0.49
{{#expr: 24 / 49 round 0}} = 0
= Equality (will be 1 or 0) {{#expr: 30 = 0 }} = 0
{{#expr: 30 = 30 }} = 1
<> OR  != Inequality (will be 1 or 0) {{#expr: 30 <> 0 }} = 1
{{#expr: 30 <> 30 }} = 0
{{#expr: 30 != 0 }} = 1
{{#expr: 30 != 30 }} = 0
< Less Than (will be 1 or 0) {{#expr: 30 < 0 }} = 0
> Greater Than (will be 1 or 0) {{#expr: 30 > 0 }} = 1
>= Greater Than or Equal To (will be 1 or 0) {{#expr: 30 >= 0 }} = 1
<= Less Than or Equal To (will be 1 or 0) {{#expr: 30 <= 0 }} = 0

[edit] #if:

The {{#if:}} function is an if-then-else system. If the condition string is empty, it returns the "else text". If it is not empty, it returns the "then text". The syntax is:

{{#if: <condition string> | <then text> | <else text> }}

Its most common usage is in templates, where if the user defines a parameter, then it returns some prescribed text. If the user does not specify the parameter, it returns a default. Example:

{{#if: {{{parameter|}}} | Parameter is defined | Parameter is not defined }}

If the user types {{templatename|parameter=true}} or something similar, the result is "Parameter is defined". However, if they type {{templatename}}, the result is "Parameter is not defined". Note in the above example that the expression is a special function that returns the value of the parameter if it has been defined and returns the text to the right of the vertical bar (|) if the parameter has not been defined.

{{#if:}} does not solve expressions. For example, if you type {{#if: 30 - 30 = 50 | 1 | 0 }}, the result will be 1, since 30 - 30 = 50 is not empty. If you want to do if-then-else using expressions, see #ifexpr.

[edit] #ifeq:

{{#ifeq:}} compares two strings and then performs an if-then-else process. To use:

{{#ifeq: <text 1> | <text 2> | <if equal> | <if not equal> }}

If text 1 and text 2 are equal, then it returns the <ifequal> text. Otherwise, it returns the <ifnotequal> text.

Some examples:

  • {{#ifeq: {{NAMESPACE}} | Help | This page is in the Help Namespace | This page is not in the Help Namespace }} shows up as This page is in the Help Namespace.
  • {{#ifeq: 7 | +000007.0 | Seven = Seven | Seven is not equal to Seven }} shows up as Seven = Seven

In this above example, notice that {{#ifeq:}} can treat numbers as well as strings.

{{#ifeq:}} is case-sensitive:

{{#ifeq: capital | Capital | Equal | Not Equal }} shows up as Not Equal.

[edit] #ifexist:

{{#ifexist:}} performs an if-then-else process depending on whether a page exists. Syntax:

{{#ifexist: <page name> | <if exists> | <if does not exist> }}

{{#ifexist:}} does not work with interwiki links.

Example:

{{#ifexist: sbemail | [[Strong Bad Email]] | [[Main Page]] }} returns Strong Bad Email because a page named "sbemail" does exist.

[edit] #ifexpr:

{{#ifexpr:}} is an if-then-else routine that, like {{#expr:}}, can only be used with numbers. Syntax:

{{#ifexpr: <expression> | <if true> | <if false> }}

Some examples:

  • {{#ifexpr: 7 + 8 = 15 | yes | no }} returns yes.
  • {{#ifexpr: 7 + 8 = 78 | yes | no }} returns no.
  • {{#ifexpr: {{PAGENAME}} = ParserFunctions | This is a help page | No}} returns the error Expression error: Unrecognised word "parserfunctions" because "ParserFunctions" (the text returned by {{PAGENAME}}) is a string, not a number.

[edit] #switch:

{{#switch:}} compares a number or a string against many items, and returns a result corresponding to the item it matches. Syntax:

{{#switch: <value>
| <result 1> = <text if 1 is true>
| <result 2> = <text if 2 is true>
| <result 3> = <text if 3 is true>
| <result 4> = <text if 4 is true>
| #default = <default value if none are true>
}}

If <value> matches <result 2>, for example, <text if 2 is true> will be returned by the function. If <value> does not match any of the first four items, <default value if none are true> will be returned.

"| <result n> = <text if n is true>" can be repeated as many times as necessary. However, "#default" can only be used once.

It is also possible to have "fall-through":

{{#switch: <value>
| <result 1>
| <result 2>
| <result 3> = <text if 1, 2, or 3 is true>
| <result 4> = <text if 4 is true>
| #default = <default value if none are true>
}}

<result 1> and <result 2> do not have equal signs, and if <value> matches either of them, the text corresponding to <result 3> will be returned.

Example:
{{#switch: {{#rand: 1|10}}
|1
|2
|3
|4
|5= This number is 1-5
|6= This number is 6
|7= This number is not 8
|8= This number is 1 more than 7
|9
|10= This is either 9 or 10
}}

turns out as This number is 1-5.

[edit] #time:

{{#time:}} is used for time and date formatting. It can be used to show the current time or day, or a set time or day in a certain format. Either way, here are the codes (following UTC):

Code What it is Possible results Currently
Y 4 digit year 1970-2038 2025
y 2 digit year 00-99 25
n Month number 1-12 10
m Month number, with leading 0 01-12 10
M Month name, abbreviated Jan-Dec Oct
F Full month name January-December October
W Current week of the year 1-52 or 53, depending on year 43
j Day of the month 1-31 24
d Day of the month, with leading 0 01-31 24
z Day of the year 0-364, 365 on a leap year 296
D Day of the week, abbreviated Mon-Sun Fri
l Full day of the week Monday-Sunday Friday
N ISO 8601 day of the week 1 (Monday) - 7 (Sunday) 5
w American day of the week 0 (Sunday) - 6 (Saturday) 5
a am or pm (lowercase) am-pm am
A AM or PM (capital) AM-PM AM
g 12 hour format of the hour 1-12 8
h 12 hour format of the hour, with leading 0 01-12 08
G 24 hour format of the hour 0-23 8
H 24 hour format of the hour, with leading 0 00-23 08
i The minute 00-59 30
s The second 00-59 14
U Seconds since Midnight on January 1, 1970 0-∞ 1761294614
L Whether it's a leap year 0 if not, 1 if yes 0
t Days in the month 28-31 31

If any input other than those discussed above is provided, it will pass through the function unmodified. So, links and punctuation can be easily used with this function. Examples:

  • {{#time: l j F Y }} generates Friday 24 October 2025.
  • {{#time: m/Y }} generates 10/2025.
  • {{#time: H:i | - 6 hours}} generates 02:30, 6 hours before the current time
  • {{#time: l Y-m-d }} generates Friday 2025-10-24.
  • {{#time: l }} generates Friday.
  • {{#time: z | 20071031}} generates 303, Halloween in "z" format

[edit] #rand:

{{#rand:}} generates a random integer. (It has been discontinued in standard versions of ParserFunctions, but the Homestar Runner Wiki uses a custom version that includes {{#rand:}}.) Syntax:

{{#rand: <minimum> | <maximum> }}

The minimum is the smallest integer it can generate, the maximum is the largest.

Examples:

  • {{#rand: 1 | 50 }} generates 1.
  • {{#rand: 1 | 500000 }} generates 62505.
  • {{#rand: -10 | -1 }} generates -5.
  • {{#rand: .1 | .9 }} generates 0, because it rounds the magnitude of the input down to the nearest integer (in this example, both the minimum and maximum values are 0).

[edit] #count:

{{#count:}} is a parser function that returns an integer that increments each time the function is called.

For more information please read the Counter help page.

[edit] #var:

{{#var:}} is a parser function that allows text to be stored and retrieved.

To set a variable's value use {{#setvar:}}. Syntax:

{{#setvar: <variable name> | <new value>}}

This will overwrite any previous value that may have been set. It does not return a value. To retrieve a variable's value use {{#var:}}. Syntax:

{{#var: <variable name>}}

This replaces the text of the function with the actual text of the variable.

A variable may be conditionally initialized using {{#if:}}, {{#var:}} and {{#setvar:}}. Syntax:

{{#if: {{#var: <variable name>}}||{{#setvar: <variable name>|<new value>}}}}

An example (the following lines produce this result when entered in order):

  • {{#var: help_Variable_Test}} returns nothing (an empty string) because the variable has not been set.
  • {{#if: {{#var: help_Variable_Test}}||{{#setvar: help_Variable_Test|Initialized}}}}{{#var: help_Variable_Test}} returns Initialized.
  • {{#var: help_Variable_Test}} still returns Initialized.
  • {{#setvar: help_Variable_Test|New Value}}{{#var: help_Variable_Test}} returns New Value.
  • {{#if: {{#var: help_Variable_Test}}||{{#setvar: help_Variable_Test|Initialized}}}}{{#var: help_Variable_Test}} still returns New Value since the variable was already initialized.

[edit] #urlformat:

{{#urlformat:}} is a parser function that formats text to be used in a link to the official site.

{{#urlformat: <text> }}
  • textOptional (default: the name of the page on which the parser function [or a containing template] is placed).

The function makes the following conversions (in order):

  • All multiple space is collapsed to single spaces and trimmed off the ends.
  • The disambiguation "(toon)" is ignored at the end of the text.
  • The text is converted to lowercase.
  • Anything that is not a letter, number, underscore, or space is removed.
  • Spaces and underscores are converted to hyphens. (Consecutive spaces or underscores are converted to a single hyphen.)

The function currently has one special case: {{#urlformat:bottom 10}} returns bottom-10- (with a hyphen at the end) because the official site erroneously includes one in the URL.

This function was built to accommodate Strong Bad Emails but may be useful for other toons too. To make a valid link, other elements such a path or a number may be necessary.

Please note any oddities or requests on the talk page.

Some examples:

  • {{#urlformat: some kinda robot}} generates some-kinda-robot.
  • {{#urlformat: bottom 10}} generates bottom-10- (see special case above).
  • {{#urlformat: myths & legends}} generates myths-legends.
  • {{#urlformat: Cheat Commandos (toon) }} generates cheat-commandos.

  • {{#urlformat:}} generates some-kinda-robot if the parser function (or a containing template) is placed on the some kinda robot page.
  • {{#urlformat:}} generates bottom-10- if the parser function (or a containing template) is placed on the bottom 10 page.
  • {{#urlformat:}} generates myths-legends if the parser function (or a containing template) is placed on the myths & legends page.
  • {{#urlformat:}} generates cheat-commandos if the parser function (or a containing template) is placed on the Cheat Commandos (toon) page.



[edit] #navlist:

{{#navlist:}} looks up a value from a list on a template and returns a value from the list, usually the next or previous value in the list, for use in navigation templates.

{{#navlist: <template name> | <action> | <lookup value> | <flag> }}
  • template name — Must be a name of a valid wiki template (Template: prefix not necessary). A malformed template name or nonexistent template will cause an error.
  • actionOptional (default: 0). Can be next, prev, first, last, size, an integer, or # (literal number sign).
  • lookup value (action not #) — Not case sensitive; optional (default: the name of the page on which the parser function [or a containing template] is placed). If specified, must be a valid list item. If not specified, the name of the page on which the parser function (or a containing template) is placed must be a valid list item.
  • lookup value (action #) — Must be an integer.
  • flagOptional (default: no flag). Can be target, pipe, or # (literal number sign).

[edit] Action

  • next or 1 or +1 returns the value in the list immediately after the lookup value. If there is no value after the lookup value, it returns the first value in the list.
  • prev or -1 returns the value in the list immediately before the lookup value. If there is no value before the lookup value, it returns the last value in the list.
  • first returns the first value in the list. In this case the lookup value has no effect.
  • last returns the last value in the list. In this case the lookup value has no effect.
  • size returns the total number of items in the list. In this case the lookup value and flags have no effect.
  • n or +n returns the nth item after the lookup value (converted to an integer, limit: 1000). If it reaches the end of the list, it will wrap around to the beginning.
  • -n returns the nth item before the lookup value (converted to an integer, limit: -1000). If it reaches the beginning of the list, it will wrap around to the end.
  • 0 or a numeric value that converts to 0 returns the lookup value itself.
  • # (literal number sign) with required lookup value integer n returns the nth item in the list (converted to an integer, limit: ±1000). Lookup value 0 returns the last item in the list. The list repeats backward and forward to accommodate a negative lookup value or a lookup value greater than the size of the list (lookup value -1 returns the next-to-last item in the list; lookup value <total size + 1> returns the first item in the list; etc.).
  • An invalid action or a numeric value that's out of range returns an error.

[edit] Flag

Refer to the template setup below.

  • # (literal number sign) returns the order in the list (index) of the lookup value.
  • Otherwise, if no pipe or no return value, then the flags below have no effect. The function returns the page name.
  • A pipe with a return value and:
    • no flag (or unrecognized flag) returns the return value.
    • target returns the page name.
    • pipe returns "Page name|Return value".

[edit] Template setup

The template should consist of a simple bulleted list. A template without a list will cause an error. Each item in the list must potentially be a valid wiki title (although it doesn't necessarily have to be a valid wiki page). Do not use brackets. Any invalid characters in the page name portion of a list item will cause an error.

A pipe can be used to return a value other than the page name.

The template can have other paragraphs or explanatory text. Only list items (wherever they appear outside <noinclude> sections) are parsed.

* List of
* Page
* Names
* Page name | Return value

<noinclude>

Explanatory text.

* This list
* Will NOT be included

</noinclude>

[edit] Examples

The {{charnav-lookup}} template contains the following list:

  • Homestar Runner
  • Strong Bad
  • The Cheat
  • Strong Mad
  • Strong Sad
  • Pom Pom
  • Marzipan
  • Coach Z
  • Bubs
  • The King of Town
  • The Poopsmith
  • Homsar
  • {{#navlist: charnav-lookup | next | Homestar Runner }} generates Strong Bad.
  • {{#navlist: charnav-lookup | next }} generates Strong Bad if the parser function (or a containing template) is placed on the Homestar Runner page.

  • {{#navlist: charnav-lookup | prev | Strong Bad }} generates Homestar Runner.
  • {{#navlist: charnav-lookup | prev }} generates Homestar Runner if the parser function (or a containing template) is placed on the Strong Bad page.

  • {{#navlist: charnav-lookup | next | Homsar }} generates Homestar Runner.
  • {{#navlist: charnav-lookup | next }} generates Homestar Runner if the parser function (or a containing template) is placed on the Homsar page.

  • {{#navlist: charnav-lookup | prev | Homestar Runner }} generates Homsar.
  • {{#navlist: charnav-lookup | prev }} generates Homsar if the parser function (or a containing template) is placed on the Homestar Runner page.

  • {{#navlist: charnav-lookup | +2 | Homestar Runner }} generates The Cheat.
  • {{#navlist: charnav-lookup | 2.9 | Homestar Runner }} generates The Cheat.
  • {{#navlist: charnav-lookup | -2 | Homestar Runner }} generates The Poopsmith.
  • {{#navlist: charnav-lookup | 954 | Homestar Runner }} generates Marzipan.

  • {{#navlist: charnav-lookup | 0 | Homestar Runner }} generates Homestar Runner.
  • {{#navlist: charnav-lookup | | Homestar Runner }} generates Homestar Runner.
  • {{#navlist: charnav-lookup }} generates Homestar Runner if the parser function (or a containing template) is placed on the Homestar Runner page.

  • {{#navlist: Template:charnav-lookup | next | Homestar Runner }} generates Strong Bad. (Using the Template: prefix is valid.)
  • {{#navlist: not-a-real-tempate | next | Homestar Runner }} generates INVALID TEMPLATE NAME.
  • {{#navlist: charnav | next | Homestar Runner }} generates INVALID LIST. (Note that {{charnav}} is a valid template but doesn't contain a list.)

  • {{#navlist: charnav-lookup | invalid | Homestar Runner }} generates INVALID ACTION.
  • {{#navlist: charnav-lookup | 10000 | Homestar Runner }} generates ACTION OFFSET OUT OF RANGE.

  • {{#navlist: charnav-lookup | next | Not in the List }} generates INVALID LOOKUP VALUE.
  • {{#navlist: charnav-lookup | next }} generates INVALID LOOKUP VALUE if the parser function (or a containing template) is not placed on a page in the list.

  • {{#navlist: charnav-lookup | first }} generates Homestar Runner.
  • {{#navlist: charnav-lookup | # | first }} generates Homestar Runner.
  • {{#navlist: charnav-lookup | # | 1 }} generates Homestar Runner.

  • {{#navlist: charnav-lookup | last }} generates Homsar.
  • {{#navlist: charnav-lookup | # | last }} generates Homsar.
  • {{#navlist: charnav-lookup | # | 0 }} generates Homsar.

  • {{#navlist: charnav-lookup | # | 5 }} generates Strong Sad.
  • {{#navlist: charnav-lookup | # | -5 }} generates Marzipan.
  • {{#navlist: charnav-lookup | # | 500 }} generates Coach Z.
  • {{#navlist: charnav-lookup | # | 5000 }} generates INDEX OUT OF RANGE.
  • {{#navlist: charnav-lookup | # | five }} generates INVALID INDEX.
  • {{#navlist: charnav-lookup | # }} generates INVALID INDEX.

  • {{#navlist: charnav-lookup | 0 | Homestar Runner | # }} generates 1.
  • {{#navlist: charnav-lookup | | Homestar Runner | # }} generates 1.
  • {{#navlist: charnav-lookup | | | # }} generates 1 if the parser function (or a containing template) is placed on the Homestar Runner page.

  • {{#navlist: charnav-lookup | next | Homestar Runner | # }} generates 2.
  • {{#navlist: charnav-lookup | next | | # }} generates 2 if the parser function (or a containing template) is placed on the Homestar Runner page.
  • {{#navlist: charnav-lookup | prev | Homestar Runner | # }} generates 12.
  • {{#navlist: charnav-lookup | prev | | # }} generates 12 if the parser function (or a containing template) is placed on the Homestar Runner page.

  • {{#navlist: charnav-lookup | | Pom Pom | # }} generates 6.
  • {{#navlist: charnav-lookup | | the king of town | # }} generates 10.
  • {{#navlist: charnav-lookup | | Not in the List | # }} generates INVALID LOOKUP VALUE.

  • {{#navlist: charnav-lookup | size }} generates 12.

The {{hrenav-lookup}} template contains the following list:

  • Hremail 49
  • Hremail 24
  • Hremail 62
  • Hremail 2000
  • Hremail 7
  • hremail 3184 | Hremail 3184
  • {{#navlist: hrenav-lookup | prev | Hremail 49 }} generates Hremail 3184.
  • {{#navlist: hrenav-lookup | prev | Hremail 49 | target }} generates hremail 3184.
  • {{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }} generates hremail 3184|Hremail 3184.

  • [[{{#navlist: hrenav-lookup | prev | Hremail 49 | pipe }}]] generates [[hremail 3184|Hremail 3184]], which generates the piped link Hremail 3184.

  • {{#navlist: hrenav-lookup | prev | }} generates Hremail 3184 if the parser function (or a containing template) is placed on the Hremail 49 page.
  • {{#navlist: hrenav-lookup | prev | | target }} generates hremail 3184 if the parser function (or a containing template) is placed on the Hremail 49 page.
  • {{#navlist: hrenav-lookup | prev | | pipe }} generates hremail 3184|Hremail 3184 if the parser function (or a containing template) is placed on the Hremail 49 page.

  • {{#navlist: hrenav-lookup | next | Hremail 49 }} generates Hremail 24.
  • {{#navlist: hrenav-lookup | next | Hremail 49 | target }} generates Hremail 24.
  • {{#navlist: hrenav-lookup | next | Hremail 49 | pipe }} generates Hremail 24.

  • {{#navlist: hrenav-lookup | next | }} generates Hremail 24 if the parser function (or a containing template) is placed on the Hremail 49 page.
  • {{#navlist: hrenav-lookup | next | | target }} generates Hremail 24 if the parser function (or a containing template) is placed on the Hremail 49 page.
  • {{#navlist: hrenav-lookup | next | | pipe }} generates Hremail 24 if the parser function (or a containing template) is placed on the Hremail 49 page.

  • [[{{#navlist: hrenav-lookup | next | Hremail 49 | pipe }}]] generates [[Hremail 24]], which generates the regular link Hremail 24 because there is no pipe.

  • {{#navlist: hrenav-lookup | # | last }} generates Hremail 3184.
  • {{#navlist: hrenav-lookup | # | 6 }} generates Hremail 3184.
  • {{#navlist: hrenav-lookup | # | 6 | target }} generates hremail 3184.
  • {{#navlist: hrenav-lookup | # | 6 | pipe }} generates hremail 3184|Hremail 3184.

  • [[{{#navlist: hrenav-lookup | # | 6 | pipe }}]] generates [[hremail 3184|Hremail 3184]], which generates the piped link Hremail 3184.

[edit] See Also

Personal tools