aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--layers.json7
-rw-r--r--src/app.cpp17
-rw-r--r--src/app.hpp2
3 files changed, 24 insertions, 2 deletions
diff --git a/layers.json b/layers.json
index 98d69e0..bf0a6f9 100644
--- a/layers.json
+++ b/layers.json
@@ -22,6 +22,13 @@
"comment": "Range of IDs that will always be placed on layer 1001, negative rect values are interpreted as output_size.dimension - $value"
},
{
+ "role": "^XDG$",
+ "name": "xdg-apps",
+ "layer_id": 1002,
+ "area": { "type": "rect", "rect": { "x": 0, "y": 218, "width": -1, "height": -433 } },
+ "comment": "Range of IDs dedicated for XDG apps that will always be placed on layer 1002, negative rect values are interpreted as output_size.dimension - $value"
+ },
+ {
"role": "^OnScreen.*",
"name": "popups",
"layer_id": 9999,
diff --git a/src/app.cpp b/src/app.cpp
index 307217e..324825f 100644
--- a/src/app.cpp
+++ b/src/app.cpp
@@ -596,9 +596,22 @@ void App::api_ping() { this->dispatch_pending_events(); }
void App::surface_created(uint32_t surface_id) {
auto layer_id = this->layers.get_layer_id(surface_id);
if (!layer_id) {
- HMI_DEBUG("wm", "Newly created surfce %d is not associated with any layer!",
+ HMI_DEBUG("wm", "Newly created surface %d is not associated with any layer! Must be a XDG apps",
surface_id);
- return;
+ auto layer_id = this->layers.get_layer_id(XDG_DRAWING_NAME);
+ if(!layer_id)
+ {
+ HMI_DEBUG("wm", "No role found for that XDG App");
+ return;
+ }
+
+ this->layers.add_surface(surface_id, *layer_id);
+ // set the main_surface[_name] here and now
+ if (!this->layers.main_surface_name.empty() &&
+ this->layers.main_surface_name == XDG_DRAWING_NAME) {
+ this->layers.main_surface = surface_id;
+ HMI_DEBUG("wm", "Set main_surface id to %u", surface_id);
+ }
}
HMI_DEBUG("wm", "surface_id is %u, layer_id is %u", surface_id, *layer_id);
diff --git a/src/app.hpp b/src/app.hpp
index 413d1c9..41642c1 100644
--- a/src/app.hpp
+++ b/src/app.hpp
@@ -35,6 +35,8 @@
#include "wayland.hpp"
#include "hmi-debug.h"
+#define XDG_DRAWING_NAME "XDG"
+
namespace wl {
struct display;
}