- if (!bv->available())
- return string();
-
- if (mathcursor)
- return mathcursor->info();
-
- ostringstream state;
-
- LyXText * text = bv->getLyXText();
- Buffer * buffer = bv->buffer();
- LyXCursor const & c(text->cursor);
-
- bool const show_change = buffer->params.tracking_changes
- && c.pos() != c.par()->size()
- && c.par()->lookupChange(c.pos()) != Change::UNCHANGED;
-
- if (show_change) {
- Change change(c.par()->lookupChangeFull(c.pos()));
- Author const & a(bv->buffer()->authors().get(change.author));
- state << _("Change: ") << a.name();
- if (!a.email().empty()) {
- state << " (" << a.email() << ")";
- }
- if (change.changetime)
- state << _(" at ") << ctime(&change.changetime);
- state << " : ";
- }
-
- // I think we should only show changes from the default
- // font. (Asger)
- LyXFont font = text->real_current_font;
- LyXFont const & defaultfont =
- buffer->params.getLyXTextClass().defaultfont();
- font.reduce(defaultfont);
-
-#if USE_BOOST_FORMAT
- state << boost::format(_("Font: %1$s")) % font.stateText(&buffer->params);
-#else
- state << _("Font: ") << font.stateText(&buffer->params);
-#endif
-
- // The paragraph depth
- int depth = text->getDepth();
- if (depth > 0) {
-#if USE_BOOST_FORMAT
- state << boost::format(_(", Depth: %1$d")) % depth;
-#else
- state << _(", Depth: ") << depth;
-#endif
+ LCursor tmpcur = bv->cursor();
+ if (!findInset(tmpcur, codes, same_content)) {
+ bv->cursor().message(_("No more insets"));
+ return;