assert: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "[Rr]oehre" to "RoehrenRadio")
 
(61 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{Command|= Comments
{{RV|type=command
____________________________________________________________________________________________


| arma |= Game name
|game1= arma1
|version1= 1.00


|1.00|= Game version
|game2= arma2
____________________________________________________________________________________________
|version2= 1.00


| Tests a condition and if the condition is false, exits the handle.
|game3= arma2oa
|version3= 1.50


Does not work properly in ArmA2(OA) 1.08(1.54) : If condition is false, it only returns an empty Error Message without closing the Script. |= Description
|game4= tkoh
____________________________________________________________________________________________
|version4= 1.00


| '''assert''' condition |= Syntax
|game5= arma3
|version5= 0.50


|p1= condition: [[Boolean]] |= Parameter 1
|gr1= Program Flow


| [[Boolean]] |= Return value
|descr= Tests a condition and if the condition is false, displays error on screen (if -showscripterrors enabled) and logs error into .rpt file. It does not interrupt the script execution.
____________________________________________________________________________________________
 
|x1= <pre>assert (_x>0)</pre> |= Example 1
____________________________________________________________________________________________


| [[exitWith]] |= See also
If script was pre-processed with [[preprocessFileLineNumbers]], it will also show/log the error line number and the file name.


}}
|s1= [[assert]] condition
 
|p1= condition: [[Boolean]]
 
|r1= [[Boolean]] - mirrors condition
 
|x1= <sqf>assert (1 > 2);</sqf>
 
[[File:PreprocessFile.jpg]]


<h3 style="display:none">Notes</h3>
|x2= Check function params (Faster alternative to [[BIS_fnc_param]])
<dl class="command_description">
<sqf>
<!-- Note Section BEGIN -->
some_func = {
<dd class="notedate">Posted on May 15, 2010 - 0:01
_0 = _this select 0;
<dt class="note">'''[[User:Roehre|Roehre]]'''<dd class="note">Returns false, if condition is false (it does close script) and returns true, if condition is true (it doesn't close script).
_1 = _this select 1;
<!-- Note Section END -->
_2 = _this select 2;
</dl>
if (!assert (
typeName _0 == "ARRAY" &&
typeName _1 == "STRING" &&
typeName _2 == "SCALAR"
)) exitWith { /* optional error logging */ };
hint "Alright!";
};
[1,2,3] call some_func; // assert error
[[1],"2",3] call some_func; // Alright!
</sqf>


<h3 style="display:none">Bottom Section</h3>
|seealso= [[try]] [[catch]] [[throw]] [[halt]] [[diag_captureFrame]] [[diag_captureSlowFrame]] [[diag_logSlowFrame]]
}}


[[Category:Scripting Commands|ASSERT]]
{{Note
[[Category:Scripting Commands ArmA|ASSERT]]
|user= RoehrenRadio
[[Category:Command_Group:_Program_Flow|{{uc:{{PAGENAME}}}}]]
|timestamp= 20100515000100
[[Category:Scripting Commands ArmA2|{{uc:{{PAGENAME}}}}]]
|text= Returns false, if condition is false, and returns true, if condition is true.
[[Category:Scripting_Commands_Take_On_Helicopters|{{uc:{{PAGENAME}}}}]]
}}

Latest revision as of 10:49, 8 April 2024

Hover & click on the images for description

Description

Description:
Tests a condition and if the condition is false, displays error on screen (if -showscripterrors enabled) and logs error into .rpt file. It does not interrupt the script execution. If script was pre-processed with preprocessFileLineNumbers, it will also show/log the error line number and the file name.
Groups:
Program Flow

Syntax

Syntax:
assert condition
Parameters:
condition: Boolean
Return Value:
Boolean - mirrors condition

Examples

Example 1:
assert (1 > 2);
PreprocessFile.jpg
Example 2:
Check function params (Faster alternative to BIS_fnc_param)
some_func = { _0 = _this select 0; _1 = _this select 1; _2 = _this select 2; if (!assert ( typeName _0 == "ARRAY" && typeName _1 == "STRING" && typeName _2 == "SCALAR" )) exitWith { /* optional error logging */ }; hint "Alright!"; }; [1,2,3] call some_func; // assert error [[1],"2",3] call some_func; // Alright!

Additional Information

See also:
try catch throw halt diag_captureFrame diag_captureSlowFrame diag_logSlowFrame

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
RoehrenRadio - c
Posted on May 15, 2010 - 00:01 (UTC)
Returns false, if condition is false, and returns true, if condition is true.