grpc-proxy: Extend AglShellSetSplit from gRPC proxy
[src/agl-compositor.git] / grpc-proxy / shell.cpp
index cc6ead6..8e78b20 100644 (file)
@@ -31,6 +31,7 @@
 #include <queue>
 
 #include "main-grpc.h"
+#include "log.h"
 #include "shell.h"
 
 void
@@ -61,18 +62,105 @@ Shell::ActivateApp(const std::string &app_id, const std::string &output_name)
 void
 Shell::DeactivateApp(const std::string &app_id)
 {
-       (void) app_id;
+       struct agl_shell *shell = this->m_shell.get();
+
+       agl_shell_deactivate_app(shell, app_id.c_str());
+       wl_display_flush(m_shell_data->wl_display);
 }
 
 void
-Shell::SetAppFloat(const std::string &app_id)
+Shell::SetAppFloat(const std::string &app_id, int32_t x_pos, int32_t y_pos)
 {
-       (void) app_id;
+       struct agl_shell *shell = this->m_shell.get();
+
+       agl_shell_set_app_float(shell, app_id.c_str(), x_pos, y_pos);
+       wl_display_flush(m_shell_data->wl_display);
 }
 
 void
-Shell::SetAppSplit(const std::string &app_id, uint32_t orientation)
+Shell::SetAppNormal(const std::string &app_id)
 {
-       (void) app_id;
-       (void) orientation;
+       struct agl_shell *shell = this->m_shell.get();
+
+       agl_shell_set_app_normal(shell, app_id.c_str());
+       wl_display_flush(m_shell_data->wl_display);
+}
+
+void
+Shell::SetAppFullscreen(const std::string &app_id)
+{
+       struct agl_shell *shell = this->m_shell.get();
+
+       agl_shell_set_app_fullscreen(shell, app_id.c_str());
+       wl_display_flush(m_shell_data->wl_display);
+}
+
+void
+Shell::SetAppOnOutput(const std::string &app_id, const std::string &output)
+{
+       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.c_str())) {
+                       w_output = woutput;
+                       break;
+               }
+       }
+
+       if (!w_output) {
+               LOG("Could not found output '%s' to set the application\n", output.c_str());
+               return;
+       }
+
+       agl_shell_set_app_output(shell, app_id.c_str(), w_output->output);
+       wl_display_flush(m_shell_data->wl_display);
+}
+
+void
+Shell::SetAppPosition(const std::string &app_id, const int32_t x, const int32_t y)
+{
+       struct agl_shell *shell = this->m_shell.get();
+
+       agl_shell_set_app_position(shell, app_id.c_str(), x, y);
+       wl_display_flush(m_shell_data->wl_display);
+}
+
+void
+Shell::SetAppScale(const std::string &app_id,
+               const int32_t width, const int32_t height)
+{
+       struct agl_shell *shell = this->m_shell.get();
+
+       agl_shell_set_app_scale(shell, app_id.c_str(), width, height);
+       wl_display_flush(m_shell_data->wl_display);
+}
+
+void
+Shell::SetAppSplit(const std::string &app_id, uint32_t orientation, const std::string &output_name)
+{
+       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);
 }