Difference between revisions of "SetFunctionValue"

From the Fallout3 GECK Wiki
Jump to navigation Jump to search
imported>Odessa
(clarified, fixed typo)
imported>Odessa
m (+cat)
 
(One intermediate revision by the same user not shown)
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 eval (PlayerREF.GetAV Strength > 5)
     elseif PlayerREF.GetAV Strength > 5
         SetFunctionValue 1
         SetFunctionValue 1


Line 40: Line 56:
*[[User Defined Function]]
*[[User Defined Function]]
*[[Call]]
*[[Call]]
*[[Array Variables]]
*[[Let]]
*[[Eval]]
*[[Eval]]
[[Category:Functions_(NVSE)]]
[[Category:Functions_(NVSE)]]
[[Category:User Defined Functions]]

Latest revision as of 11:33, 21 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

[help]
(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

See Also