Plan document share decisions in app core
This commit is contained in:
@@ -2,6 +2,7 @@
|
||||
#include "app_core/document_cloud.h"
|
||||
#include "app_core/document_recording.h"
|
||||
#include "app_core/document_route.h"
|
||||
#include "app_core/document_sharing.h"
|
||||
#include "app_core/document_session.h"
|
||||
#include "assets/image_format.h"
|
||||
#include "assets/image_metadata.h"
|
||||
@@ -160,6 +161,10 @@ struct PlanRecordingSessionArgs {
|
||||
bool platform_deletes_recorded_files = false;
|
||||
};
|
||||
|
||||
struct PlanShareFileArgs {
|
||||
std::string path;
|
||||
};
|
||||
|
||||
struct SimulateAppSessionArgs {
|
||||
bool has_canvas = true;
|
||||
bool new_document = false;
|
||||
@@ -481,6 +486,18 @@ const char* recording_stop_action_name(pp::app::RecordingStopAction action) noex
|
||||
return "no-op-not-running";
|
||||
}
|
||||
|
||||
const char* document_share_action_name(pp::app::DocumentShareAction action) noexcept
|
||||
{
|
||||
switch (action) {
|
||||
case pp::app::DocumentShareAction::show_save_required_warning:
|
||||
return "show-save-required-warning";
|
||||
case pp::app::DocumentShareAction::share_now:
|
||||
return "share-now";
|
||||
}
|
||||
|
||||
return "show-save-required-warning";
|
||||
}
|
||||
|
||||
pp::foundation::Result<float> parse_float_arg(std::string_view text)
|
||||
{
|
||||
float value = 0.0F;
|
||||
@@ -521,6 +538,7 @@ void print_help()
|
||||
<< " plan-cloud-browse [--no-canvas] [--selected-file FILE]\n"
|
||||
<< " plan-cloud-upload-all [--file-count N] [--no-progress-ui]\n"
|
||||
<< " plan-recording-session [--running] [--frame-count N] [--platform-deletes-recorded-files]\n"
|
||||
<< " plan-share-file [--path FILE]\n"
|
||||
<< " load-project --path FILE\n"
|
||||
<< " parse-layout --path FILE\n"
|
||||
<< " record-render [--width N] [--height N] [--exercise-clear]\n"
|
||||
@@ -1854,6 +1872,43 @@ int plan_recording_session(int argc, char** argv)
|
||||
return 0;
|
||||
}
|
||||
|
||||
pp::foundation::Status parse_plan_share_file_args(
|
||||
int argc,
|
||||
char** argv,
|
||||
PlanShareFileArgs& 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 {
|
||||
return pp::foundation::Status::invalid_argument("unknown option");
|
||||
}
|
||||
}
|
||||
|
||||
return pp::foundation::Status::success();
|
||||
}
|
||||
|
||||
int plan_share_file(int argc, char** argv)
|
||||
{
|
||||
PlanShareFileArgs args;
|
||||
const auto status = parse_plan_share_file_args(argc, argv, args);
|
||||
if (!status.ok()) {
|
||||
print_error("plan-share-file", status.message);
|
||||
return 2;
|
||||
}
|
||||
|
||||
const auto decision = pp::app::plan_document_share(args.path);
|
||||
std::cout << "{\"ok\":true,\"command\":\"plan-share-file\""
|
||||
<< ",\"state\":{\"path\":\"" << json_escape(args.path)
|
||||
<< "\"},\"decision\":\"" << document_share_action_name(decision)
|
||||
<< "\"}\n";
|
||||
return 0;
|
||||
}
|
||||
|
||||
pp::foundation::Status parse_plan_export_target_args(
|
||||
int argc,
|
||||
char** argv,
|
||||
@@ -4021,6 +4076,10 @@ int main(int argc, char** argv)
|
||||
return plan_recording_session(argc, argv);
|
||||
}
|
||||
|
||||
if (command == "plan-share-file") {
|
||||
return plan_share_file(argc, argv);
|
||||
}
|
||||
|
||||
if (command == "load-project") {
|
||||
return load_project(argc, argv);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user