Pixel-Composer/scripts/append_function/append_function.gml

126 lines
3.5 KiB
Text
Raw Normal View History

2022-01-18 11:31:19 +07:00
function APPEND(_path) {
APPENDING = true;
2022-12-12 15:08:03 +07:00
var log = false;
2022-01-18 11:31:19 +07:00
if(_path == "") return;
2022-12-12 15:08:03 +07:00
var _map = json_load(_path);
2022-01-18 11:31:19 +07:00
2022-12-12 15:08:03 +07:00
if(_map == -1) {
printlog("Decode error");
return
2022-01-18 11:31:19 +07:00
}
if(ds_map_exists(_map, "version")) {
var _v = _map[? "version"];
if(_v != SAVEFILE_VERSION) {
var warn = "File version mismatch : loading file verion " + string(_v) + " to Pixel Composer " + string(SAVEFILE_VERSION);
log_warning("FILE", warn)
}
} else {
var warn = "File version mismatch : loading old format to Pixel Composer " + string(SAVEFILE_VERSION);
log_warning("FILE", warn)
}
var _node_list = _map[? "nodes"];
var appended_list = ds_list_create();
var node_create = ds_list_create();
ds_queue_clear(CONNECTION_CONFLICT);
2022-01-19 09:05:13 +07:00
ds_map_clear(APPEND_MAP);
2022-12-12 15:08:03 +07:00
var t = current_time;
2022-01-18 11:31:19 +07:00
for(var i = 0; i < ds_list_size(_node_list); i++) {
var _node = nodeLoad(_node_list[| i], true);
if(_node) ds_list_add(appended_list, _node);
}
2022-12-12 15:08:03 +07:00
printlog("Load time: " + string(current_time - t));
t = current_time;
2022-01-18 11:31:19 +07:00
try {
for(var i = 0; i < ds_list_size(appended_list); i++) {
var _node = appended_list[| i];
_node.loadGroup();
2022-01-18 11:31:19 +07:00
if(_node.group == PANEL_GRAPH.getCurrentContext())
ds_list_add(node_create, _node);
}
} catch(e) {
log_warning("APPEND, node", e.longMessage);
2022-01-18 11:31:19 +07:00
}
2022-12-12 15:08:03 +07:00
printlog("Load group time: " + string(current_time - t));
t = current_time;
2022-01-18 11:31:19 +07:00
try {
for(var i = 0; i < ds_list_size(appended_list); i++)
appended_list[| i].postDeserialize();
} catch(e) {
log_warning("APPEND, deserialize", e.longMessage);
2022-01-18 11:31:19 +07:00
}
2022-12-12 15:08:03 +07:00
printlog("Deserialize time: " + string(current_time - t));
t = current_time;
2022-12-10 11:06:01 +07:00
try {
for(var i = 0; i < ds_list_size(appended_list); i++)
appended_list[| i].preConnect();
for(var i = 0; i < ds_list_size(appended_list); i++)
appended_list[| i].connect();
for(var i = 0; i < ds_list_size(appended_list); i++)
appended_list[| i].postConnect();
} catch(e) {
log_warning("APPEND, connect", e.longMessage);
2022-01-18 11:31:19 +07:00
}
2022-12-12 15:08:03 +07:00
printlog("Connect time: " + string(current_time - t));
t = current_time;
2022-01-18 11:31:19 +07:00
try {
for(var i = 0; i < ds_list_size(appended_list); i++)
appended_list[| i].doUpdate();
} catch(e) {
log_warning("APPEND, update", e.longMessage);
2022-01-23 10:08:16 +07:00
}
2022-12-12 15:08:03 +07:00
printlog("Update time: " + string(current_time - t));
t = current_time;
2022-01-18 11:31:19 +07:00
ds_list_destroy(appended_list);
2022-12-10 11:06:01 +07:00
Render(true);
2022-01-18 11:31:19 +07:00
2022-01-23 10:08:16 +07:00
if(!ds_queue_empty(CONNECTION_CONFLICT)) {
var pass = 0;
2022-01-18 11:31:19 +07:00
try {
2022-09-21 11:09:40 +07:00
while(++pass < 3 && !ds_queue_empty(CONNECTION_CONFLICT)) {
var size = ds_queue_size(CONNECTION_CONFLICT);
log_message("APPEND", "[Connect] " + string(size) + " Connection conflict(s) detected ( pass: " + string(pass) + " )");
repeat(size) {
2022-09-21 11:09:40 +07:00
var junc = ds_queue_dequeue(CONNECTION_CONFLICT);
var res = junc.connect(true);
log_message("APPEND", "[Connect] Reconnecting " + string(junc.name) + " " + (res? "SUCCESS" : "FAILED"));
}
2022-12-10 11:06:01 +07:00
Render(true);
2022-01-23 10:08:16 +07:00
}
2022-01-18 11:31:19 +07:00
if(!ds_queue_empty(CONNECTION_CONFLICT))
2022-12-12 15:08:03 +07:00
log_warning("APPEND", "Some connection(s) is unresolved. This may caused by render node not being update properly, or image path is broken.");
} catch(e) {
2022-11-14 09:16:15 +07:00
log_warning("APPEND, Conflict solver error : ", e.longMessage);
}
2022-01-23 10:08:16 +07:00
}
2022-12-12 15:08:03 +07:00
printlog("Conflict time: " + string(current_time - t));
t = current_time;
2022-01-18 11:31:19 +07:00
APPENDING = false;
PANEL_ANIMATION.updatePropertyList();
2022-11-18 09:20:31 +07:00
log_message("FILE", "append file " + _path, THEME.noti_icon_file_load);
2022-01-29 20:25:18 +07:00
ds_map_destroy(_map);
2022-01-18 11:31:19 +07:00
return node_create;
2022-01-19 09:05:13 +07:00
}
function GetAppendID(old_id) {
if(ds_map_exists(APPEND_MAP, old_id))
return APPEND_MAP[? old_id];
return -1;
2022-01-18 11:31:19 +07:00
}