diff options
author | Kenji Hosokawa <khosokawa@jp.adit-jv.com> | 2020-08-24 21:58:42 +0900 |
---|---|---|
committer | Kenji Hosokawa <khosokawa@jp.adit-jv.com> | 2020-08-24 21:58:42 +0900 |
commit | 2b4ae7fde370bc3316ab30cc38b74d23e785b360 (patch) | |
tree | 41b6eb70b3419c2fbd192ed133c5890a985eddec /src/view/RBAAreaImpl.cpp | |
parent | 6694a4d2952ebd171564932200cac00d6e5792f4 (diff) |
First commitjellyfish_9.99.4jellyfish/9.99.49.99.4
Signed-off-by: Kenji Hosokawa <khosokawa@jp.adit-jv.com>
Change-Id: I381abb0a6521f5349768a76ef7ceecbce4b2d701
Diffstat (limited to 'src/view/RBAAreaImpl.cpp')
-rw-r--r-- | src/view/RBAAreaImpl.cpp | 222 |
1 files changed, 222 insertions, 0 deletions
diff --git a/src/view/RBAAreaImpl.cpp b/src/view/RBAAreaImpl.cpp new file mode 100644 index 0000000..ffc354f --- /dev/null +++ b/src/view/RBAAreaImpl.cpp @@ -0,0 +1,222 @@ +/** + * Copyright (c) 2019 DENSO CORPORATION. + * + * 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. + */ +/** + * Area imeplementation class + */ + +#include "RBAAreaImpl.hpp" + +#include "RBAArbitrationPolicy.hpp" +#include "RBAContent.hpp" +#include "RBASizeImpl.hpp" +#include "RBAViewContentImpl.hpp" +#include "RBAModelElementType.hpp" + +namespace rba +{ + +RBAAreaImpl::RBAAreaImpl(const std::string& name) + : RBARuleObject{name}, + RBAArea(), + RBAAllocatable{name} +{ +} + +std::string +RBAAreaImpl::getName() const +{ + return RBANamedElement::getElementName(); +} + +std::int32_t +RBAAreaImpl::getX() const +{ + return x_; +} + +std::int32_t +RBAAreaImpl::getY() const +{ + return y_; +} + +std::int32_t +RBAAreaImpl::getZorder() const +{ + return zorder_; +} + +const std::list<const RBAViewContent*>& +RBAAreaImpl::getContents() const +{ + if(externContents_.size() == 0U) { + for(const RBAContent* const content : getInternalContents()) { + if(content->isViewContent()) { + const RBAViewContentImpl* contentImpl + {dynamic_cast<const RBAViewContentImpl*>(content)}; + externContents_.push_back(contentImpl); + } + } + } + + return externContents_; +} + +const std::list<const RBAViewContent*>& +RBAAreaImpl::getAllViewContents() const +{ + if(externAllContents_.size() == 0U) { + for(const RBAViewContent* const content : getAllViewContentsRecursive(this)) { + externAllContents_.push_back(content); + } + } + + return externAllContents_; +} + +const std::list<const RBAViewContent*> +RBAAreaImpl::getAllViewContentsRecursive(const RBAAllocatable* const alloc) const +{ + std::list<const RBAViewContent*> contents; + if(alloc == nullptr) { + return contents; + } + + for(const RBAContent* const content : alloc->getInternalContents()) { + if(content->isViewContent()) { + const RBAViewContentImpl* contentImpl {dynamic_cast<const RBAViewContentImpl*>(content)}; + contents.push_back(contentImpl); + } + else { + const RBAAllocatable* const a {dynamic_cast<const RBAAllocatable*>(content)}; + if(a != nullptr) { + // @Deviation (MEM05-CPP,Rule-7_5_4,A7-5-2) + // [Contents that deviate from the rules] + // Recursively calling getAllViewContentsRecursive() + // [Why there is no problem if it deviate from the rules] + // When getAllViewContentsRecursive() is performed for Area associated + // with CyclicContent, it responds including ViewContent associated + // with CyclicContent. + // Multiple recursive calls may be made, such as when CyclicContent + // is assigned to CyclicContent, but the rule model definition + // is finite and stack overflow does not occur, so there is no problem. + for(const RBAViewContent* const c : getAllViewContentsRecursive(a)) { + contents.push_back(c); + } + } + } + } + + return contents; +} + +const std::list<const RBASize*>& +RBAAreaImpl::getSizes() const +{ + return externSizes_; +} + +RBAArbitrationPolicy +RBAAreaImpl::getArbitrationPolicy() const +{ + return getAllocatableArbitrationPolicy(); +} + +void +RBAAreaImpl::clearStatus() +{ + RBAAllocatable::clearStatus(); + resetCoordinate(); +} + +bool +RBAAreaImpl::isArea() const +{ + return true; +} + +void +RBAAreaImpl::setZorder(const std::int32_t newZorder) +{ + zorder_ = newZorder; +} + +void +RBAAreaImpl::setDefaultX(const std::int32_t defaultX) +{ + defaultX_ = defaultX; + x_ = defaultX; +} + +void +RBAAreaImpl::setDefaultY(const std::int32_t defaultY) +{ + defaultY_ = defaultY; + y_ = defaultY; +} + +void +RBAAreaImpl::setOffsetX(const std::int32_t offsetX) +{ + x_ = defaultX_ + offsetX; +} + +void +RBAAreaImpl::setOffsetY(const std::int32_t offsetY) +{ + y_ = defaultY_ + offsetY; +} + +void +RBAAreaImpl::addSize(const RBASizeImpl* size) +{ + externSizes_.push_back(size); +} + +void +RBAAreaImpl::addContent(const RBAViewContentImpl* const content) +{ + RBAAbstractAllocatable::addContent(content); +} + +void +RBAAreaImpl::resetCoordinate() +{ + x_ = defaultX_; + y_ = defaultY_; +} + +RBAModelElementType +RBAAreaImpl::getModelElementType() const +{ + return RBAModelElementType::Area; +} + +#ifdef RBA_USE_LOG +std::string +RBAAreaImpl::getSymbol() const +{ + return "Area"; +} + +std::string +RBAAreaImpl::getHiddenSymbol() const +{ + return "hidden"; +} +#endif + +} |