message SplitRequest {
string app_id = 1;
int32 tile_orientation = 2;
+ string output_name = 3;
}
message SplitResponse {
LOG("m_aglShell not set-up\n");
return nullptr;
}
- m_aglShell->SetAppSplit(request->app_id(), request->tile_orientation());
+ m_aglShell->SetAppSplit(request->app_id(), request->tile_orientation(), request->output_name());
grpc::ServerUnaryReactor* reactor = context->DefaultReactor();
reactor->Finish(grpc::Status::OK);
}
void
-Shell::SetAppSplit(const std::string &app_id, uint32_t orientation)
+Shell::SetAppSplit(const std::string &app_id, uint32_t orientation, const std::string &output_name)
{
- (void) app_id;
- (void) orientation;
+ struct window_output *woutput, *w_output;
+ struct agl_shell *shell = this->m_shell.get();
+
+ woutput = nullptr;
+ w_output = nullptr;
+
+ wl_list_for_each(woutput, &m_shell_data->output_list, link) {
+ if (woutput->name && !strcmp(woutput->name, output_name.c_str())) {
+ w_output = woutput;
+ break;
+ }
+ }
+
+ // else, get the first one available
+ if (!w_output)
+ w_output = wl_container_of(m_shell_data->output_list.prev,
+ w_output, link);
+
+
+ agl_shell_set_app_split(shell, app_id.c_str(), orientation, w_output->output);
+ wl_display_flush(m_shell_data->wl_display);
}
m_shell(shell), m_shell_data(sh_data) { }
void ActivateApp(const std::string &app_id, const std::string &output_name);
void DeactivateApp(const std::string &app_id);
- void SetAppSplit(const std::string &app_id, uint32_t orientation);
+ void SetAppSplit(const std::string &app_id, uint32_t orientation, const std::string &output_name);
void SetAppFloat(const std::string &app_id,
int32_t x_pos, int32_t y_pos);
void SetAppNormal(const std::string &app_id);