-JpS-RaptorMan 1 Posted July 19, 2020 Group, I'm looking to write the results of a function call to the log file. I read up on IF's & isNil via the wiki. Unsuccessfully... so I've started trying to tell what sort of data is coming back to me ... Some of my tests ... Trying to caputure the result of fn_getUIDPermissions in _c ... but really, this applies to every function I've tried to test yet 😞 ("-----Test-----") call BIS_fnc_log; _b = ('< my valid steam UID>' call fn_getUIDPermissions); _c = if (_b) then [ {"true"}, {"false"}]; (format ["-----Test %1 ...", _c]) call BIS_fnc_log; Results in "Test Dedicated server/BIS_fnc_log: ""-----Test-----""" "Test Dedicated server/BIS_fnc_log: ""-----Test any ...""" Another test just trying to tell if the stupid thing is nil or not ... ("-----Test-----") call BIS_fnc_log; _b = ('< my valid steam UID>' call fn_getUIDPermissions); _c = if (_b) then [ {"true"} else {"false"}]; (_c) call BIS_fnc_log; Which comes back "Test Dedicated server/BIS_fnc_log: ""-----Test-----""" (originally I was doing the good stuff like calling it private etc - but don't know enough to know if that's the issue so I pulled that stuff out in favor of simplicity since no function has been captured in console) Can someone shed some light on what's happening, maybe point me to something specific? Thanks! -R Share this post Link to post Share on other sites
gc8 981 Posted July 19, 2020 This: _c = if (_b) then [ {"true"}, {"false"}]; should be: _c = if (_b) then {"true"} else {"false"}; at least to my knowledge Share this post Link to post Share on other sites
-JpS-RaptorMan 1 Posted July 19, 2020 I've tried both ways & they are actually both documented on the link I posted for the IF statements ... any idea why I get "any" back when I format the true/false results? Share this post Link to post Share on other sites
RCA3 593 Posted July 19, 2020 (edited) "true" and "false" are undefined variables hence "any" as a result. true and false are booleans. Edit: Unless _b is a boolean. Edited July 19, 2020 by RCA3 Share this post Link to post Share on other sites
-JpS-RaptorMan 1 Posted July 19, 2020 On 7/19/2020 at 8:08 PM, RCA3 said: "true" and "false" are undefined variables hence "any" as a result. true and false are booleans. Edit: Unless _b is a boolean. So, from a c/haskell/ruby/javascript/elixir background this makes no sense ... sqf is untyped basically? Even if it was, I should get "true" or "false" back ... notice I'm putting string handlers around it - is this some weird BI thing where they perverted the typing 99% of the programmers in the world use? Share this post Link to post Share on other sites
killzone_kid 1333 Posted July 19, 2020 On 7/19/2020 at 4:33 PM, gc8 said: at least to my knowledge Always check the wiki first https://community.bistudio.com/wiki/if Share this post Link to post Share on other sites
killzone_kid 1333 Posted July 19, 2020 On 7/19/2020 at 3:49 PM, -JpS-RaptorMan said: Can someone shed some light on what's happening, maybe point me to something specific? fn_getUIDPermissions returns array, you are treating it as boolean. Check your .rpt for errors Share this post Link to post Share on other sites
gc8 981 Posted July 20, 2020 On 7/19/2020 at 9:27 PM, killzone_kid said: Always check the wiki first https://community.bistudio.com/wiki/if Yea I did but must admit I don't know what the example 2 really does Share this post Link to post Share on other sites
-JpS-RaptorMan 1 Posted July 20, 2020 On 7/19/2020 at 9:29 PM, killzone_kid said: fn_getUIDPermissions returns array, you are treating it as boolean. Check your .rpt for errors That's actually why I'm here ... RPT doesn't ... even when I write the correct sequence & get a 1 back in the debug console status bar - my RPT will show the "Test" but not the other line. I even built several versions of IF(<condition>) (isNil, check if value was above -1, etc) & was trying to have the if statement return strings. This got me thinking that I could skip that check & just act on the array itself, ty! I'm getting the idea that ... the isNil check isn't handled by array object in the arma3 engine ... so I have to call isNil against the element of the array, not the array itself ... // this if(isNil _b[0]) // not this if(isNil _b) // though I suppose I could fake the 2nd one with ... results ... _b = ""; count (_b); hint str(_b); // reports 0 _b = nil; count (_b); hint str(_b); // dies silently Thanks gang!! This really helps Also, the other reason nothing was showing up after the "TEST" in the RPT ... the mod wrapped that function I was calling in another ... I just noticed after debugging my if/isnil stuff and was going over the mod code ... right version was ... Quote ASMS_fnc_getUIDPermissions Share this post Link to post Share on other sites
Sgt. Dennenboom 98 Posted July 20, 2020 You are using the isNil command wrong. You can use it to check the existence of variables by supplying the variable name, or the existing of the result of code by supplying a code block. So using the former: ("-----Test-----") call BIS_fnc_log; _b = '< my valid steam UID>' call fn_getUIDPermissions; _c = if (isNil "_b") then {false} else {true}; // essentially the same as _c = !isNil "_b"; (format ["-----Test %1 ...", _c]) call BIS_fnc_log; And using the latter: ("-----Test-----") call BIS_fnc_log; _c = !isNil {'< my valid steam UID>' call fn_getUIDPermissions}; (format ["-----Test %1 ...", _c]) call BIS_fnc_log; Format also takes care of converting boolean _c into a string, so no need to do the weird string "true"/"false" definition. 1 Share this post Link to post Share on other sites