• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdesdk API Reference
  • KDE Home
  • Contact Us
 

okteta

  • sources
  • kde-4.12
  • kdesdk
  • okteta
  • core
addressrangelist.cpp
Go to the documentation of this file.
1 /*
2  This file is part of the Okteta Core library, made within the KDE community.
3 
4  Copyright 2003 Friedrich W. H. Kossebau <kossebau@kde.org>
5 
6  This library is free software; you can redistribute it and/or
7  modify it under the terms of the GNU Lesser General Public
8  License as published by the Free Software Foundation; either
9  version 2.1 of the License, or (at your option) version 3, or any
10  later version accepted by the membership of KDE e.V. (or its
11  successor approved by the membership of KDE e.V.), which shall
12  act as a proxy defined in AddressRange 6 of version 3 of the license.
13 
14  This library is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  Lesser General Public License for more details.
18 
19  You should have received a copy of the GNU Lesser General Public
20  License along with this library. If not, see <http://www.gnu.org/licenses/>.
21 */
22 
23 #include "addressrangelist.h"
24 
25 
26 namespace Okteta
27 {
28 
29 AddressRangeList::AddressRangeList() {}
30 
31 
32 void AddressRangeList::addAddressRange( const AddressRange& newAddressRange )
33 {
34  if( !newAddressRange.isValid() )
35  return;
36 
37  // we try to insert it by ascending indizes
38  // if addressRanges are overlapping we combine them
39  Iterator firstOverlappingIt = begin();
40  for( ; firstOverlappingIt!=end(); ++firstOverlappingIt )
41  {
42  // new addressRange before next addressRange?
43  if( newAddressRange.endsBefore((*firstOverlappingIt).nextBeforeStart()) )
44  {
45  // put the new before it
46  insert( firstOverlappingIt, newAddressRange );
47  return;
48  }
49 
50  // does the next addressRange overlap?
51  if( (*firstOverlappingIt).isJoinable(newAddressRange) )
52  {
53  AddressRange joinedAddressRange( newAddressRange );
54  // Start of the joined addressRanges is the smaller one
55  joinedAddressRange.extendStartTo( (*firstOverlappingIt).start() );
56  // next we search all the overlapping addressRanges and keep the highest end index
57  int joinedEnd = (*firstOverlappingIt).end();
58  Iterator lastOverlappingIt = firstOverlappingIt;
59  for( ++lastOverlappingIt; lastOverlappingIt!=end(); ++lastOverlappingIt )
60  {
61  if( joinedAddressRange.endsBefore((*lastOverlappingIt).nextBeforeStart()) )
62  break;
63  joinedEnd = (*lastOverlappingIt).end();
64  }
65  // the higher end is the end of the joined addressRange
66  joinedAddressRange.extendEndTo( joinedEnd );
67  // remove all overlapping addressRanges
68  firstOverlappingIt = erase( firstOverlappingIt, lastOverlappingIt );
69  // and instead insert the joined one
70  insert( firstOverlappingIt, joinedAddressRange );
71  return;
72  }
73  }
74 
75  // all others before the new?
76  if( firstOverlappingIt == end() )
77  // add it at the end
78  append( newAddressRange );
79 }
80 
81 void AddressRangeList::addAddressRangeList( const AddressRangeList& addressRangeList )
82 {
83  // TODO: optimize with two parallel iterators
84  foreach( const AddressRange& addressRange, addressRangeList )
85  addAddressRange( addressRange );
86 }
87 
88 
89 AddressRangeList::~AddressRangeList() {}
90 
91 }
KDE::Range::extendEndTo
void extendEndTo(T Limit)
extends the end to Limit.
Definition: range.h:76
Okteta::AddressRangeList::addAddressRange
void addAddressRange(const AddressRange &addressRange)
Definition: addressrangelist.cpp:32
KDE::NumberRange< Address, Size >
addressrangelist.h
Okteta::AddressRangeList::AddressRangeList
AddressRangeList()
Definition: addressrangelist.cpp:29
Okteta::AddressRangeList::~AddressRangeList
~AddressRangeList()
Definition: addressrangelist.cpp:89
KDE::Range::extendStartTo
void extendStartTo(T Limit)
extends the start to Limit.
Definition: range.h:74
KDE::Range::endsBefore
bool endsBefore(T Value) const
returns true if range is before index.
Definition: range.h:103
Okteta::AddressRangeList
Definition: addressrangelist.h:38
KDE::Range::isValid
bool isValid() const
returns true if the range covers at least one index
Definition: range.h:122
Okteta::AddressRangeList::addAddressRangeList
void addAddressRangeList(const AddressRangeList &addressRangeList)
Definition: addressrangelist.cpp:81
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 23:04:06 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

okteta

Skip menu "okteta"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Related Pages

kdesdk API Reference

Skip menu "kdesdk API Reference"
  • kapptemplate
  • kcachegrind
  • kompare
  • lokalize
  • okteta
  • umbrello
  •   umbrello

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal