diff options
author | emaste <emaste@FreeBSD.org> | 2013-08-23 18:06:42 +0000 |
---|---|---|
committer | emaste <emaste@FreeBSD.org> | 2013-08-23 18:06:42 +0000 |
commit | 424d4dadd208e2a1e9a43c3d55f47f03ba0c4509 (patch) | |
tree | 05d762b98a499804ce690e6ce04033f1ddf4dee6 /contrib/llvm/tools/lldb/source/Utility/Range.cpp | |
parent | cde487f27a84e02a560384f75178fddca68740f6 (diff) | |
parent | dcd15f81789e389c1cb27d264fcdddfd0a6002bd (diff) | |
download | FreeBSD-src-424d4dadd208e2a1e9a43c3d55f47f03ba0c4509.zip FreeBSD-src-424d4dadd208e2a1e9a43c3d55f47f03ba0c4509.tar.gz |
Merge lldb r188801 to contrib/llvm/tools/lldb/
Diffstat (limited to 'contrib/llvm/tools/lldb/source/Utility/Range.cpp')
-rw-r--r-- | contrib/llvm/tools/lldb/source/Utility/Range.cpp | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/contrib/llvm/tools/lldb/source/Utility/Range.cpp b/contrib/llvm/tools/lldb/source/Utility/Range.cpp new file mode 100644 index 0000000..158d1e7 --- /dev/null +++ b/contrib/llvm/tools/lldb/source/Utility/Range.cpp @@ -0,0 +1,103 @@ +//===--------------------- 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; +} |