app/api: add demo_activate_surface() api_binding
[staging/windowmanager.git] / src / layers.cpp
index 7cc2f00..6eae48a 100644 (file)
@@ -1,3 +1,19 @@
+/*
+ * Copyright (C) 2017 Mentor Graphics Development (Deutschland) GmbH
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
 //
 // Created by m on 7/27/17.
 //
@@ -12,7 +28,7 @@ namespace wm {
 
 using json = nlohmann::json;
 
-surface_id_to_layer::surface_id_to_layer(nlohmann::json const &j) {
+layer::layer(nlohmann::json const &j) {
    DB(j);
    if (j["type"] == "range") {
       this->id_min = get<int>(j["first_surface_id"]);
@@ -22,7 +38,7 @@ surface_id_to_layer::surface_id_to_layer(nlohmann::json const &j) {
    }
    this->name = j["name"].get<std::string>();
    this->layer_id = get<int>(j["layer_id"]);
-   this->rect = genivi::rect{-1, -1, 0, 0};
+   this->rect = genivi::full_rect;
    if (j["area"]["type"] == "rect") {
       auto jr = j["area"]["rect"];
       this->rect = genivi::rect{
@@ -32,32 +48,34 @@ surface_id_to_layer::surface_id_to_layer(nlohmann::json const &j) {
    }
 }
 
-struct result<struct surface_id_to_layer_map> to_surface_id_to_layer_map(
-   nlohmann::json const &j) {
+struct result<struct layer_map> to_layer_map(nlohmann::json const &j) {
    DB(j);
    try {
-      surface_id_to_layer_map stl{};
+      layer_map stl{};
       auto m = j["mappings"];
       stl.layers.reserve(m.size());
       std::transform(std::cbegin(m), std::cend(m),
                      std::inserter(stl.mapping, stl.mapping.end()),
                      [&stl](nlohmann::json const &j) {
-                        auto k = surface_id_to_layer(j);
+                        auto k = layer(j);
                         stl.layers.push_back(unsigned(k.layer_id));
                         return k;
                      });
       // XXX need to sort layers?
       for (auto i : stl.mapping) {
          if (i.name.empty()) {
-            return Err<struct surface_id_to_layer_map>(
-               "Found mapping w/o name");
+            return Err<struct layer_map>("Found mapping w/o name");
          }
          if (i.layer_id == -1 || i.id_min == -1 || i.id_max == -1) {
-            return Err<struct surface_id_to_layer_map>(
-               "Found invalid/unset IDs in mapping");
+            return Err<struct layer_map>("Found invalid/unset IDs in mapping");
          }
       }
 
+      auto msi = j.find("main_surface");
+      if (msi != j.end()) {
+         stl.main_surface = get<int>((*msi)["surface_id"]);
+      }
+
       // Check lookup
       auto jtests = j.value("tests", json());
 
@@ -73,39 +91,38 @@ struct result<struct surface_id_to_layer_map> to_surface_id_to_layer_map(
                         });
 
          for (auto sid : tests) {
-            int lid = stl.get_layer_for_surface(sid.first).value_or(-1);
+            int lid = stl.get_layer_id(sid.first).value_or(-1);
             DB("this=" << sid.first << ", that=" << lid
                        << ", expect=" << sid.second);
             if (lid != sid.second) {
-               return Err<surface_id_to_layer_map>(
-                  "ID Map embedded test failed!");
+               return Err<layer_map>("ID Map embedded test failed!");
             }
          }
       }
 
       return Ok(stl);
    } catch (std::exception &e) {
-      return Err<struct surface_id_to_layer_map>(e.what());
+      return Err<struct layer_map>(e.what());
    }
 }
 
 // Helper to allow std::lower_bound with a int key only
 inline bool
-   operator<(struct surface_id_to_layer const &a, int b) {
+   operator<(struct layer const &a, int b) {
    return a.id_max < b;
 }
 
 namespace {
-optional<surface_id_to_layer> get_surface_id_to_layer(
-   struct surface_id_to_layer_map const *s2l, int surface_id) {
+optional<layer> get_surface_id_to_layer(struct layer_map const *s2l,
+                                        int surface_id) {
    auto i = std::lower_bound(std::cbegin(s2l->mapping), std::cend(s2l->mapping),
                              surface_id);
 
    if (i != s2l->mapping.end()) {
-      // std::less only checks for surface_id_to_layer::id_max, so check
+      // std::less only checks for layer::id_max, so check
       // that we are actually inside of an interval here.
       if (i->id_min <= surface_id) {
-         return optional<surface_id_to_layer>(*i);
+         return optional<layer>(*i);
       }
    }
 
@@ -113,15 +130,46 @@ optional<surface_id_to_layer> get_surface_id_to_layer(
 }
 }
 
-optional<int> surface_id_to_layer_map::get_layer_for_surface(int surface_id) {
+optional<int> layer_map::get_layer_id(int surface_id) {
    auto e = get_surface_id_to_layer(this, surface_id);
    return e ? optional<int>(e->layer_id) : nullopt;
 }
 
-optional<genivi::rect> surface_id_to_layer_map::get_rect_for_surface(
-   int surface_id) {
+optional<genivi::rect> layer_map::get_layer_rect(int surface_id) {
    auto e = get_surface_id_to_layer(this, surface_id);
    return e ? optional<genivi::rect>(e->rect) : nullopt;
 }
 
+json layer::to_json() const {
+   auto is_full = this->rect == genivi::full_rect;
+
+   json r{};
+   if (is_full) {
+      r = {{"type", "full"}};
+   } else {
+      r = {{"type", "rect"},
+           {"rect",
+            {{"x", this->rect.x},
+             {"y", this->rect.y},
+             {"width", this->rect.w},
+             {"height", this->rect.h}}}};
+   }
+
+   return {
+      {"id_min", this->id_min},
+      {"id_max", this->id_max},
+      {"name", this->name},
+      {"layer_id", this->layer_id},
+      {"area", r},
+   };
+}
+
+json layer_map::to_json() const {
+   json j{};
+   for (auto const &i: this->mapping) {
+      j.push_back(i.to_json());
+   }
+   return j;
+}
+
 }  // namespace wm