Difference between revisions of "SetFunctionValue"
Jump to navigation
Jump to search
imported>Odessa (clarified, fixed typo) |
imported>Odessa (improved clarity) |
||
Line 4: | Line 4: | ||
If the function is called multiple times in the same function, the most recent is used by the call; this function is not a substitute for the keyword 'return', script execution will continue to the end of the block as normal. | If the function is called multiple times in the same function, the most recent is used by the call; this function is not a substitute for the keyword 'return', script execution will continue to the end of the block as normal. | ||
In another script, to bind the UDF function value to a variable, [[Let]] must be used rather than <b>set</b>, and to use in a conditional, [[Eval|if eval]] rather than just <b>if</b>. | |||
|name = SetFunctionValue | |name = SetFunctionValue | ||
|returnType = None | |returnType = None | ||
Line 13: | Line 15: | ||
==Example== | ==Example== | ||
<pre> | <pre> | ||
scn MyUDF | |||
Begin Function { } | Begin Function { } | ||
Line 19: | Line 23: | ||
End | End | ||
</pre> | </pre> | ||
Then in some other script: | |||
<pre> | |||
ref rActor | |||
let rActor := call MyUDF | |||
; rActor == SunnyREF | |||
</pre> | |||
Another UDF example: | |||
<pre> | <pre> | ||
Begin Function { } | Begin Function { } | ||
Line 25: | Line 41: | ||
SetFunctionValue 1 | SetFunctionValue 1 | ||
elseif | elseif PlayerREF.GetAV Strength > 5 | ||
SetFunctionValue 1 | SetFunctionValue 1 | ||
Line 40: | Line 56: | ||
*[[User Defined Function]] | *[[User Defined Function]] | ||
*[[Call]] | *[[Call]] | ||
*[[ | *[[Let]] | ||
*[[Eval]] | *[[Eval]] | ||
[[Category:Functions_(NVSE)]] | [[Category:Functions_(NVSE)]] |
Revision as of 03:20, 12 July 2014
< [[::Category:Functions|Category:Functions]]
A function added by the New Vegas Script Extender.
Description
Added by NVSE V4. Used only within the 'Function' block type of a User Defined Function, sets the return value to that specified. A UDF may return only a single value, but it may be of any type, including an array.
If the function is called multiple times in the same function, the most recent is used by the call; this function is not a substitute for the keyword 'return', script execution will continue to the end of the block as normal.
In another script, to bind the UDF function value to a variable, Let must be used rather than set, and to use in a conditional, if eval rather than just if.
Syntax
(None) SetFunctionValue UDFReturnValue:multi
Example
scn MyUDF Begin Function { } SetFunctionValue SunnyREF ; * this function simply returns Sunny Smiles End
Then in some other script:
ref rActor let rActor := call MyUDF ; rActor == SunnyREF
Another UDF example:
Begin Function { } if GameHour > 12 SetFunctionValue 1 elseif PlayerREF.GetAV Strength > 5 SetFunctionValue 1 else SetFunctionValue 0 endif ; * return true if it is after midday or player has more than 5 strength End