X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Flayers.cpp;h=a0665b78679818cffdc453da35d1e2ad62ff0727;hb=69a5f240268953b43aa89fdf414589ae3421aefc;hp=c814c2257c995bb684a8b1f0421e1629e42030d9;hpb=ec9af67cd42ff42c2e76ac12133bd53bba5da0b7;p=staging%2Fwindowmanager.git diff --git a/src/layers.cpp b/src/layers.cpp index c814c22..a0665b7 100644 --- a/src/layers.cpp +++ b/src/layers.cpp @@ -42,6 +42,28 @@ 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"], + sl.value("priority", 0) + }; + logdebug( + "layer %d add split_layout \"%s\" (main: \"%s\") (sub: " + "\"%s\") (prio: %d)", this->layer_id, + l.name.c_str(), l.main_match.c_str(), + l.sub_match.c_str(), l.prio); + return l; + }); + //std::sort(std::begin(this->layouts), std::end(this->layouts), + // [](struct split_layout const &a, struct split_layout const &b) { + // return a.prio < b.prio; + // }); + } } struct result to_layer_map(nlohmann::json const &j) { @@ -65,7 +87,8 @@ struct result to_layer_map(nlohmann::json const &j) { return unsigned(k.layer_id); }); - // XXX need to sort layers? + std::sort(stl.layers.begin(), stl.layers.end()); + for (auto i : stl.mapping) { if (i.name.empty()) { return Err("Found mapping w/o name"); @@ -179,12 +202,9 @@ 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}, + {"id_min", this->id_min}, {"id_max", this->id_max}, + {"name", this->name}, {"role", this->role}, + {"layer_id", this->layer_id}, {"area", r}, }; }