xpdb/addons/generate/functions/fnc_vehicleID.sqf
Jacob Schmidt 1b6b825653
All checks were successful
Build / Build (push) Successful in 53s
Initial Repo Setup
2025-01-01 21:18:03 -06:00

51 lines
1.8 KiB
Plaintext

#include "script_component.hpp"
/*
* Function: xpdb_generate_fnc_vehicleID
* Author: NikolaiF90, J.Schmidt
* Edit: 07.27.2024
* Copyright © 2024 NikolaiF90, J.Schmidt, All rights reserved
*
* Do not edit without permission!
*
* This work is licensed under the Creative Commons Attribution-NonCommercial-NoDerivative 4.0 International License.
* To view a copy of this license, vist https://creativecommons.org/licenses/by-nc-nd/4.0/ or send a letter to Creative Commons,
* PO Box 1866, Mountain View, CA 94042
*
* [Description]
* Generate unique ID for a vehicle and store it, or retrieve the unique ID of an existing vehicle.
*
* Arguments:
* 0: Entity object <OBJECT> (default: nil)
*
* Return Value:
* The return <SCALAR>
*
* Examples:
* [veh1] call xpdb_generate_fnc_vehicleID
*
* Public: Yes
*/
params [["_vehicle", nil, [objNull, 0, [], sideUnknown, grpNull, ""]]];
private _vehicleID = 0;
if (isNil "_vehicle" || isNull _vehicle) exitWith {[EGVAR(db,debug), "xpdb_generate_fnc_vehicleID", "No vehicle to generate ID for.", true] call EFUNC(utils,debug); };
[EGVAR(db,debug), "xpdb_generate_fnc_vehicleID", format ["Generating ID for vehicle '%1'...", _vehicle], false] call EFUNC(utils,debug);
private _vehicleIndex = (EGVAR(db,vehs)) find _vehicle;
if (_vehicleIndex == -1) then {
_vehicleID = count (EGVAR(db,vehs));
_vehicle setVariable [EGVAR(db,vehIDKey), _vehicleID];
(EGVAR(db,vehs)) pushback _vehicle;
[EGVAR(db,debug), "xpdb_generate_fnc_vehicleID", format ["ID for vehicle '%1' has been successfully generated.", _vehicle], false] call EFUNC(utils,debug);
} else {
[EGVAR(db,debug), "xpdb_generate_fnc_vehicleID", format ["Vehicle '%1' already had an existing ID.", _vehicle], false] call EFUNC(utils,debug);
_vehicleID = ((EGVAR(db,vehs)) # _vehicleIndex) getVariable EGVAR(db,vehIDKey);
};
_vehicleID;