From: Chris Lattner Date: Sun, 6 Apr 2008 04:36:15 +0000 (+0000) Subject: don't dereference hte end iterator when inserting at end of buffer. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=19bf719a2b9033e00d9e5931d700b7c1c893b8d6;p=clang don't dereference hte end iterator when inserting at end of buffer. Patch by Cédric Venet! git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@49259 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Rewrite/RewriteRope.h b/include/clang/Rewrite/RewriteRope.h index 4d558b579f..8d2fbe3857 100644 --- a/include/clang/Rewrite/RewriteRope.h +++ b/include/clang/Rewrite/RewriteRope.h @@ -148,6 +148,7 @@ public: iterator getAtOffset(unsigned Offset) { assert(Offset <= CurSize && "Offset out of range!"); + if (Offset == CurSize) return iterator(Chunks.end(), 0); std::list::iterator Piece = Chunks.begin(); while (Offset >= Piece->size()) { Offset -= Piece->size(); @@ -158,6 +159,7 @@ public: const_iterator getAtOffset(unsigned Offset) const { assert(Offset <= CurSize && "Offset out of range!"); + if (Offset == CurSize) return const_iterator(Chunks.end(), 0); std::list::const_iterator Piece = Chunks.begin(); while (Offset >= Piece->size()) { Offset -= Piece->size();