X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwm_layer.cpp;h=154d874c9b50fa734f399c148597162051fada6a;hb=2ce7162980b40cf5587ed8a0247f3e9bd3407ad7;hp=f02a5b62823962e1ef36413ec80db374006da306;hpb=a5106227c3c9ddbe2b07fbc2ecfc4e2ae1e4de74;p=apps%2Fagl-service-windowmanager.git diff --git a/src/wm_layer.cpp b/src/wm_layer.cpp index f02a5b6..154d874 100644 --- a/src/wm_layer.cpp +++ b/src/wm_layer.cpp @@ -26,6 +26,8 @@ using std::string; using std::vector; using std::unordered_map; +#define BG_LAYER_NAME "BackGroundLayer" + namespace wm { @@ -41,7 +43,7 @@ void LayerState::attachIdToArea(const string& area, const WMClient& client) this->render_order.push_back(client.layerID()); } -const unordered_map LayerState::popCurrentState() +const unordered_map LayerState::popCurrentState() { unordered_map tmp = this->area2appid; this->area2appid.clear(); @@ -49,7 +51,7 @@ const unordered_map LayerState::popCurrentState() return tmp; } -const unordered_map LayerState::getCurrentState() +const unordered_map LayerState::getCurrentState() { return this->area2appid; } @@ -59,7 +61,41 @@ const vector LayerState::getIviIdList() return this->render_order; } -WMLayer::WMLayer(json_object* j) : before_state(), state() +void LayerState::addLayer(unsigned layer) +{ + this->render_order.push_back(layer); +} + +void LayerState::removeLayer(unsigned layer) +{ + auto fwd_itr = std::remove_if( + this->render_order.begin(), this->render_order.end(), + [layer](unsigned elm) { + if(elm == layer) + HMI_DEBUG("remove layer %d", elm); + return elm == layer; + } + ); + this->render_order.erase(fwd_itr, this->render_order.end()); +} + +void LayerState::setArea(const string& app, const string& area) +{ + this->area2appid[area] = app; +} + +void LayerState::dump() +{ + std::string str; + for(const auto& ro : this->render_order) + { + str += std::to_string(ro); + str += ","; + } + DUMP(" render order : %s", str.c_str()); +} + +WMLayer::WMLayer(json_object* j, unsigned uuid) : tmp_state(), state(), uuid(uuid) { this->name = jh::getStringFromJson(j, "name"); this->role_list = jh::getStringFromJson(j, "role"); @@ -67,7 +103,7 @@ WMLayer::WMLayer(json_object* j) : before_state(), state() this->id_begin = static_cast(jh::getIntFromJson(j, "id_range_begin")); this->id_end = static_cast(jh::getIntFromJson(j, "id_range_end")); - if (name.size() == 0 || type || this->id_begin == 0 || this->id_end == 0) + if (name.size() == 0 || !type) { HMI_ERROR("Parse Error!!"); exit(1); @@ -84,21 +120,30 @@ WMLayer::WMLayer(json_object* j) : before_state(), state() unsigned WMLayer::getNewLayerID(const string& role) { unsigned ret = 0; - auto re = std::regex(this->role_list); - if (std::regex_match(role, re)) + if(this->name == BG_LAYER_NAME) + return ret; + + // generate new layer id; + if(this->hasRole(role)) { - // generate new layer id; - ret = this->id_list.back() + 1; - HMI_DEBUG("role %s matches layer %d, new layerID %d", role.c_str(), this->name.c_str(), ret); + if(this->id_list.size() == 0) + { + ret = this->idBegin(); + this->id_list.push_back(ret); + } + else + { + ret = this->id_list.back() + 1; + } + HMI_INFO("Generate new id: %d", ret); } - - if(ret == 0) + else { return ret; } - auto id_found = std::find(id_list.begin(), id_list.end(), ret); - if( (ret > this->idEnd()) || (id_found != id_list.cend()) ) + size_t count = std::count(id_list.begin(), id_list.end(), ret); + if( (ret > this->idEnd()) || (count > 1)) { HMI_NOTICE("id %d is not available then generate new id", ret); ret = 0; // reset @@ -132,37 +177,76 @@ const string& WMLayer::layerName() WMError WMLayer::setLayerState(const LayerState& l) { - this->before_state = l; + this->tmp_state = l; return WMError::SUCCESS; } +void WMLayer::addLayerToState(unsigned layer) +{ + this->tmp_state.addLayer(layer); +} + +void WMLayer::removeLayerFromState(unsigned layer) +{ + this->tmp_state.removeLayer(layer); +} + void WMLayer::appendArea(const string& area) { this->area_list.push_back(area); } -void WMLayer::removeLayerID(unsigned id) +void WMLayer::terminateApp(unsigned id) { auto fwd_itr = std::remove_if(this->id_list.begin(), this->id_list.end(), [id](unsigned elm) { return elm == id; }); this->id_list.erase(fwd_itr, this->id_list.end()); + this->tmp_state.removeLayer(id); + this->state.removeLayer(id); + ilm_layerRemove(id); +} + +bool WMLayer::hasLayerID(unsigned id) +{ + bool ret = (id > this->idBegin() && id < this->idEnd()); + if(!ret) + return ret; + auto itr = std::find(this->id_list.begin(), this->id_list.end(), id); + return (itr != this->id_list.end()) ? true : false; } -bool WMLayer::checkIDBelongTo(unsigned id) +bool WMLayer::hasRole(const string& role) { - return (id > this->idBegin() && id < this->idEnd()); + auto re = std::regex(this->role_list); + if (std::regex_match(role, re)) + { + HMI_DEBUG("role %s matches layer %s", role.c_str(), this->name.c_str()); + return true; + } + return false; } -/* WMError WMLayer::commitChange() +WMError WMLayer::commitChange() { - this->state = this->before_state; + this->state = this->tmp_state; + return WMError::SUCCESS; +} + +void WMLayer::dump() +{ + DUMP("===== wm layer status ====="); + DUMP("Layer :%s", this->name.c_str()); + this->tmp_state.dump(); + this->state.dump(); + DUMP("===== wm layer status end ====="); + } -void WMLayer::undo() +/* void WMLayer::undo() { - this->before_state = this->state; + this->tmp_state = this->state; } */ } // namespace wm