assert: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "<dd class="notedate">Posted on ([^<>]+) " to "<dd class="notedate">Posted on $1</dd> ")
m (Text replacement - "[Rr]oehre" to "RoehrenRadio")
 
(29 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{RV|type=command
{{RV|type=command


| arma1
|game1= arma1
|version1= 1.00
 
|game2= arma2
|version2= 1.00
 
|game3= arma2oa
|version3= 1.50
 
|game4= tkoh
|version4= 1.00
 
|game5= arma3
|version5= 0.50


|gr1= Program Flow
|gr1= Program Flow


|1.00
|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.
 
| 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.
If script was pre-processed with [[preprocessFileLineNumbers]], it will also show/log the error line number and the file name.


| '''assert''' condition
|s1= [[assert]] condition


|p1= condition: [[Boolean]]
|p1= condition: [[Boolean]]


| [[Boolean]] - mirrors condition
|r1= [[Boolean]] - mirrors condition
 
|x1= <code>[[assert]] (1>2);</code>


[[Image:PreprocessFile.jpg]]
|x1= <sqf>assert (1 > 2);</sqf>


|x2= Check function params (Faster alternative to [[BIS_fnc_param]])<code>some_func = {
[[File:PreprocessFile.jpg]]
_0 = _this [[select]] 0;
 
_1 = _this [[select]] 1;
|x2= Check function params (Faster alternative to [[BIS_fnc_param]])
_2 = _this [[select]] 2;
<sqf>
if (![[assert]] (
some_func = {
[[typeName]] _0 == "ARRAY" &&  
_0 = _this select 0;
[[typeName]] _1 == "STRING" &&  
_1 = _this select 1;
[[typeName]] _2 == "SCALAR"
_2 = _this select 2;
)) [[exitWith]] {<nowiki>/*</nowiki>optional error logging<nowiki>*/</nowiki>};
if (!assert (
[[hint]] "Alright!";
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; // assert error
<nowiki>[</nowiki>[1],"2",3] [[call]] some_func; //Alright!</code>
[[1],"2",3] call some_func; // Alright!
</sqf>


| [[try]], [[catch]], [[throw]], [[halt]], [[diag_captureFrame]], [[diag_captureSlowFrame]], [[diag_logSlowFrame]]
|seealso= [[try]] [[catch]] [[throw]] [[halt]] [[diag_captureFrame]] [[diag_captureSlowFrame]] [[diag_logSlowFrame]]
}}
}}


<dl class="command_description">
{{Note
<!-- Note Section BEGIN -->
|user= RoehrenRadio
<dd class="notedate">Posted on May 15, 2010 - 0:01</dd>
|timestamp= 20100515000100
<dt class="note">[[User:Roehre|Roehre]]<dd class="note">Returns false, if condition is false, and returns true, if condition is true.
|text= Returns false, if condition is false, and returns true, if condition is true.
<!-- Note Section END -->
}}
</dl>
 
 
[[Category:Scripting Commands|ASSERT]]
{{GameCategory|arma1|Scripting Commands}}
{{GameCategory|arma2|Scripting Commands}}
{{GameCategory|arma3|Scripting Commands}}
{{GameCategory|tkoh|Scripting Commands}}

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.