X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Flayers.cpp;h=9219766de6952b49c52f28c292b6448e4ab6cc36;hb=5710504a95125fdf504c80ca6c445218514633fb;hp=c814c2257c995bb684a8b1f0421e1629e42030d9;hpb=ec9af67cd42ff42c2e76ac12133bd53bba5da0b7;p=staging%2Fwindowmanager.git diff --git a/src/layers.cpp b/src/layers.cpp index c814c22..9219766 100644 --- a/src/layers.cpp +++ b/src/layers.cpp @@ -26,12 +26,6 @@ namespace wm { using json = nlohmann::json; layer::layer(nlohmann::json const &j) { - if (j["type"] == "range") { - this->id_min = j["first_surface_id"]; - this->id_max = j["last_surface_id"]; - } else { - this->id_min = this->id_max = j["surface_id"]; - } this->role = j["role"]; this->name = j["name"]; this->layer_id = j["layer_id"]; @@ -42,6 +36,22 @@ layer::layer(nlohmann::json const &j) { jr["width"], jr["height"], jr["x"], jr["y"], }; } + auto split_layouts = j.find("split_layouts"); + if (split_layouts != j.end()) { + auto &sls = j["split_layouts"]; + // this->layouts.reserve(sls.size()); + std::transform(std::cbegin(sls), std::cend(sls), + std::back_inserter(this->layouts), [this](json const &sl) { + struct split_layout l { + sl["name"], sl["main_match"], sl["sub_match"] }; + logdebug( + "layer %d add split_layout \"%s\" (main: \"%s\") (sub: " + "\"%s\")", this->layer_id, + l.name.c_str(), l.main_match.c_str(), + l.sub_match.c_str()); + return l; + }); + } } struct result to_layer_map(nlohmann::json const &j) { @@ -51,26 +61,31 @@ struct result to_layer_map(nlohmann::json const &j) { std::transform(std::cbegin(m), std::cend(m), std::inserter(stl.mapping, stl.mapping.end()), - [](nlohmann::json const &j) { return layer(j); }); + [](nlohmann::json const &j) { + return std::pair( + j.value("layer_id", -1), layer(j)); + }); // XXX: add sanity checks here? // * check for double IDs // * check for double names/roles stl.layers.reserve(m.size()); - std::transform( - std::cbegin(stl.mapping), std::cend(stl.mapping), - std::back_inserter(stl.layers), [&stl](struct layer const &k) { - stl.roles.emplace_back(std::make_pair(k.role, k.layer_id)); - return unsigned(k.layer_id); - }); - - // XXX need to sort layers? + std::transform(std::cbegin(stl.mapping), std::cend(stl.mapping), + std::back_inserter(stl.layers), + [&stl](std::pair const &k) { + stl.roles.emplace_back( + std::make_pair(k.second.role, k.second.layer_id)); + return unsigned(k.second.layer_id); + }); + + std::sort(stl.layers.begin(), stl.layers.end()); + for (auto i : stl.mapping) { - if (i.name.empty()) { + if (i.second.name.empty()) { return Err("Found mapping w/o name"); } - if (i.layer_id == -1 || i.id_min == -1 || i.id_max == -1) { + if (i.second.layer_id == -1) { return Err("Found invalid/unset IDs in mapping"); } } @@ -78,30 +93,7 @@ struct result to_layer_map(nlohmann::json const &j) { auto msi = j.find("main_surface"); if (msi != j.end()) { stl.main_surface_name = msi->value("surface_role", ""); - stl.main_surface = - stl.main_surface_name.empty() ? int((*msi)["surface_id"]) : -1; - } - - // Check lookup - auto jtests = j.value("tests", json()); - - if (!jtests.empty()) { - logdebug("Embedded tests..."); - std::vector> tests; - tests.reserve(jtests.size()); - std::transform(std::cbegin(jtests), std::cend(jtests), - std::back_inserter(tests), [](json const &j) { - return std::make_pair(j["surface_id"], - j["expect_layer_id"]); - }); - - for (auto sid : tests) { - int lid = stl.get_layer_id(sid.first).value_or(-1); - logdebug("this=%d, that=%d, expect=%d", sid.first, lid, sid.second); - if (lid != sid.second) { - return Err("ID Map embedded test failed!"); - } - } + stl.main_surface = -1; } return Ok(stl); @@ -110,40 +102,12 @@ struct result to_layer_map(nlohmann::json const &j) { } } -// Helper to allow std::lower_bound with a int key only -inline bool - operator<(struct layer const &a, int b) { - return a.id_max < b; -} - -namespace { -optional 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 layer::id_max, so check - // that we are actually inside of an interval here. - if (i->id_min <= surface_id) { - return optional(*i); - } - } - - return nullopt; -} -} // namespace - optional layer_map::get_layer_id(int surface_id) { - auto e = get_surface_id_to_layer(this, surface_id); - if (!e) { - auto i = this->surfaces.find(surface_id); - if (i != this->surfaces.end()) { - return optional(int(i->second)); - } - return nullopt; + auto i = this->surfaces.find(surface_id); + if (i != this->surfaces.end()) { + return optional(i->second); } - return optional(e->layer_id); + return nullopt; } optional layer_map::get_layer_id(std::string const &role) { @@ -158,11 +122,6 @@ optional layer_map::get_layer_id(std::string const &role) { return nullopt; } -optional layer_map::get_layer_rect(int surface_id) { - auto e = get_surface_id_to_layer(this, surface_id); - return e ? optional(e->rect) : nullopt; -} - json layer::to_json() const { auto is_full = this->rect == genivi::full_rect; @@ -179,19 +138,15 @@ json layer::to_json() const { } return { - {"id_min", this->id_min}, - {"id_max", this->id_max}, - {"name", this->name}, - {"role", this->role}, - {"layer_id", this->layer_id}, - {"area", r}, + {"name", this->name}, {"role", this->role}, + {"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()); + j.push_back(i.second.to_json()); } return j; }