/* * KiRouter - a push-and-(sometimes-)shove PCB router * * Copyright (C) 2013-2014 CERN * Author: Tomasz Wlostowski * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation, either version 3 of the License, or (at your * option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ #ifndef __RANGE_H #define __RANGE_H template class RANGE { public: RANGE (T aMin, T aMax) : m_min(aMin), m_max(aMax), m_defined(true) {} RANGE (): m_defined (false) {}; T MinV() const { return m_min; } T MaxV() const { return m_max; } void Set ( T aMin, T aMax ) const { m_max = aMax; m_min = aMin; } void Grow ( T value ) { if(!m_defined) { m_min = value; m_max = value; m_defined = true; } else { m_min = std::min(m_min, value); m_max = std::max(m_max, value); } } bool Inside ( const T& value ) const { if(!m_defined) return true; return value >= m_min && value <= m_max; } bool Overlaps ( const RANGE &aOther ) const { if(!m_defined || !aOther.m_defined) return true; return m_max >= aOther.m_min && m_min <= aOther.m_max; } bool Defined() const { return m_defined; } private: T m_min, m_max; bool m_defined; }; #endif