assert: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (removed return as non sensical)
m (Text replacement - "[Rr]oehre" to "RoehrenRadio")
 
(76 intermediate revisions by 9 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, halts the program. |= Description
|game3= arma2oa
____________________________________________________________________________________________
|version3= 1.50


| '''assert''' condition |= Syntax
|game4= tkoh
|version4= 1.00


|p1= condition: [[Boolean]] |= Parameter 1
|game5= arma3
|version5= 0.50


| |= Return value
|gr1= Program Flow
____________________________________________________________________________________________
 
|x1= <pre>assert (_x>0)</pre> |= Example 1
____________________________________________________________________________________________


| |= See also
|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.


}}
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>


<h3 style="display:none">Notes</h3>
[[File:PreprocessFile.jpg]]
<dl class="command_description">
<!-- Note Section BEGIN -->


<!-- Note Section END -->
|x2= Check function params (Faster alternative to [[BIS_fnc_param]])
</dl>
<sqf>
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!
</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
|text= Returns false, if condition is false, and returns true, if condition is true.
}}

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.