Plan document open actions in app core
This commit is contained in:
@@ -97,6 +97,11 @@ struct ClassifyOpenArgs {
|
||||
std::string path;
|
||||
};
|
||||
|
||||
struct PlanOpenRouteArgs {
|
||||
std::string path;
|
||||
bool unsaved = false;
|
||||
};
|
||||
|
||||
struct PlanDocumentFileArgs {
|
||||
std::string work_directory;
|
||||
std::string name;
|
||||
@@ -275,6 +280,22 @@ const char* project_open_decision_name(pp::app::ProjectOpenDecision decision) no
|
||||
return "open-now";
|
||||
}
|
||||
|
||||
const char* document_open_plan_action_name(pp::app::DocumentOpenPlanAction action) noexcept
|
||||
{
|
||||
switch (action) {
|
||||
case pp::app::DocumentOpenPlanAction::open_project_now:
|
||||
return "open-project-now";
|
||||
case pp::app::DocumentOpenPlanAction::prompt_discard_unsaved_project:
|
||||
return "prompt-discard-unsaved-project";
|
||||
case pp::app::DocumentOpenPlanAction::prompt_import_abr:
|
||||
return "prompt-import-abr";
|
||||
case pp::app::DocumentOpenPlanAction::prompt_import_ppbr:
|
||||
return "prompt-import-ppbr";
|
||||
}
|
||||
|
||||
return "open-project-now";
|
||||
}
|
||||
|
||||
const char* close_request_decision_name(pp::app::CloseRequestDecision decision) noexcept
|
||||
{
|
||||
switch (decision) {
|
||||
@@ -377,6 +398,7 @@ void print_help()
|
||||
<< " import-image --path FILE [--document-width N] [--document-height N] [--face N] [--x N] [--y N]\n"
|
||||
<< " inspect-project --path FILE\n"
|
||||
<< " classify-open --path FILE\n"
|
||||
<< " plan-open-route --path FILE [--unsaved]\n"
|
||||
<< " plan-document-file --work-dir DIR --name NAME [--target-exists]\n"
|
||||
<< " plan-document-version --directory DIR --doc-name NAME [--existing-path FILE]\n"
|
||||
<< " plan-export-target --kind file|collection|stem|name --doc-name NAME [--work-dir DIR] [--directory DIR] [--extension EXT] [--suffix SUFFIX]\n"
|
||||
@@ -1221,6 +1243,60 @@ int classify_open(int argc, char** argv)
|
||||
return 0;
|
||||
}
|
||||
|
||||
pp::foundation::Status parse_plan_open_route_args(
|
||||
int argc,
|
||||
char** argv,
|
||||
PlanOpenRouteArgs& args)
|
||||
{
|
||||
for (int i = 2; i < argc; ++i) {
|
||||
const std::string_view key(argv[i]);
|
||||
if (key == "--path") {
|
||||
if (i + 1 >= argc) {
|
||||
return pp::foundation::Status::invalid_argument("missing value for option");
|
||||
}
|
||||
args.path = argv[++i];
|
||||
} else if (key == "--unsaved") {
|
||||
args.unsaved = true;
|
||||
} else {
|
||||
return pp::foundation::Status::invalid_argument("unknown option");
|
||||
}
|
||||
}
|
||||
|
||||
if (args.path.empty()) {
|
||||
return pp::foundation::Status::invalid_argument("path must not be empty");
|
||||
}
|
||||
|
||||
return pp::foundation::Status::success();
|
||||
}
|
||||
|
||||
int plan_open_route(int argc, char** argv)
|
||||
{
|
||||
PlanOpenRouteArgs args;
|
||||
const auto status = parse_plan_open_route_args(argc, argv, args);
|
||||
if (!status.ok()) {
|
||||
print_error("plan-open-route", status.message);
|
||||
return 2;
|
||||
}
|
||||
|
||||
const auto route = pp::app::classify_document_open_path(args.path);
|
||||
if (!route) {
|
||||
print_error("plan-open-route", route.status().message);
|
||||
return 2;
|
||||
}
|
||||
|
||||
const auto action = pp::app::plan_document_open(route.value().kind, args.unsaved);
|
||||
std::cout << "{\"ok\":true,\"command\":\"plan-open-route\""
|
||||
<< ",\"route\":{\"kind\":\"" << document_open_kind_name(route.value().kind)
|
||||
<< "\",\"path\":\"" << json_escape(route.value().path)
|
||||
<< "\",\"directory\":\"" << json_escape(route.value().directory)
|
||||
<< "\",\"name\":\"" << json_escape(route.value().name)
|
||||
<< "\",\"extension\":\"" << json_escape(route.value().extension)
|
||||
<< "\"},\"state\":{\"unsaved\":" << json_bool(args.unsaved)
|
||||
<< "},\"plan\":{\"action\":\"" << document_open_plan_action_name(action)
|
||||
<< "\"}}\n";
|
||||
return 0;
|
||||
}
|
||||
|
||||
pp::foundation::Status parse_plan_document_file_args(
|
||||
int argc,
|
||||
char** argv,
|
||||
@@ -3475,6 +3551,10 @@ int main(int argc, char** argv)
|
||||
return classify_open(argc, argv);
|
||||
}
|
||||
|
||||
if (command == "plan-open-route") {
|
||||
return plan_open_route(argc, argv);
|
||||
}
|
||||
|
||||
if (command == "plan-document-file") {
|
||||
return plan_document_file(argc, argv);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user