/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */ /* * Main authors: * Christian Schulte * * Contributing authors: * Guido Tack * * Copyright: * Christian Schulte, 2004 * Guido Tack, 2004 * * Last modified: * $Date: 2011-05-11 20:44:17 +1000 (Wed, 11 May 2011) $ by $Author: tack $ * $Revision: 12001 $ * * This file is part of Gecode, the generic constraint * development environment: * http://www.gecode.org * * 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. * */ namespace Gecode { /** * \brief Lists of ranges (intervals) * * This class implements a simple datastructure for storing sets of * integers as lists of ranges (intervals). Memory is managed as * space-allocated free lists. * * \ingroup FuncMemSpace */ class RangeList : public FreeList { protected: /// Minimum of range int _min; /// Maximum of range int _max; public: /// \name Constructors //@{ /// Default constructor (noop) RangeList(void); /// Initialize with minimum \a min and maximum \a max and successor \a n RangeList(int min, int max, RangeList* n); //@} /// \name Access //@{ /// Return minimum int min(void) const; /// Return maximum int max(void) const; /// Return width (distance between maximum and minimum) unsigned int width(void) const; /// Return next element RangeList* next(void) const; //@} /// \name Update //@{ /// Set minimum to \a n void min(int n); /// Set maximum to \a n void max(int n); /// Set next rane to \a n void next(RangeList* n); //@} /// \name Memory management //@{ /** * \brief Free memory for all elements between this and \a l (inclusive) */ void dispose(Space& home, RangeList* l); /// Allocate memory from space static void* operator new(size_t s, Space& home); /// Placement-new operator (noop) static void* operator new(size_t s, void* p); /// No-op (for exceptions) static void operator delete(void*); /// No-op (use dispose instead) static void operator delete(void*, Space& home); /// No-op (use dispose instead) static void operator delete(void*, void*); //@} }; /* * Range lists * */ forceinline RangeList::RangeList(void) {} forceinline RangeList::RangeList(int min, int max, RangeList* n) : FreeList(n), _min(min), _max(max) {} forceinline RangeList* RangeList::next() const { return static_cast(FreeList::next()); } forceinline void RangeList::min(int n) { _min = n; } forceinline void RangeList::max(int n) { _max = n; } forceinline void RangeList::next(RangeList* n) { FreeList::next(n); } forceinline int RangeList::min(void) const { return _min; } forceinline int RangeList::max(void) const { return _max; } forceinline unsigned int RangeList::width(void) const { return static_cast(_max - _min + 1); } forceinline void RangeList::operator delete(void*) {} forceinline void RangeList::operator delete(void*, Space&) { GECODE_NEVER; } forceinline void RangeList::operator delete(void*, void*) { GECODE_NEVER; } forceinline void* RangeList::operator new(size_t, Space& home) { return home.fl_alloc(); } forceinline void* RangeList::operator new(size_t, void* p) { return p; } forceinline void RangeList::dispose(Space& home, RangeList* l) { home.fl_dispose(this,l); } } // STATISTICS: kernel-other