/***************************************************************************************** * * * OpenSpace * * * * Copyright (c) 2014-2020 * * * * Permission is hereby granted, free of charge, to any person obtaining a copy of this * * software and associated documentation files (the "Software"), to deal in the Software * * without restriction, including without limitation the rights to use, copy, modify, * * merge, publish, distribute, sublicense, and/or sell copies of the Software, and to * * permit persons to whom the Software is furnished to do so, subject to the following * * conditions: * * * * The above copyright notice and this permission notice shall be included in all copies * * or substantial portions of the Software. * * * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A * * PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF * * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE * * OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * ****************************************************************************************/ #include #include #include #include #include #include namespace { constexpr const openspace::properties::Property::PropertyInfo TimeFramesInfo = { "TimeFrames", "Time Frames", "A vector of time frames to combine into one. " "The time frame is active when any of the contained time frames are, " "but not in gaps between contained time frames." }; } // namespace namespace openspace { documentation::Documentation TimeFrameUnion::Documentation() { using namespace openspace::documentation; return { "Time Frame Union", "base_time_frame_union", { { TimeFramesInfo.identifier, new TableVerifier({ { "*", new ReferencingVerifier("core_time_frame"), Optional::Yes } }), Optional::No, TimeFramesInfo.description }, } }; } bool TimeFrameUnion::isActive(const Time& time) const { for (const auto& tf : _timeFrames) { if (tf->isActive(time)) { return true; } } return false; } TimeFrameUnion::TimeFrameUnion(const ghoul::Dictionary& dictionary) : TimeFrame() { documentation::testSpecificationAndThrow(Documentation(), dictionary, "TimeFrameUnion"); ghoul::Dictionary frames = dictionary.value(TimeFramesInfo.identifier); for (const std::string& k : frames.keys()) { const ghoul::Dictionary& subDictionary = frames.value(k); _timeFrames.push_back(TimeFrame::createFromDictionary(subDictionary)); TimeFrame& subFrame = *_timeFrames.back(); subFrame.setIdentifier(k); subFrame.setGuiName(k); subFrame.setDescription(k); addPropertySubOwner(*_timeFrames.back()); } } } // namespace openspace