• 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
  • piecetable
replacepiecetablechange.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 2008 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 Section 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 "replacepiecetablechange.h"
24 
25 // lib
26 #include "piecetable.h"
27 //
28 #include <arraychangemetrics.h>
29 // KDE
30 #include <KLocale>
31 
32 
33 namespace KPieceTable
34 {
35 
36 int ReplacePieceTableChange::type() const { return ReplaceId; }
37 
38 QString ReplacePieceTableChange::description() const
39 {
40  return i18nc( "name of the change", "Replace" );
41 }
42 
43 Address ReplacePieceTableChange::storageOffset() const { return mStorageOffset; }
44 
45 
46 bool ReplacePieceTableChange::merge( const AbstractPieceTableChange* other )
47 {
48 // TODO: remove me again after synching solved
49 // return false;
50  bool result = false;
51 
52  if( other->type() == ReplaceId )
53  {
54  const ReplacePieceTableChange* otherReplaceChange = static_cast<const ReplacePieceTableChange *>( other );
55  // other replaced after?
56  if( mRemoveRange.start()+mInsertLength == otherReplaceChange->mRemoveRange.start() )
57  {
58  mRemoveRange.moveEndBy( otherReplaceChange->mRemoveRange.width() );
59  mInsertLength += otherReplaceChange->mInsertLength;
60  mRemovedPieces.append( otherReplaceChange->mRemovedPieces );
61  result = true;
62  }
63  // other replaced before would be two swapped ranges in the change buffer, if this ever needed/wanted?
64  }
65 
66  return result;
67 }
68 
69 AddressRange ReplacePieceTableChange::apply( PieceTable* pieceTable ) const
70 {
71  const Size oldSize = pieceTable->size();
72 
73  pieceTable->replace( mRemoveRange, mInsertLength, mStorageOffset );
74 
75  const Size newSize = pieceTable->size();
76  const Address lastChanged = ( newSize == oldSize ) ? mRemoveRange.end() :
77  ( newSize > oldSize ) ? newSize - 1 :
78  oldSize - 1;
79  return AddressRange( mRemoveRange.start(), lastChanged );
80 }
81 
82 AddressRange ReplacePieceTableChange::revert( PieceTable* pieceTable ) const
83 {
84  const Size oldSize = pieceTable->size();
85 
86  const AddressRange insertedSection = AddressRange::fromWidth( mRemoveRange.start(), mInsertLength );
87  pieceTable->replace( insertedSection, mRemovedPieces );
88 
89  const Size newSize = pieceTable->size();
90  const Address lastChanged = ( newSize == oldSize ) ? insertedSection.end() :
91  ( newSize > oldSize ) ? newSize - 1 :
92  oldSize - 1;
93  return AddressRange( mRemoveRange.start(), lastChanged );
94 }
95 
96 ArrayChangeMetrics ReplacePieceTableChange::metrics() const
97 {
98  return ArrayChangeMetrics::asReplacement( mRemoveRange.start(), mRemoveRange.width(), mInsertLength );
99 }
100 
101 Size ReplacePieceTableChange::dataSize() const { return mInsertLength; }
102 
103 ReplacePieceTableChange::~ReplacePieceTableChange() {}
104 
105 }
KPieceTable::PieceTable::replace
PieceList replace(const AddressRange &removeRange, Size insertLength, Address storageOffset)
Definition: piecetable.cpp:299
KPieceTable::PieceList::append
void append(const PieceList &other)
Definition: piecelist.h:81
KPieceTable::Size
Okteta::Size Size
Definition: piece.h:33
KDE::NumberRange< Address, Size >
KDE::Range::start
T start() const
Definition: range.h:86
KPieceTable::ReplacePieceTableChange::mInsertLength
Size mInsertLength
Definition: replacepiecetablechange.h:58
KPieceTable::ReplacePieceTableChange::merge
virtual bool merge(const AbstractPieceTableChange *other)
returns true if successful, false otherwise. Default returns false.
Definition: replacepiecetablechange.cpp:46
KPieceTable::ReplacePieceTableChange::metrics
virtual ArrayChangeMetrics metrics() const
Definition: replacepiecetablechange.cpp:96
KPieceTable::ReplacePieceTableChange::type
virtual int type() const
Definition: replacepiecetablechange.cpp:36
KPieceTable::ReplacePieceTableChange::apply
virtual AddressRange apply(PieceTable *pieceTable) const
Definition: replacepiecetablechange.cpp:69
KPieceTable::PieceTable::size
Size size() const
Definition: piecetable.h:64
KPieceTable::ReplacePieceTableChange::~ReplacePieceTableChange
virtual ~ReplacePieceTableChange()
Definition: replacepiecetablechange.cpp:103
KDE::NumberRange::width
S width() const
Definition: numberrange.h:141
KPieceTable::ReplacePieceTableChange::storageOffset
virtual Address storageOffset() const
returns the storageOffset. Default returns -1.
Definition: replacepiecetablechange.cpp:43
KDE::Range::end
T end() const
Definition: range.h:88
KDE::NumberRange< Address, Size >::fromWidth
static NumberRange fromWidth(AddressstartIndex, Sizewidth)
constructs a range by width
KPieceTable::ReplacePieceTableChange::mRemoveRange
AddressRange mRemoveRange
Definition: replacepiecetablechange.h:57
KPieceTable::AddressRange
Okteta::AddressRange AddressRange
Definition: piece.h:35
KPieceTable::Address
Okteta::Address Address
Definition: piece.h:34
KPieceTable::ReplacePieceTableChange::dataSize
virtual Size dataSize() const
returns the size of the added data. Default returns 0.
Definition: replacepiecetablechange.cpp:101
KPieceTable::AbstractPieceTableChange
class
Definition: abstractpiecetablechange.h:45
KPieceTable::ReplacePieceTableChange::mRemovedPieces
PieceList mRemovedPieces
Definition: replacepiecetablechange.h:60
KPieceTable::PieceTable
Definition: piecetable.h:35
KPieceTable::ReplacePieceTableChange::mStorageOffset
Address mStorageOffset
Definition: replacepiecetablechange.h:59
Okteta::ArrayChangeMetrics::asReplacement
static ArrayChangeMetrics asReplacement(Address offset, Size removeLength, Size insertLength)
Definition: arraychangemetrics.h:100
KPieceTable::ReplacePieceTableChange::description
virtual QString description() const
Definition: replacepiecetablechange.cpp:38
replacepiecetablechange.h
KPieceTable::AbstractPieceTableChange::type
virtual int type() const =0
Okteta::ArrayChangeMetrics
Definition: arraychangemetrics.h:38
piecetable.h
KPieceTable::ReplacePieceTableChange
class
Definition: replacepiecetablechange.h:38
KDE::Range::moveEndBy
void moveEndBy(T D)
moves the end by D.
Definition: range.h:80
KPieceTable::ReplacePieceTableChange::revert
virtual AddressRange revert(PieceTable *pieceTable) const
Definition: replacepiecetablechange.cpp:82
KPieceTable::AbstractPieceTableChange::ReplaceId
Definition: abstractpiecetablechange.h:52
arraychangemetrics.h
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 23:04:09 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