diff options
author | Chris Lattner <sabre@nondot.org> | 2007-11-08 20:51:02 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-11-08 20:51:02 +0000 |
commit | fab21b6d735a8f96e7dda595fecf72946d745871 (patch) | |
tree | ed322f98ae2a54e30671b3c0c255d84533ad8044 | |
parent | 93a9ab4bdc607b12fdcf6aa5cf56950dd45ae0f5 (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.cpp | 17 | ||||
-rw-r--r-- | clang.xcodeproj/project.pbxproj | 3 | ||||
-rw-r--r-- | include/clang/Rewrite/RewriteRope.h | 32 | ||||
-rw-r--r-- | include/clang/Rewrite/Rewriter.h | 1 |
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; |