//===--------------------- Range.cpp -----------------------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "lldb/Utility/Range.h" using namespace lldb_utility; Range::Range (const Range& rng) : m_low(rng.m_low), m_high(rng.m_high) { InitRange(); } Range::Range (Range::ValueType low, Range::ValueType high) : m_low(low), m_high(high) { InitRange(); } void Range::InitRange () { if (m_low == OPEN_END) { if (m_high == OPEN_END) m_low = 0; else { // make an empty range m_low = 1; m_high = 0; } } } Range& Range::operator = (const Range& rhs) { if (&rhs != this) { this->m_low = rhs.m_low; this->m_high = rhs.m_high; } return *this; } void Range::Flip () { std::swap(m_high, m_low); } void Range::Intersection (const Range& other) { m_low = std::max(m_low,other.m_low); m_high = std::min(m_high,other.m_high); } void Range::Union (const Range& other) { m_low = std::min(m_low,other.m_low); m_high = std::max(m_high,other.m_high); } void Range::Iterate (RangeCallback callback) { ValueType counter = m_low; while (counter <= m_high) { bool should_continue = callback(counter); if (!should_continue) return; counter++; } } bool Range::IsEmpty () { return (m_low > m_high); } Range::ValueType Range::GetSize () { if (m_high == OPEN_END) return OPEN_END; if (m_high >= m_low) return m_high - m_low + 1; return 0; }