
This commit includes several changes to improve the performance and stability of ArmaRAMDb: * **Increased Buffer Size:** Increased the buffer size in `Main.cs` to 10240 to handle larger data chunks. * **Debug Logging:** Added `#ifdef __A3__DEBUG__` preprocessor directives to enable debug logging in various `.sqf` functions for easier troubleshooting. * **Improved Chunking Logic:** Refactored the chunking logic in `Utils.cs` to correctly handle array data and improve efficiency. * **ListStore Formatting:** Modified `ListStore.cs` to correctly format list values as JSON strings when retrieving or setting list elements. * **Removed Unnecessary Code:** Removed unnecessary `_dataString` variable in `fnc_fetch.sqf`. * **Updated DLL/SO:** Updated the ArmaRAMDb_x64.dll and ArmaRAMDb_x64.so files.
167 lines
4.6 KiB
Plaintext
167 lines
4.6 KiB
Plaintext
#include "..\script_component.hpp"
|
|
|
|
/*
|
|
* Function: ramdb_db_fnc_processQueue
|
|
* Author: Creedcoder, J.Schmidt
|
|
* Edit: 07.15.2024
|
|
* Copyright © 2024 Creedcoder, J.Schmidt, All rights reserved
|
|
*
|
|
* Do not edit without permission!
|
|
*
|
|
* This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.
|
|
* To view a copy of this license, vist https://creativecommons.org/licenses/by-nc-sa/4.0/ or send a letter to Creative Commons,
|
|
* PO Box 1866, Mountain View, CA 94042
|
|
*
|
|
* [Description]
|
|
* Process queue of tasks.
|
|
*
|
|
* Arguments:
|
|
* N/A
|
|
*
|
|
* Return Value:
|
|
* N/A
|
|
*
|
|
* Examples:
|
|
* [] spawn ramdb_db_fnc_processQueue (Server or Singleplayer Only)
|
|
* [] remoteExec ["ramdb_db_fnc_processQueue", 2, false] (Multiplayer Only)
|
|
*
|
|
* Public: Yes
|
|
*/
|
|
|
|
GVAR(isProcessing) = true;
|
|
|
|
while { count GVAR(taskQueue) > 0} do {
|
|
private _task = GVAR(taskQueue) deleteAt 0;
|
|
private _taskType = _task select 0;
|
|
private _key = _task select 1;
|
|
private _keyField = _task select 2;
|
|
private _index = _task select 3;
|
|
private _value = _task select 4;
|
|
private _function = _task select 5;
|
|
private _call = _task select 6;
|
|
private _netId = _task select 7;
|
|
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["Initializing Task: %1", _task];
|
|
#endif
|
|
|
|
switch (_taskType) do {
|
|
case "get": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _function, _call, _netId] call FUNC(get);
|
|
};
|
|
case "set": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _value] call FUNC(set);
|
|
};
|
|
case "del": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key] call FUNC(delete);
|
|
};
|
|
case "hget": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_keyField, _function, _call, _netId] call FUNC(hashGet);
|
|
};
|
|
case "hgetid": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _keyField, _function, _call, _netId] call FUNC(hashGetId);
|
|
};
|
|
case "hgetall": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_function, _call, _netId] call FUNC(hashGetAll);
|
|
};
|
|
case "hgetallid": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _function, _call, _netId] call FUNC(hashGetAllId);
|
|
};
|
|
case "hset": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_keyField, _value] call FUNC(hashSet);
|
|
};
|
|
case "hsetbulk": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_value] call FUNC(hashSetBulk);
|
|
};
|
|
case "hsetid": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _keyField, _value] call FUNC(hashSetId);
|
|
};
|
|
case "hsetidbulk": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_value] call FUNC(hashSetIdBulk);
|
|
};
|
|
case "listadd": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _value] call FUNC(listAdd);
|
|
};
|
|
case "listidx": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _index, _function, _call, _netId] call FUNC(listGet);
|
|
};
|
|
case "listrng": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _function, _call, _netId] call FUNC(listLoad);
|
|
};
|
|
case "listrem": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _index] call FUNC(listRemove);
|
|
};
|
|
case "listset": {
|
|
#ifdef __A3__DEBUG__
|
|
diag_log text format ["ArmaRAMDb: 'ramdb_db_fnc_processQueue' Processing Task '%1'", _taskType];
|
|
#endif
|
|
|
|
[_key, _index, _value] call FUNC(listSet);
|
|
};
|
|
};
|
|
|
|
sleep 1;
|
|
|
|
};
|
|
|
|
GVAR(isProcessing) = false; |