+ pars_.clear();
+ slices0_.clear();
+ slices1_.clear();
+}
+
+
+Point CoordCache::get(LyXText const * text, pit_type pit) const
+{
+ ParPosCache::const_iterator const it = pars_.find(text);
+ BOOST_ASSERT(it != pars_.end());
+ 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<lyx::pos_type>(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<InsetBase>::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;
+ }