X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fcoordcache.C;h=b55b296ef13b4adc000914b06f43c6fa0d84de83;hb=cd4033aef3a3f1efdb5a676b8bab3d367f53a830;hp=262aaa7d8a7ff9b687b707f53f1d97840265aea5;hpb=d37fae169ceb695bb36089ff7552fd18fae2af7e;p=lyx.git diff --git a/src/coordcache.C b/src/coordcache.C index 262aaa7d8a..b55b296ef1 100644 --- a/src/coordcache.C +++ b/src/coordcache.C @@ -19,6 +19,17 @@ #include +namespace lyx { + +Point::Point(int x, int y) + : x_(x), y_(y) +{ + BOOST_ASSERT(x > -1000000); + BOOST_ASSERT(x < 1000000); + BOOST_ASSERT(y > -1000000); + BOOST_ASSERT(y < 1000000); +} + // just a helper to be able to set a breakpoint void lyxbreaker(void const * data, const char * hint, int size) { @@ -38,11 +49,40 @@ void CoordCache::clear() } -Point CoordCache::get(LyXText const * text, lyx::pit_type pit) +Point CoordCache::get(LyXText const * text, pit_type pit) const { - ParPosCache::iterator const it = pars_.find(text); + ParPosCache::const_iterator const it = pars_.find(text); BOOST_ASSERT(it != pars_.end()); - InnerParPosCache::iterator const posit = it->second.find(pit); + InnerParPosCache::const_iterator const posit = it->second.find(pit); BOOST_ASSERT(posit != it->second.end()); return posit->second; } + +void +CoordCache::dump() const { + lyxerr << "ParPosCache contains:" << std::endl; + for (ParPosCache::const_iterator i = getParPos().begin(); i != getParPos().end(); ++i) { + LyXText const * lt = (*i).first; + InnerParPosCache const & cache = (*i).second; + lyxerr << "LyXText:" << lt << std::endl; + for (InnerParPosCache::const_iterator j = cache.begin(); j != cache.end(); ++j) { + pit_type pit = (*j).first; + Paragraph const & par = lt->getPar(pit); + Point p = (*j).second; + lyxerr << "Paragraph " << pit << ": \""; + for (int k = 0; k < std::min(static_cast(10), par.size()); ++k) { + lyxerr << to_utf8(docstring(1,par.getChar(k))); + } + lyxerr << "\" has point " << p.x_ << "," << p.y_ << std::endl; + } + } + + lyxerr << "InsetCache contains:" << std::endl; + for (CoordCacheBase::cache_type::const_iterator i = getInsets().getData().begin(); i != getInsets().getData().end(); ++i) { + InsetBase const * inset = (*i).first; + Point p = (*i).second; + lyxerr << "Inset " << inset << "(" << to_utf8(inset->getInsetName()) << ") has point " << p.x_ << "," << p.y_ << std::endl; + } +} + +} // namespace lyx