aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-11-08 20:51:02 +0000
committerChris Lattner <sabre@nondot.org>2007-11-08 20:51:02 +0000
commitfab21b6d735a8f96e7dda595fecf72946d745871 (patch)
treeed322f98ae2a54e30671b3c0c255d84533ad8044
parent93a9ab4bdc607b12fdcf6aa5cf56950dd45ae0f5 (diff)
add a getAtOffset() member to simplify some code.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43905 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--Rewrite/Rewriter.cpp17
-rw-r--r--clang.xcodeproj/project.pbxproj3
-rw-r--r--include/clang/Rewrite/RewriteRope.h32
-rw-r--r--include/clang/Rewrite/Rewriter.h1
4 files changed, 36 insertions, 17 deletions
diff --git a/Rewrite/Rewriter.cpp b/Rewrite/Rewriter.cpp
index 3a007f3e71..e8a469fe1e 100644
--- a/Rewrite/Rewriter.cpp
+++ b/Rewrite/Rewriter.cpp
@@ -91,7 +91,8 @@ void RewriteBuffer::RemoveText(unsigned OrigOffset, unsigned Size) {
assert(RealOffset+Size < Buffer.size() && "Invalid location");
// Remove the dead characters.
- Buffer.erase(Buffer.begin()+RealOffset, Buffer.begin()+RealOffset+Size);
+ RewriteRope::iterator I = Buffer.getAtOffset(RealOffset);
+ Buffer.erase(I, I+Size);
// Add a delta so that future changes are offset correctly.
AddDelta(OrigOffset, -Size);
@@ -106,7 +107,7 @@ void RewriteBuffer::InsertText(unsigned OrigOffset,
assert(RealOffset <= Buffer.size() && "Invalid location");
// Insert the new characters.
- Buffer.insert(Buffer.begin()+RealOffset, StrData, StrData+StrLen);
+ Buffer.insert(Buffer.getAtOffset(RealOffset), StrData, StrData+StrLen);
// Add a delta so that future changes are offset correctly.
AddDelta(OrigOffset, StrLen);
@@ -120,14 +121,16 @@ void RewriteBuffer::ReplaceText(unsigned OrigOffset, unsigned OrigLength,
unsigned RealOffset = getMappedOffset(OrigOffset, true);
assert(RealOffset+OrigLength <= Buffer.size() && "Invalid location");
+#if 0
Buffer.erase(Buffer.begin()+RealOffset, Buffer.begin()+RealOffset+OrigLength);
Buffer.insert(Buffer.begin()+RealOffset, NewStr, NewStr+NewLength);
AddDelta(OrigOffset, NewLength-OrigLength);
return;
+#endif
// Overwrite the common piece.
unsigned CommonLength = std::min(OrigLength, NewLength);
- std::copy(NewStr, NewStr+CommonLength, Buffer.begin()+RealOffset);
+ std::copy(NewStr, NewStr+CommonLength, Buffer.getAtOffset(RealOffset));
// If replacing without shifting around, just overwrite the text.
if (OrigLength == NewLength)
@@ -135,12 +138,12 @@ void RewriteBuffer::ReplaceText(unsigned OrigOffset, unsigned OrigLength,
// If inserting more than existed before, this is like an insertion.
if (NewLength > OrigLength) {
- Buffer.insert(Buffer.begin()+RealOffset+OrigLength,
+ Buffer.insert(Buffer.getAtOffset(RealOffset+OrigLength),
NewStr+OrigLength, NewStr+NewLength);
} else {
- // If insertion less than existed before, this is like a removal.
- Buffer.erase(Buffer.begin()+RealOffset+NewLength,
- Buffer.begin()+RealOffset+OrigLength);
+ // If inserting less than existed before, this is like a removal.
+ RewriteRope::iterator I = Buffer.getAtOffset(RealOffset+NewLength);
+ Buffer.erase(I, I+(OrigLength-NewLength));
}
AddDelta(OrigOffset, NewLength-OrigLength);
}
diff --git a/clang.xcodeproj/project.pbxproj b/clang.xcodeproj/project.pbxproj
index b9eb859d85..d1670a4189 100644
--- a/clang.xcodeproj/project.pbxproj
+++ b/clang.xcodeproj/project.pbxproj
@@ -251,7 +251,7 @@
84AF36A00CB17A3B00C820A5 /* DeclObjC.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; name = DeclObjC.h; path = clang/AST/DeclObjC.h; sourceTree = "<group>"; };
84D9A8870C1A57E100AC7ABC /* AttributeList.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = AttributeList.cpp; path = Parse/AttributeList.cpp; sourceTree = "<group>"; };
84D9A88B0C1A581300AC7ABC /* AttributeList.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; name = AttributeList.h; path = clang/Parse/AttributeList.h; sourceTree = "<group>"; };
- 8DD76F6C0486A84900D96B5E /* clang */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = clang; sourceTree = BUILT_PRODUCTS_DIR; };
+ 8DD76F6C0486A84900D96B5E /* clang */ = {isa = PBXFileReference; includeInIndex = 0; lastKnownFileType = "compiled.mach-o.executable"; path = clang; sourceTree = BUILT_PRODUCTS_DIR; };
DE01DA480B12ADA300AC22CE /* PPCallbacks.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = PPCallbacks.h; sourceTree = "<group>"; };
DE06756B0C051CFE00EBBFD8 /* ParseExprCXX.cpp */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = ParseExprCXX.cpp; path = Parse/ParseExprCXX.cpp; sourceTree = "<group>"; };
DE06B73D0A8307640050E87E /* LangOptions.h */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.c.h; path = LangOptions.h; sourceTree = "<group>"; };
@@ -764,7 +764,6 @@
08FB7793FE84155DC02AAC07 /* Project object */ = {
isa = PBXProject;
buildConfigurationList = 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "clang" */;
- compatibilityVersion = "Xcode 2.4";
hasScannedForEncodings = 1;
mainGroup = 08FB7794FE84155DC02AAC07 /* clang */;
projectDirPath = "";
diff --git a/include/clang/Rewrite/RewriteRope.h b/include/clang/Rewrite/RewriteRope.h
index c4d80ea7c4..d287aad3da 100644
--- a/include/clang/Rewrite/RewriteRope.h
+++ b/include/clang/Rewrite/RewriteRope.h
@@ -87,10 +87,6 @@ public:
return *this;
}
- inline RewriteRopeIterator operator++(int) { // Postincrement
- RewriteRopeIterator tmp = *this; ++*this; return tmp;
- }
-
RewriteRopeIterator operator+(int Offset) const {
assert(Offset >= 0 && "FIXME: Only handle forward case so far!");
@@ -104,6 +100,10 @@ public:
Char += Offset;
return RewriteRopeIterator(Piece, Char);
}
+
+ inline RewriteRopeIterator operator++(int) { // Postincrement
+ RewriteRopeIterator tmp = *this; ++*this; return tmp;
+ }
};
@@ -146,6 +146,27 @@ public:
CurSize = End-Start;
}
+ iterator getAtOffset(unsigned Offset) {
+ assert(Offset <= CurSize && "Offset out of range!");
+ std::list<RopePiece>::iterator Piece = Chunks.begin();
+ while (Offset >= Piece->size()) {
+ Offset -= Piece->size();
+ ++Piece;
+ }
+ return iterator(Piece, Offset);
+ }
+
+ const_iterator getAtOffset(unsigned Offset) const {
+ assert(Offset <= CurSize && "Offset out of range!");
+ std::list<RopePiece>::const_iterator Piece = Chunks.begin();
+ while (Offset >= Piece->size()) {
+ Offset -= Piece->size();
+ ++Piece;
+ }
+ return const_iterator(Piece, Offset);
+ }
+
+
void insert(iterator Loc, const char *Start, const char *End) {
if (Start == End) return;
Chunks.insert(SplitAt(Loc), MakeRopeString(Start, End));
@@ -155,9 +176,6 @@ public:
void erase(iterator Start, iterator End) {
if (Start == End) return;
- //unsigned StartChunkIdx = getChunkIdx(Start);
- //unsigned EndChunkIdx = getChunkIdx(End);
-
// If erase is localized within the same chunk, this is a degenerate case.
if (Start.CurPiece == End.CurPiece) {
RopePiece &Chunk = *Start.CurPiece;
diff --git a/include/clang/Rewrite/Rewriter.h b/include/clang/Rewrite/Rewriter.h
index bc8a4fc72c..7dba252b40 100644
--- a/include/clang/Rewrite/Rewriter.h
+++ b/include/clang/Rewrite/Rewriter.h
@@ -57,7 +57,6 @@ class RewriteBuffer {
/// string is a horribly inefficient way to do this, we should use a rope
/// instead.
typedef RewriteRope BufferTy;
- //typedef std::vector<char> BufferTy;
BufferTy Buffer;
public:
typedef BufferTy::const_iterator iterator;