]> git.lyx.org Git - lyx.git/blobdiff - src/bufferview_funcs.C
minimal effort implementation of:
[lyx.git] / src / bufferview_funcs.C
index fedeccdd6b858ffd9c50f7c6fde0162605f081f9..2125c5706b5eae0b73e56904c3b762aa0d0bd700 100644 (file)
@@ -201,8 +201,12 @@ Point coordOffset(DocIterator const & dit, bool boundary)
 Point getPos(DocIterator const & dit, bool boundary)
 {
        CursorSlice const & bot = dit.bottom();
-       CoordCache::InnerParPosCache const & cache =
-               theCoords.getParPos().find(bot.text())->second;
+       CoordCache::ParPosCache::const_iterator cache_it = 
+               theCoords.getParPos().find(bot.text());
+       if (cache_it == theCoords.getParPos().end())
+               return Point(-1, -1);
+
+       CoordCache::InnerParPosCache const & cache = cache_it->second;
        CoordCache::InnerParPosCache::const_iterator it = cache.find(bot.pit());
        if (it == cache.end()) {
                //lyxerr << "cursor out of view" << std::endl;
@@ -259,6 +263,8 @@ bool findInset(DocIterator & dit, vector<InsetBase_code> const & codes,
        string contents;
        DocIterator tmpdit = dit;
        tmpdit.forwardInset();
+       if (!tmpdit)
+               return false;
 
        if (same_content) {
                InsetBase const * inset = tmpdit.nextInset();
@@ -277,7 +283,7 @@ bool findInset(DocIterator & dit, vector<InsetBase_code> const & codes,
                } else
                        return false;
        }
-       
+
        dit = tmpdit;
        return true;
 }