Template:FunctionDeclaration: Difference between revisions

From Kolmafia
Jump to navigation Jump to search
No edit summary
Use question marks (?, a la TypeScript) instead of brackets for optional parameters. Brackets have a different meaning in ASH (maps), so using them for optional parameters was confusing.
 
(3 intermediate revisions by the same user not shown)
Line 3: Line 3:
   | <kbd><b>{{type|{{data|{{{name}}}|function{{{func}}}.return_type}}}} [[{{data|{{{name}}}|name}}]]({{
   | <kbd><b>{{type|{{data|{{{name}}}|function{{{func}}}.return_type}}}} [[{{data|{{{name}}}|name}}]]({{
     #if: {{data|{{{name}}}|function{{{func}}}.param1.type}}
     #if: {{data|{{{name}}}|function{{{func}}}.param1.type}}
     |&nbsp;{{param2|name={{{name}}}|func={{{func}}}|param=1|format={{{format}}}}}}}{{
     |&nbsp;{{param2|name={{{name}}}|func={{{func}}}|param=1|format={{{format}}}}}
  }}{{
     #if: {{data|{{{name}}}|function{{{func}}}.param2.type}}
     #if: {{data|{{{name}}}|function{{{func}}}.param2.type}}
     |, {{param2|name={{{name}}}|func={{{func}}}|param=2|format={{{format}}}}}}}{{
     |, {{param2|name={{{name}}}|func={{{func}}}|param=2|format={{{format}}}}}
  }}{{
     #if: {{data|{{{name}}}|function{{{func}}}.param3.type}}
     #if: {{data|{{{name}}}|function{{{func}}}.param3.type}}
     |, {{param2|name={{{name}}}|func={{{func}}}|param=3|format={{{format}}}}}}}{{
     |, {{param2|name={{{name}}}|func={{{func}}}|param=3|format={{{format}}}}}
  }}{{
     #if: {{data|{{{name}}}|function{{{func}}}.param4.type}}
     #if: {{data|{{{name}}}|function{{{func}}}.param4.type}}
     |, {{param2|name={{{name}}}|func={{{func}}}|param=4|format={{{format}}}}}}}{{
     |, {{param2|name={{{name}}}|func={{{func}}}|param=4|format={{{format}}}}}
  }}{{
     #if: {{data|{{{name}}}|function{{{func}}}.param5.type}}
     #if: {{data|{{{name}}}|function{{{func}}}.param5.type}}
     |, {{param2|name={{{name}}}|func={{{func}}}|param=5|format={{{format}}}}}}}{{
     |, {{param2|name={{{name}}}|func={{{func}}}|param=5|format={{{format}}}}}
  }}{{
     #if: {{data|{{{name}}}|function{{{func}}}.param1.type}}
     #if: {{data|{{{name}}}|function{{{func}}}.param1.type}}
     |&nbsp;}})</b></kbd>{{
     |&nbsp;}})</b></kbd>{{
       #if: {{{desc|}}}
       #if: {{{desc|}}}
       | <br>{{data|{{{name}}}|function{{{func}}}.description}}{{
       | :{{data|{{{name}}}|function{{{func}}}.description}}}}{{
      #if: {{{param_desc|}}}
      |{{
         #if: {{data|{{{name}}}|function{{{func}}}.param1.type}}
         #if: {{data|{{{name}}}|function{{{func}}}.param1.type}}
         | * {{pspan|{{data|{{{name}}}|function{{{func}}}.param1}}}}: {{data|{{{name}}}|function{{{func}}}.param1.description}}}}{{
         | :* {{pspan|{{data|{{{name}}}|function{{{func}}}.param1}}}}: {{data|{{{name}}}|function{{{func}}}.param1.description}}}}{{
         #if: {{data|{{{name}}}|function{{{func}}}.param2.type}}
         #if: {{data|{{{name}}}|function{{{func}}}.param2.type}}
         | * {{pspan|{{data|{{{name}}}|function{{{func}}}.param2}}}}: {{data|{{{name}}}|function{{{func}}}.param2.description}}}}{{
         | :* {{pspan|{{data|{{{name}}}|function{{{func}}}.param2}}}}: {{data|{{{name}}}|function{{{func}}}.param2.description}}}}{{
         #if: {{data|{{{name}}}|function{{{func}}}.param3.type}}
         #if: {{data|{{{name}}}|function{{{func}}}.param3.type}}
         | * {{pspan|{{data|{{{name}}}|function{{{func}}}.param3}}}}: {{data|{{{name}}}|function{{{func}}}.param3.description}}}}{{
         | :* {{pspan|{{data|{{{name}}}|function{{{func}}}.param3}}}}: {{data|{{{name}}}|function{{{func}}}.param3.description}}}}{{
         #if: {{data|{{{name}}}|function{{{func}}}.param4.type}}
         #if: {{data|{{{name}}}|function{{{func}}}.param4.type}}
         | * {{pspan|{{data|{{{name}}}|function{{{func}}}.param4}}}}: {{data|{{{name}}}|function{{{func}}}.param4.description}}}}{{
         | :* {{pspan|{{data|{{{name}}}|function{{{func}}}.param4}}}}: {{data|{{{name}}}|function{{{func}}}.param4.description}}}}{{
         #if: {{data|{{{name}}}|function{{{func}}}.param5.type}}
         #if: {{data|{{{name}}}|function{{{func}}}.param5.type}}
         | * {{pspan|{{data|{{{name}}}|function{{{func}}}.param5}}}}: {{data|{{{name}}}|function{{{func}}}.param5.description}}}}
         | :* {{pspan|{{data|{{{name}}}|function{{{func}}}.param5}}}}: {{data|{{{name}}}|function{{{func}}}.param5.description}}}}
     }}
     }}
   | {{error|Invalid function number (func &#61; "{{{func|}}}") in Template:FunctionDeclaration}}}}</includeonly><noinclude>
   | {{error|Invalid function number (func &#61; "{{{func|}}}") in Template:FunctionDeclaration}}}}</includeonly><noinclude>
Line 53: Line 60:
       "label": "Show descriptions?",
       "label": "Show descriptions?",
       "description": "If set to \"yes\", also show the description of each function and its parameters below the declaration. Technically, any non-empty string works, but please use \"yes\" for ease of maintenance.",
       "description": "If set to \"yes\", also show the description of each function and its parameters below the declaration. Technically, any non-empty string works, but please use \"yes\" for ease of maintenance.",
      "type": "line"
    },
    "param_desc": {
      "label": "Show parameter descriptions?",
      "description": "If set to \"yes\", also show the description of each function's parameters below the declaration. Technically, any non-empty string works, but please use \"yes\" for ease of maintenance.",
       "type": "line"
       "type": "line"
     }
     }
Line 79: Line 91:
| <pre>{{FunctionDeclaration|name=visit_url|func=2|desc=yes}}</pre>
| <pre>{{FunctionDeclaration|name=visit_url|func=2|desc=yes}}</pre>
| {{FunctionDeclaration|name=visit_url|func=2|desc=yes}}
| {{FunctionDeclaration|name=visit_url|func=2|desc=yes}}
|-
! colspan="2" | Normal format with description + parameter description
|-
| <pre>{{FunctionDeclaration|name=visit_url|func=1|desc=yes|param_desc=yes}}</pre>
| {{FunctionDeclaration|name=visit_url|func=1|desc=yes|param_desc=yes}}
|-
| <pre>{{FunctionDeclaration|name=visit_url|func=2|desc=yes|param_desc=yes}}</pre>
| {{FunctionDeclaration|name=visit_url|func=2|desc=yes|param_desc=yes}}
|-
|-
! colspan="2" | Signature format
! colspan="2" | Signature format
Line 96: Line 116:
| {{FunctionDeclaration|name=visit_url}}
| {{FunctionDeclaration|name=visit_url}}
|}
|}
[[Category:Basic Templates]]
</noinclude>
</noinclude>

Latest revision as of 14:22, 31 December 2020


Displays an ASH function's declaration. This is meant to be transcluded by other templates, rather than regular pages.

Template parameters[Edit template data]

ParameterDescriptionTypeStatus
Function page namename

Name of a function page. '''This must be a data page.'''

Page namerequired
Overloaded function numberfunc

A function page may describe multiple overloaded functions under the same name. This parameter allows you to select one. Allowed values are 1-5, inclusive.

Numberrequired
Rendering formatformat

"" (empty string) = show everything, "signature" = only show parameter types (i.e. function signature). Default value is empty string (show everything).

Lineoptional
Show descriptions?desc

If set to "yes", also show the description of each function and its parameters below the declaration. Technically, any non-empty string works, but please use "yes" for ease of maintenance.

Lineoptional
Show parameter descriptions?param_desc

If set to "yes", also show the description of each function's parameters below the declaration. Technically, any non-empty string works, but please use "yes" for ease of maintenance.

Lineoptional

Examples

Wiki markup Result
Normal format
{{FunctionDeclaration|name=visit_url|func=1}}
buffer visit_url()
{{FunctionDeclaration|name=visit_url|func=2}}
buffer visit_urlstring url, boolean? use_POST = true, boolean? encoded = false )
Normal format with description
{{FunctionDeclaration|name=visit_url|func=1|desc=yes}}
buffer visit_url()
Returns the original HTML source of the page being overridden inside a relay override script.
{{FunctionDeclaration|name=visit_url|func=2|desc=yes}}
buffer visit_urlstring url, boolean? use_POST = true, boolean? encoded = false )
Visits a web page and returns its HTML source.
Normal format with description + parameter description
{{FunctionDeclaration|name=visit_url|func=1|desc=yes|param_desc=yes}}
buffer visit_url()
Returns the original HTML source of the page being overridden inside a relay override script.
{{FunctionDeclaration|name=visit_url|func=2|desc=yes|param_desc=yes}}
buffer visit_urlstring url, boolean? use_POST = true, boolean? encoded = false )
Visits a web page and returns its HTML source.
  • url: URL of the page to visit. If a relative URL is provided, it is treated as an in-game page.
  • use_POST: If true, makes an HTTP POST request when visiting the URL. Otherwise, makes a GET request.
  • encoded: If true, KoLmafia assumes that url has already been URL-encoded and will not encode it.
Signature format
{{FunctionDeclaration|name=visit_url|func=2|format=signature}}
buffer visit_urlstring, boolean?, boolean? )
Invalid or missing function number
{{FunctionDeclaration|name=visit_url|func=4}}
Invalid function number (func = "4") in Template:FunctionDeclaration
{{FunctionDeclaration|name=visit_url|func=0}}
Invalid function number (func = "0") in Template:FunctionDeclaration
{{FunctionDeclaration|name=visit_url}}
Invalid function number (func = "") in Template:FunctionDeclaration