Move project save write planning to app core

This commit is contained in:
2026-06-06 12:00:57 +02:00
parent ed9709ade8
commit a03db82307
8 changed files with 199 additions and 15 deletions

View File

@@ -413,6 +413,7 @@ struct PlanCanvasClearArgs {
struct PlanCanvasProjectSaveTargetArgs {
std::string data_directory = "D:/Paint/data";
std::string target_path = "D:/Paint/projects/demo.ppi";
bool target_exists = false;
};
struct PlanCanvasDocumentSnapshotArgs {
@@ -966,6 +967,19 @@ const char* document_canvas_save_writer_action_name(pp::app::DocumentCanvasSaveW
return "use-legacy-project-save";
}
const char* document_canvas_project_save_write_action_name(
pp::app::DocumentCanvasProjectSaveWriteAction action) noexcept
{
switch (action) {
case pp::app::DocumentCanvasProjectSaveWriteAction::write_direct_to_target:
return "write-direct-to-target";
case pp::app::DocumentCanvasProjectSaveWriteAction::write_temporary_then_swap:
return "write-temporary-then-swap";
}
return "write-direct-to-target";
}
const char* document_workflow_decision_name(pp::app::DocumentWorkflowDecision decision) noexcept
{
switch (decision) {
@@ -2546,7 +2560,7 @@ void print_help()
<< " plan-canvas-view-density [--density N] [--bad-float]\n"
<< " plan-canvas-view-cursor-mode [--mode N]\n"
<< " plan-canvas-cursor [--mode draw|erase|line|camera|grid|copy|cut|fill|mask-free|mask-line|bucket] [--visibility never|small-brush|not-painting|always] [--brush-size N] [--no-brush] [--drawing] [--alt] [--resizing] [--picking] [--bad-size]\n"
<< " plan-canvas-project-save-target [--data-dir DIR] [--path FILE]\n"
<< " plan-canvas-project-save-target [--data-dir DIR] [--path FILE] [--target-exists]\n"
<< " plan-grid-operation --kind pick|load|reload|clear|render|commit [--path FILE] [--no-heightmap] [--no-canvas] [--float32] [--float16] [--texture-resolution N] [--samples N]\n"
<< " plan-history-operation --kind undo|redo|clear [--undo-count N] [--redo-count N] [--memory-bytes N]\n"
<< " plan-main-toolbar --command open|save|undo|redo|clear-history|clear-canvas|message-box|settings [--undo-count N] [--redo-count N] [--memory-bytes N] [--no-canvas]\n"
@@ -6075,6 +6089,8 @@ pp::foundation::Status parse_plan_canvas_project_save_target_args(
} else {
args.target_path = argv[++i];
}
} else if (key == "--target-exists") {
args.target_exists = true;
} else {
return pp::foundation::Status::invalid_argument("unknown option");
}
@@ -6100,14 +6116,31 @@ int plan_canvas_project_save_target(int argc, char** argv)
return 2;
}
const auto write_plan = pp::app::plan_document_canvas_project_save_write(
plan.value(),
args.target_exists);
if (!write_plan) {
print_error("plan-canvas-project-save-target", write_plan.status().message);
return 2;
}
const auto& value = plan.value();
const auto& write_value = write_plan.value();
std::cout << "{\"ok\":true,\"command\":\"plan-canvas-project-save-target\""
<< ",\"dataDirectory\":\"" << json_escape(args.data_directory)
<< "\",\"targetPath\":\"" << json_escape(value.target_path)
<< "\",\"fileName\":\"" << json_escape(value.file_name)
<< "\",\"temporaryPath\":\"" << json_escape(value.temporary_path)
<< "\",\"timelapsePath\":\"" << json_escape(value.timelapse_path)
<< "\"}\n";
<< "\",\"writePlan\":{\"action\":\""
<< document_canvas_project_save_write_action_name(write_value.action)
<< "\",\"targetExists\":" << json_bool(write_value.target_exists)
<< ",\"usesTemporary\":" << json_bool(write_value.uses_temporary)
<< ",\"writePath\":\"" << json_escape(write_value.write_path)
<< "\",\"fallbackDirectOnTemporaryOpenFailure\":"
<< json_bool(write_value.falls_back_to_direct_on_temporary_open_failure)
<< "}"
<< "}\n";
return 0;
}