From c34df76272c17401955f6daf30ca9c7e7671ae56 Mon Sep 17 00:00:00 2001 From: Andreas Hansson Date: Wed, 19 Sep 2012 06:15:43 -0400 Subject: AddrRange: Simplify Range by removing stream input/output This patch simplifies the Range class in preparation for the introduction of a more specific AddrRange class that allows interleaving/striping. The only place where the parsing was used was in the unit test. --- src/base/SConscript | 1 - src/base/range.cc | 85 ----------------------------------------------------- src/base/range.hh | 36 ----------------------- 3 files changed, 122 deletions(-) delete mode 100644 src/base/range.cc (limited to 'src/base') diff --git a/src/base/SConscript b/src/base/SConscript index 8790942cd..ff6d696d4 100644 --- a/src/base/SConscript +++ b/src/base/SConscript @@ -52,7 +52,6 @@ Source('output.cc') Source('pollevent.cc') Source('random.cc') Source('random_mt.cc') -Source('range.cc') if env['TARGET_ISA'] != 'no': Source('remote_gdb.cc') Source('socket.cc') diff --git a/src/base/range.cc b/src/base/range.cc deleted file mode 100644 index c50dff056..000000000 --- a/src/base/range.cc +++ /dev/null @@ -1,85 +0,0 @@ -/* - * Copyright (c) 2004-2005 The Regents of The University of Michigan - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are - * met: redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer; - * redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution; - * neither the name of the copyright holders nor the names of its - * contributors may be used to endorse or promote products derived from - * this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT - * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, - * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT - * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, - * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY - * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT - * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - * - * Authors: Nathan Binkert - */ - -#include "base/intmath.hh" -#include "base/range.hh" -#include "base/str.hh" - -using namespace std; - -template -bool -__x_parse_range(const std::string &str, T &first, T &last) -{ - std::vector values; - tokenize(values, str, ':'); - - T thefirst, thelast; - - if (values.size() != 2) - return false; - - std::string s = values[0]; - std::string e = values[1]; - - if (!to_number(s, thefirst)) - return false; - - bool increment = (e[0] == '+'); - if (increment) - e = e.substr(1); - - if (!to_number(e, thelast)) - return false; - - if (increment) - thelast += thefirst - 1; - - first = thefirst; - last = thelast; - - return true; -} - -#define RANGE_PARSE(type) \ -template<> bool \ -__parse_range(const std::string &s, type &first, type &last) \ -{ return __x_parse_range(s, first, last); } - -RANGE_PARSE(unsigned long long) -RANGE_PARSE(signed long long) -RANGE_PARSE(unsigned long) -RANGE_PARSE(signed long) -RANGE_PARSE(unsigned int) -RANGE_PARSE(signed int) -RANGE_PARSE(unsigned short) -RANGE_PARSE(signed short) -RANGE_PARSE(unsigned char) -RANGE_PARSE(signed char) diff --git a/src/base/range.hh b/src/base/range.hh index ac64a37f9..3b1a9277b 100644 --- a/src/base/range.hh +++ b/src/base/range.hh @@ -32,21 +32,6 @@ #ifndef __BASE_RANGE_HH__ #define __BASE_RANGE_HH__ -#include -#include -#include - -/** - * @param s range string - * EndExclusive Ranges are in the following format: - * @verbatim - * := {}:{} - * := | + - * @endverbatim - */ -template -bool __parse_range(const std::string &s, T &start, T &end); - template struct Range { @@ -65,12 +50,6 @@ struct Range : start(r.start), end(r.end) {} - Range(const std::string &s) - { - if (!__parse_range(s, start, end)) - invalidate(); - } - template const Range &operator=(const Range &r) { @@ -87,26 +66,11 @@ struct Range return *this; } - const Range &operator=(const std::string &s) - { - if (!__parse_range(s, start, end)) - invalidate(); - return *this; - } - void invalidate() { start = 1; end = 0; } T size() const { return end - start + 1; } bool valid() const { return start < end; } }; -template -inline std::ostream & -operator<<(std::ostream &o, const Range &r) -{ - o << '[' << r.start << "," << r.end << ']'; - return o; -} - template inline Range RangeEx(T start, T end) -- cgit v1.2.3