summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcus Fritzsch <marcus_fritzsch@mentor.com>2017-08-03 12:38:51 +0200
committerMarcus Fritzsch <marcus_fritzsch@mentor.com>2017-08-08 17:24:00 +0200
commitd41f142b48e7d38031be8339b15e377d5b264b0a (patch)
treec16e20b284f2cfbac18730e8d4e187fc857427e3
parent895f0779a75df433b46a0a7b9e6dd845da884018 (diff)
app/api: add demo_activate_all()
Signed-off-by: Marcus Fritzsch <marcus_fritzsch@mentor.com>
-rw-r--r--generate-binding-glue.py1
-rw-r--r--src/app.cpp14
2 files changed, 13 insertions, 2 deletions
diff --git a/generate-binding-glue.py b/generate-binding-glue.py
index 7aaad36..43bc742 100644
--- a/generate-binding-glue.py
+++ b/generate-binding-glue.py
@@ -108,6 +108,7 @@ API = {
],
},
{ 'name': 'demo_activate_surface', 'args': [ { 'name': 'surfaceid', 'type': 'uint32_t', 'jtype': 'int' } ] },
+ { 'name': 'demo_activate_all' },
{ 'name': 'debug_status', },
{ 'name': 'debug_layers', },
{ 'name': 'debug_surfaces', },
diff --git a/src/app.cpp b/src/app.cpp
index 57d1b17..88ee0fa 100644
--- a/src/app.cpp
+++ b/src/app.cpp
@@ -330,15 +330,16 @@ char const *App::activate_surface(uint32_t surface_id) {
// Make it visible, no (or little effect) if already visible
auto &s = this->controller->surfaces[surface_id];
- s->set_visibility(1);
// Set all others invisible
for (auto &i: this->controller->surfaces) {
auto &si = this->controller->sprops[i.second->id];
- if (si.visibility == 1 && si.id != s->id && int(si.id) != this->layers.main_surface) {
+ if (si.visibility == 1 && si.id != s->id &&
+ int(si.id) != this->layers.main_surface) {
i.second->set_visibility(0);
}
}
+ s->set_visibility(1);
// commit changes
this->controller->commit_changes();
@@ -438,6 +439,15 @@ binding_api::result_type binding_api::demo_activate_surface(
return Ok(json_object_new_object());
}
+binding_api::result_type binding_api::demo_activate_all() {
+ for (auto &s: this->app->controller->surfaces) {
+ s.second->set_visibility(1);
+ }
+ this->app->controller->commit_changes();
+ this->app->display->flush();
+ return Ok(json_object_new_object());
+}
+
// _ _ _ _ _
// ___ ___ _ __ | |_ _ __ ___ | | | ___ _ __ | |__ ___ ___ | | _____
// / __/ _ \| '_ \| __| '__/ _ \| | |/ _ \ '__|| '_ \ / _ \ / _ \| |/ / __|