Difference between revisions of "Template:FunctionDeclaration"

From Kolmafia
Jump to navigation Jump to search
Line 1: Line 1:
 
<includeonly><kbd><b>{{{return_type}}} {{{name}}}({{
 
<includeonly><kbd><b>{{{return_type}}} {{{name}}}({{
 
   #if: {{{param1|}}}
 
   #if: {{{param1|}}}
   |{{#if: {{{param1.optional|}}}|<nowiki>[</nowiki>}}&nbsp;{{param|{{{param1.type}}}|{{{param1}}}}}{{
+
   |{{#if: {{{param1.optional|}}}|&nbsp;<nowiki>[</nowiki>}}&nbsp;{{param|{{{param1.type}}}|{{{param1}}}}}{{
 
   #if: {{{param1.default|}}}| &#61; {{{param1.default|}}}&nbsp;}}{{
 
   #if: {{{param1.default|}}}| &#61; {{{param1.default|}}}&nbsp;}}{{
 
   #if: {{{param1.optional|}}}|<nowiki>]</nowiki>&nbsp;}}
 
   #if: {{{param1.optional|}}}|<nowiki>]</nowiki>&nbsp;}}
Line 162: Line 162:
 
|param1=url
 
|param1=url
 
|param1.type=string
 
|param1.type=string
|param1.optional=y
+
|param1.optional=yes
 
|param2=use_POST
 
|param2=use_POST
 
|param2.type=boolean
 
|param2.type=boolean

Revision as of 18:22, 18 December 2020


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

Template parameters

ParameterDescriptionTypeStatus
Parameter 1 nameparam1

Name of parameter 1 (and so on for parameters 2 through 5)

Lineoptional
Parameter 1 typeparam1.type

Parameter 1 data type

Example
string
Lineoptional
Parameter 1 is optional?param1.optional

"yes" = optional. Any non-empty string will do, but please use "yes" to make standardization easier.

Example
yes
Stringoptional
Parameter 1 default valueparam1.default

If this is specified, param1.optional must be "yes"

Lineoptional

Examples

No arguments

{{User:Philmasterplus/FunctionDeclaration
|name=my_id
|return_type=int
}}

int my_id()

Single argument

{{User:Philmasterplus/FunctionDeclaration
|name=to_item
|return_type=int
|param1=it
|param1.type=item
}}

int to_item( item it )

Multiple arguments

{{User:Philmasterplus/FunctionDeclaration
|name=maximize
|return_type=record [int]
|param1=expression
|param1.type=string
|param2=max_price
|param2.type=int
|param3=price_level
|param3.type=int
|param4=simulate
|param4.type=boolean
|param5=include_equip
|param5.type=boolean
}}

record [int] maximize( string expression , int max_price , int price_level , boolean simulate , boolean include_equip )

Optional arguments

{{User:Philmasterplus/FunctionDeclaration
|name=creatable_turns
|return_type=int
|param1=check_me
|param1.type=item
|param2=qty
|param2.type=int
|param2.optional=yes
|param3=free
|param3.type=boolean
|param3.optional=yes
}}

int creatable_turns( item check_me [, int qty  ] [, boolean free  ] )

Default arguments

{{User:Philmasterplus/FunctionDeclaration
|name=visit_url
|return_type=buffer
|param1=url
|param1.type=string
|param2=use_POST
|param2.type=boolean
|param2.optional=yes
|param2.default=true
|param3=encoded
|param3.type=boolean
|param3.optional=yes
|param3.default=false
}}

buffer visit_url( [ string url  ] [, boolean use_POST  = true ] [, boolean encoded  = false ] [, boolean encoded  = true ] )