fileExists: Difference between revisions

From Bohemia Interactive Community
m (Text replacement - " \| *(([^=\| ]+)('''|\[\[)([^=\| ]+)) * \|p1=" to " |s1= $1 |p1=")
m (Text replacement - "{{Feature|Informative|" to "{{Feature|informative|")
 
(11 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{RV|type=command
{{RV|type=command


| arma3
|game1= arma3
 
|version1= 2.02
|2.02


|gr1= Program Flow
|gr1= Program Flow


| Checks if file on given path exists. Uses same path resolve code as [[loadFile]].
|descr= Checks if file on given path exists. Uses same path resolve code as [[loadFile]].
{{Feature|informative|Absolute paths are not supported, such as those generated using [[getMissionPath]]. Attempting to check an absolute path will result in this error in [[RPT]] logs:
{{hl|Invalid path (only relative paths supported): 'C:\...'}}
}}


|s1= [[fileExists]] path
|s1= [[fileExists]] path


|p1= path: [[String]] - Path to file
|p1= path: [[String]] - path to file


|r1=[[Boolean]] - [[true]] if it exists, otherwise [[false]]
|r1= [[Boolean]] - [[true]] if it exists, otherwise [[false]]


|x1= <code>[[fileExists]] "\a3\mySuperPath\bestFileEver.paa"; {{cc|Returns [[false]]}}</code>
|x1= <sqf>fileExists "\a3\mySuperPath\bestFileEver.paa"; // returns false</sqf>


|x2= <code>[[private]] _path [[a = b|=]] "a3\functions_f_mp_mark\revive\_addaction_revive.inc";
|x2= <sqf>
[[if]] ([[fileExists]] _path) [[then]] {[[loadFile]] _path} [[else]] {[[diag_log]] [[format]] ["File (%1) does not exist!",_path]};</code>
private _path = "a3\functions_f_mp_mark\revive\_addaction_revive.inc";
if (fileExists _path) then { loadFile _path } else { diag_log format ["File (%1) does not exist!", _path] };
</sqf>


|x3= <code>{{cc|Sometimes it might be better to check if a file exists instead of checking if path is empty ("")}}
|x3= <sqf>
[[private]] _class = "ModuleObjectiveRaceFinish_F";
// Sometimes it might be better to check if a file exists instead of checking if path is empty ("")
[[private]] _picture [[a = b|=]] [[getText]] ([[configFile]] [[config greater greater name|>>]] "CfgVehicles" [[config greater greater name|>>]] _class [[config greater greater name|>>]] "editorPreview");
private _class = "ModuleObjectiveRaceFinish_F";
[[if]] [[! a|!]](fileExists _picture) [[then]] {_picture [[a = b|=]] [[getText]] ([[configFile]] [[config greater greater name|>>]] "CfgVehicles" [[config greater greater name|>>]] _class [[config greater greater name|>>]] "portrait")};
private _picture = getText (configFile >> "CfgVehicles" >> _class >> "editorPreview");
[[if]] [[! a|!]](fileExists _picture) [[then]] {_picture [[a = b|=]] [[getText]] ([[configFile]] [[config greater greater name|>>]] "CfgVehicles" [[config greater greater name|>>]] _class [[config greater greater name|>>]] "icon")};
if !(fileExists _picture) then { _picture = getText (configFile >> "CfgVehicles" >> _class >> "portrait") };
[[if]] [[! a|!]](fileExists _picture) [[then]] {_picture [[a = b|=]] [[getText]] ([[configFile]] [[config greater greater name|>>]] "CfgVehicles" [[config greater greater name|>>]] _class [[config greater greater name|>>]] "picture")};
if !(fileExists _picture) then { _picture = getText (configFile >> "CfgVehicles" >> _class >> "icon") };
[[if]] [[! a|!]](fileExists _picture) [[then]] {[[systemChat]] "No valid picture found!"} [[else]] {[[systemChat]] _picture};</code>
if !(fileExists _picture) then { _picture = getText (configFile >> "CfgVehicles" >> _class >> "picture") };
if !(fileExists _picture) then { systemChat "No valid picture found!" } else { systemChat _picture };
</sqf>


|seealso= [[loadFile]] [[preprocessFile]] [[preprocessFileLineNumbers]]
|seealso= [[loadFile]] [[preprocessFile]] [[preprocessFileLineNumbers]]
}}
{{Note
|user= Leopard20
|timestamp= 20220101162930
|text= Returns [[true]] for empty strings: <sqf inline>fileExists ""; // true</sqf>
}}
}}

Latest revision as of 00:24, 2 February 2024

Hover & click on the images for description

Description

Description:
Checks if file on given path exists. Uses same path resolve code as loadFile.
Absolute paths are not supported, such as those generated using getMissionPath. Attempting to check an absolute path will result in this error in RPT logs: Invalid path (only relative paths supported): 'C:\...'
Groups:
Program Flow

Syntax

Syntax:
fileExists path
Parameters:
path: String - path to file
Return Value:
Boolean - true if it exists, otherwise false

Examples

Example 1:
fileExists "\a3\mySuperPath\bestFileEver.paa"; // returns false
Example 2:
private _path = "a3\functions_f_mp_mark\revive\_addaction_revive.inc"; if (fileExists _path) then { loadFile _path } else { diag_log format ["File (%1) does not exist!", _path] };
Example 3:
// Sometimes it might be better to check if a file exists instead of checking if path is empty ("") private _class = "ModuleObjectiveRaceFinish_F"; private _picture = getText (configFile >> "CfgVehicles" >> _class >> "editorPreview"); if !(fileExists _picture) then { _picture = getText (configFile >> "CfgVehicles" >> _class >> "portrait") }; if !(fileExists _picture) then { _picture = getText (configFile >> "CfgVehicles" >> _class >> "icon") }; if !(fileExists _picture) then { _picture = getText (configFile >> "CfgVehicles" >> _class >> "picture") }; if !(fileExists _picture) then { systemChat "No valid picture found!" } else { systemChat _picture };

Additional Information

See also:
loadFile preprocessFile preprocessFileLineNumbers

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
Leopard20 - c
Posted on Jan 01, 2022 - 16:29 (UTC)
Returns true for empty strings: fileExists ""; // true