Template:BSLfuncinfo: Difference between revisions

From OniGalore
(working on comma/parens fix)
(replaced Pipe template with built-in {{!}} magic word)
 
(76 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<includeonly>{|
<includeonly>{{Anchor|{{{name|placeholder}}}}}
!<!--"type" label, OS icons, "default" label-->
{| class="BSLFuncInfo"
!<!--func type, name, default return value-->
!<!--arg 1 type, name, default value-->
!<!--arg 2 type, name, default value-->
!<!--arg 3 type, name, default value-->
!<!--arg 4 type, name, default value-->
|-
|-
|type:
|{{{type|}}}<!--
|{{{type|}}}
-->{{#if:{{{arg1name|}}}|<br />
|align="center"|{{{arg1type|}}} {{#if:{{{arg1alttype|}}}|<u>or</u> {{{arg1alttype|}}}}} {{#if:{{{arg1optional|}}}|(optional)|}}
{{!}}align="center"{{!}}{{#if:{{{arg1optional|}}}|''|}}{{{arg1type|}}} {{#if:{{{arg1alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg1alttype|}}}}}|<br />
|align="center"|{{{arg2type|}}} {{#if:{{{arg2alttype|}}}|<u>or</u> {{{arg2alttype|}}}}} {{#if:{{{arg2optional|}}}|(optional)|}}
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}<!--
|align="center"|{{{arg3type|}}} {{#if:{{{arg3alttype|}}}|<u>or</u> {{{arg3alttype|}}}}} {{#if:{{{arg3optional|}}}|(optional)|}}
-->{{#if:{{{arg2name|}}}|<br />
|align="center"|{{{arg4type|}}} {{#if:{{{arg4alttype|}}}|<u>or</u> {{{arg4alttype|}}}}} {{#if:{{{arg4optional|}}}|(optional)|}}
{{!}}align="center"{{!}}{{#if:{{{arg2optional|}}}|''|}}{{{arg2type|}}} {{#if:{{{arg2alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg2alttype|}}}}}|{{#if:{{{arg1name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}<!--
-->{{#if:{{{arg3name|}}}|<br />
{{!}}align="center"{{!}}{{#if:{{{arg3optional|}}}|''|}}{{{arg3type|}}} {{#if:{{{arg3alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg3alttype|}}}}}|{{#if:{{{arg2name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}<!--
-->{{#if:{{{arg4name|}}}|<br />
{{!}}align="center"{{!}}{{#if:{{{arg4optional|}}}|''|}}{{{arg4type|}}} {{#if:{{{arg4alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg4alttype|}}}}}|{{#if:{{{arg3name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}<!--
-->{{#if:{{{arg5name|}}}|<br />
{{!}}align="center"{{!}}{{#if:{{{arg5optional|}}}|''|}}{{{arg5type|}}} {{#if:{{{arg5alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg5alttype|}}}}}|{{#if:{{{arg4name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}<!--
-->{{#if:{{{arg6name|}}}|<br />
{{!}}align="center"{{!}}{{#if:{{{arg6optional|}}}|''|}}{{{arg6type|}}} {{#if:{{{arg6alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg6alttype|}}}}}|{{#if:{{{arg5name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}<!--
-->{{#if:{{{arg7name|}}}|<br />
{{!}}align="center"{{!}}{{#if:{{{arg7optional|}}}|''|}}{{{arg7type|}}} {{#if:{{{arg7alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg7alttype|}}}}}|{{#if:{{{arg6name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}<!--
-->{{#if:{{{arg8name|}}}|<br />
{{!}}align="center"{{!}}{{#if:{{{arg8optional|}}}|''|}}{{{arg8type|}}} {{#if:{{{arg8alttype|}}}|<span style="font-weight:1000;">or</span> {{{arg8alttype|}}}}}|{{#if:{{{arg7name|}}}|<br />
{{!}}[[Image:Edit-pencil.png|link={{{name}}}|Edit this info]]}}|}}
|-
|-
|{{#ifeq:{{{mac|yes}}}|no|{{#ifeq:{{{win|yes}}}|no|[[Image:Cmbox deletion.png|20px]]                                <!--if neither platform, show error icon
|'''{{{name}}}('''<!--
                                               -->|[[Image:Platform-empty.png|20px]] [[Image:Platform-Win.png|20px]]  <!--if only Win, show blank and Win icon
-->{{#if:{{{arg1name|}}}|<br /><!--                                  if this arg exists... -->
                      -->}}<!--
{{!}}align="center"{{!}}'''<!--                                create a cell, then...
                      -->|{{#ifeq:{{{win|yes}}}|no|[[Image:Platform-Mac.png|20px]] [[Image:Platform-empty.png|20px]] <!--if only Mac, show Mac and blank icon
-->{{#if:{{{arg1optional|}}}|''|}}<!--                               start italics if optional arg
                                              -->|[[Image:Platform-Win.png|20px]] [[Image:Platform-Mac.png|20px]]    <!--if both platforms, show both icons
-->{{{arg1name|}}}<!--                                               print arg name
                      -->}}<!--
-->{{#if:{{{arg1altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg1altname|}}}}}<!-- print " or " and alternate arg name if supplied
-->}}
-->{{#if:{{{arg1optional|}}}|''|}}<!--                               end italics if optional arg
|style="font-size:166%; vertical-align:bottom"|{{{name}}}(
-->{{#if:{{{arg2name|}}}|, |}}|<br /><!--                            and if there is a next arg, print a comma -->
|style="font-size:166%; vertical-align:bottom"|{{#if:{{{arg1name|}}}
{{!}}''' );}}<!--                                                 else if no args, just close parentheses
                                                |{{{arg1name|}}} {{#if:{{{arg1altname|}}}
-->{{#if:{{{arg2name|}}}|<br />
                                                                    |<u>or</u> {{{arg1altname|}}}|}} <!-- print alternative arg 1 if present
{{!}}align="center"{{!}}'''<!--
                                                              -->{{#if:{{{arg2name|}}}|, | ) }}     <!-- if there is a next arg, print comma, else close parens
-->{{#if:{{{arg2optional|}}}|''|}}<!--
                                              -->|void )}}                                           <!-- if no arg1, print "void" and a close parens -->
-->{{{arg2name|}}}<!--
|style="font-size:166%; vertical-align:bottom"|{{#if:{{{arg2name|}}}
-->{{#if:{{{arg2altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg2altname|}}}}}<!--
                                                |{{{arg2name|}}} {{#if:{{{arg2altname|}}}
-->{{#if:{{{arg2optional|}}}|''|}}<!--
                                                                    |<u>or</u> {{{arg2altname|}}}|}}
-->{{#if:{{{arg3name|}}}|, |}}|{{#if:{{{arg1name|}}}|<br />
                                                                  {{#if:{{{arg3name|}}}|, | ) }} }} <!-- if there is next arg, print comma else close parens -->
{{!}}''' ); |}}}}<!--
|style="font-size:166%; vertical-align:bottom"|{{#if:{{{arg3name|}}}
-->{{#if:{{{arg3name|}}}|<br />
                                                |{{{arg3name|}}} {{#if:{{{arg3altname|}}}
{{!}}align="center"{{!}}'''<!--
                                                                    |<u>or</u> {{{arg3altname|}}}|}}
-->{{#if:{{{arg3optional|}}}|''|}}<!--
                                                                  {{#if:{{{arg4name|}}}|, | ) }} }}
-->{{{arg3name|}}}<!--
|style="font-size:166%; vertical-align:bottom"|{{#if:{{{arg4name|}}}
-->{{#if:{{{arg3altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg3altname|}}}}}<!--
                                                |{{{arg4name|}}} {{#if:{{{arg4altname|}}}
-->{{#if:{{{arg3optional|}}}|''|}}<!--
                                                                    |<u>or</u> {{{arg4altname|}}}|}} ) }}
-->{{#if:{{{arg4name|}}}|, |}}|{{#if:{{{arg2name|}}}|<br />
{{!}}''' ); |}}}}<!--
-->{{#if:{{{arg4name|}}}|<br />
{{!}}align="center"{{!}}'''<!--
-->{{#if:{{{arg4optional|}}}|''|}}<!--
-->{{{arg4name|}}}<!--
-->{{#if:{{{arg4altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg4altname|}}}}}<!--
-->{{#if:{{{arg4optional|}}}|''|}}<!--
-->{{#if:{{{arg5name|}}}|, |}}|{{#if:{{{arg3name|}}}|<br />
{{!}}''' ); |}}}}<!--
-->{{#if:{{{arg5name|}}}|<br />
{{!}}align="center"{{!}}'''<!--
-->{{#if:{{{arg5optional|}}}|''|}}<!--
-->{{{arg5name|}}}<!--
-->{{#if:{{{arg5altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg5altname|}}}}}<!--
-->{{#if:{{{arg5optional|}}}|''|}}<!--
-->{{#if:{{{arg6name|}}}|, |}}|{{#if:{{{arg4name|}}}|<br />
{{!}}''' ); |}}}}<!--
-->{{#if:{{{arg6name|}}}|<br />
{{!}}align="center"{{!}}'''<!--
-->{{#if:{{{arg6optional|}}}|''|}}<!--
-->{{{arg6name|}}}<!--
-->{{#if:{{{arg6altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg6altname|}}}}}<!--
-->{{#if:{{{arg6optional|}}}|''|}}<!--
-->{{#if:{{{arg7name|}}}|, |}}|{{#if:{{{arg5name|}}}|<br />
{{!}}''' ); |}}}}<!--
-->{{#if:{{{arg7name|}}}|<br />
{{!}}align="center"{{!}}'''<!--
-->{{#if:{{{arg7optional|}}}|''|}}<!--
-->{{{arg7name|}}}<!--
-->{{#if:{{{arg7altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg7altname|}}}}}<!--
-->{{#if:{{{arg7optional|}}}|''|}}<!--
-->{{#if:{{{arg8name|}}}|, |}}|{{#if:{{{arg6name|}}}|<br />
{{!}}''' ); |}}}}<!--
-->{{#if:{{{arg8name|}}}|<br />
{{!}}align="center"{{!}}'''<!--
-->{{#if:{{{arg8optional|}}}|''|}}<!--
-->{{{arg8name|}}}<!--
-->{{#if:{{{arg8altname|}}}|&nbsp;<span style="font-weight:1000;">or</span> {{{arg8altname|}}}}}<!--
-->{{#if:{{{arg8optional|}}}|''|}}|{{#if:{{{arg7name|}}}|<br />
{{!}}''' ); |}}}}
|-
|-
|default:
|default: {{#if:{{{default|}}}|{{{default|}}}| --}}<!-- print "--" if there is no default return value for function
|              {{#if:{{{default|}}}   |{{{default|}}}| --}}                               <!-- print "--" if there is no default return value for function -->
-->{{#if:{{{arg1default|}}}|<br />
|align="center"|{{#if:{{{arg1default|}}}|{{{arg1default|}}}|{{#if:{{{arg1name|}}}| --|}}|}} <!-- print "--" if there is arg in this position with no default -->
{{!}}align="center"{{!}}{{{arg1default|}}}|{{#if:{{{arg1name|}}}|<br />
|align="center"|{{#if:{{{arg2default|}}}|{{{arg2default|}}}|{{#if:{{{arg2name|}}}| --|}}|}}
{{!}}align="center"{{!}} --|}}|}}<!--
|align="center"|{{#if:{{{arg3default|}}}|{{{arg3default|}}}|{{#if:{{{arg3name|}}}| --|}}|}}
-->{{#if:{{{arg2default|}}}|<br />
|align="center"|{{#if:{{{arg4default|}}}|{{{arg4default|}}}|{{#if:{{{arg4name|}}}| --|}}|}}
{{!}}align="center"{{!}}{{{arg2default|}}}|{{#if:{{{arg2name|}}}|<br />
|}</includeonly><noinclude>
{{!}}align="center"{{!}} --|}}|}}<!--
 
-->{{#if:{{{arg3default|}}}|<br />
'''BSLfunc''' allows for standardized listing of BSL functions. The assumption at the moment is that the most arguments a function can take is four; this will be raised if some functions are discovered to take more arguments.
{{!}}align="center"{{!}}{{{arg3default|}}}|{{#if:{{{arg3name|}}}|<br />
{{!}}align="center"{{!}} --|}}|}}<!--
-->{{#if:{{{arg4default|}}}|<br />
{{!}}align="center"{{!}}{{{arg4default|}}}|{{#if:{{{arg4name|}}}|<br />
{{!}}align="center"{{!}} --|}}|}}<!--
-->{{#if:{{{arg5default|}}}|<br />
{{!}}align="center"{{!}}{{{arg5default|}}}|{{#if:{{{arg5name|}}}|<br />
{{!}}align="center"{{!}} --|}}|}}<!--
-->{{#if:{{{arg6default|}}}|<br />
{{!}}align="center"{{!}}{{{arg6default|}}}|{{#if:{{{arg6name|}}}|<br />
{{!}}align="center"{{!}} --|}}|}}<!--
-->{{#if:{{{arg7default|}}}|<br />
{{!}}align="center"{{!}}{{{arg7default|}}}|{{#if:{{{arg7name|}}}|<br />
{{!}}align="center"{{!}} --|}}|}}<!--
-->{{#if:{{{arg8default|}}}|<br />
{{!}}align="center"{{!}}{{{arg8default|}}}|{{#if:{{{arg8name|}}}|<br />
{{!}}align="center"{{!}} --|}}|}}
|}</includeonly><noinclude>'''BSLfuncinfo''' allows for standardized listing of BSL functions. Since BSL allows for functions to take up to eight arguments, and each argument can be described here by up to six parameters, this makes '''BSLfuncinfo''' the most complex template on the wiki. However, you'll rarely need to use more than a few of these parameters to describe an average function.


Parameters:
Parameters:
Line 62: Line 133:
:You don't have to use these unless the function is <u>not</u> available and working on one platform; set the appropriate parameter(s) to "no" if that is the case.
:You don't have to use these unless the function is <u>not</u> available and working on one platform; set the appropriate parameter(s) to "no" if that is the case.


;<tt>arg1optional</tt>, <tt>arg2optional</tt>, <tt>arg3optional</tt>, <tt>arg4optional</tt>
;<tt>arg[1-8]optional</tt>
:If this argument can be omitted, set this to "yes".
:If this argument can be omitted, set this to "yes".


;<tt>arg1default</tt>, <tt>arg2default</tt>, <tt>arg3default</tt>, <tt>arg4default</tt>
;<tt>arg[1-8]default</tt>
:Optional arguments have default assumed values that are used when the argument is not used explicitly; give those values here.
:Optional arguments have default assumed values that are used when the argument is not provided; give those values here.


;<tt>arg1type</tt>, <tt>arg2type</tt>, <tt>arg3type</tt>, <tt>arg4type</tt>
;<tt>arg[1-8]type</tt>
:If these arguments to the BSL function exist, give their types here.
:If these arguments to the BSL function exist, give their types here.


;<tt>arg1name</tt>, <tt>arg2name</tt>, <tt>arg3name</tt>, <tt>arg4name</tt>
;<tt>arg[1-8]name</tt>
:If these arguments to the BSL function exist, give their names here.
:If these arguments to the BSL function exist, give their names here.


;<tt>arg1alttype</tt>, <tt>arg2alttype</tt>, <tt>arg3alttype</tt>, <tt>arg4alttype</tt>
;<tt>arg[1-8]alttype</tt>
:If a BSL function can take more than one kind of data in a given argument position, give the second argument type here.
:If a BSL function can take more than one kind of data in a given argument position, give the second argument type here.


;<tt>arg1altname</tt>, <tt>arg2altname</tt>, <tt>arg3altname</tt>, <tt>arg4altname</tt>
;<tt>arg[1-8]altname</tt>
:If a BSL function can take more than one kind of data in a given argument position, give the second argument name here.
:If a BSL function can take more than one kind of data in a given argument position, give the second argument name here.


Here's a default blank call with all parameters:
Below is a default blank call for all parameters up through the fourth function argument, to save some time. You can omit any parameters you don't need when adding this template to a page.


  <nowiki>{{</nowiki>BSLfunc
  <nowiki>{{</nowiki>BSLfuncinfo
  |type=
  |type=
  |default=
  |default=
Line 114: Line 185:
  <nowiki>}}</nowiki>
  <nowiki>}}</nowiki>


[[Category:Basic formatting templates]]</noinclude>
[[Category:Table templates]]</noinclude>

Latest revision as of 21:37, 22 April 2025

BSLfuncinfo allows for standardized listing of BSL functions. Since BSL allows for functions to take up to eight arguments, and each argument can be described here by up to six parameters, this makes BSLfuncinfo the most complex template on the wiki. However, you'll rarely need to use more than a few of these parameters to describe an average function.

Parameters:

type
Return type of function; should be "int", "string", "float", "bool", or "void".
default
Default return value of function, if there is one at the time the level starts.
name
Name of function.
mac, win
You don't have to use these unless the function is not available and working on one platform; set the appropriate parameter(s) to "no" if that is the case.
arg[1-8]optional
If this argument can be omitted, set this to "yes".
arg[1-8]default
Optional arguments have default assumed values that are used when the argument is not provided; give those values here.
arg[1-8]type
If these arguments to the BSL function exist, give their types here.
arg[1-8]name
If these arguments to the BSL function exist, give their names here.
arg[1-8]alttype
If a BSL function can take more than one kind of data in a given argument position, give the second argument type here.
arg[1-8]altname
If a BSL function can take more than one kind of data in a given argument position, give the second argument name here.

Below is a default blank call for all parameters up through the fourth function argument, to save some time. You can omit any parameters you don't need when adding this template to a page.

{{BSLfuncinfo
|type=
|default=
|name=
|mac=
|win=
|arg1optional= |arg1default= |arg1type= |arg1name= |arg1alttype= |arg1altname=
|arg2optional= |arg2default= |arg2type= |arg2name= |arg2alttype= |arg2altname=
|arg3optional= |arg3default= |arg3type= |arg3name= |arg3alttype= |arg3altname=
|arg4optional= |arg4default= |arg4type= |arg4name= |arg4alttype= |arg4altname= }}