]> git.lyx.org Git - lyx.git/blobdiff - src/BufferView_pimpl.C
cosmetic fix
[lyx.git] / src / BufferView_pimpl.C
index a3cc67c144503df8b61fbd735c0231c9726d2e8d..e1ccdc8b05c7e73281363937bfcdd6d8be598993 100644 (file)
@@ -138,6 +138,13 @@ void BufferView::Pimpl::addError(ErrorItem const & ei)
 }
 
 
+void BufferView::Pimpl::showReadonly(bool)
+{
+       owner_->updateWindowTitle();
+       owner_->getDialogs().updateBufferDependent(false);
+}
+
+
 void BufferView::Pimpl::connectBuffer(Buffer & buf)
 {
        if (errorConnection_.connected())
@@ -146,6 +153,10 @@ void BufferView::Pimpl::connectBuffer(Buffer & buf)
        errorConnection_ = buf.error.connect(boost::bind(&BufferView::Pimpl::addError, this, _1));
        messageConnection_ = buf.message.connect(boost::bind(&LyXView::message, owner_, _1));
        busyConnection_ = buf.busy.connect(boost::bind(&LyXView::busy, owner_, _1));
+       titleConnection_ = buf.updateTitles.connect(boost::bind(&LyXView::updateWindowTitle, owner_));
+       timerConnection_ = buf.resetAutosaveTimers.connect(boost::bind(&LyXView::resetAutosaveTimer, owner_));
+       readonlyConnection_ = buf.readonly.connect(boost::bind(&BufferView::Pimpl::showReadonly, this, _1));
+       closingConnection_ = buf.closing.connect(boost::bind(&BufferView::Pimpl::buffer, this, (Buffer *)0));
 }
 
 
@@ -154,10 +165,14 @@ void BufferView::Pimpl::disconnectBuffer()
        errorConnection_.disconnect();
        messageConnection_.disconnect();
        busyConnection_.disconnect();
+       titleConnection_.disconnect();
+       timerConnection_.disconnect();
+       readonlyConnection_.disconnect();
+       closingConnection_.disconnect();
 }
 
 
-bool BufferView::Pimpl::newFile(string const & filename, 
+bool BufferView::Pimpl::newFile(string const & filename,
                                string const & tname,
                                bool isNamed)
 {
@@ -246,8 +261,6 @@ void BufferView::Pimpl::buffer(Buffer * b)
                            << b << ')' << endl;
        if (buffer_) {
                disconnectBuffer();
-               buffer_->delUser(bv_);
-
                // Put the old text into the TextCache, but
                // only if the buffer is still loaded.
                // Also set the owner of the test to 0
@@ -273,7 +286,6 @@ void BufferView::Pimpl::buffer(Buffer * b)
 
        if (buffer_) {
                lyxerr[Debug::INFO] << "Buffer addr: " << buffer_ << endl;
-               buffer_->addUser(bv_);
                connectBuffer(*buffer_);
 
                // If we don't have a text object for this, we make one
@@ -314,8 +326,8 @@ void BufferView::Pimpl::buffer(Buffer * b)
                owner_->setLayout(layoutname);
        }
 
-       if (grfx::Previews::activated() && buffer_)
-               grfx::Previews::get().generateBufferPreviews(*buffer_);
+       if (lyx::graphics::Previews::activated() && buffer_)
+               lyx::graphics::Previews::get().generateBufferPreviews(*buffer_);
 }
 
 
@@ -381,8 +393,9 @@ int BufferView::Pimpl::resizeCurrentBuffer()
                selection = bv_->text->selection.set();
                mark_set = bv_->text->selection.mark();
                the_locking_inset = bv_->theLockingInset();
-               buffer_->resizeInsets(bv_);
-               bv_->text->init(bv_);
+               resizeInsets(bv_);
+               bv_->text->fullRebreak();
+               update();
        } else {
                lyxerr << "text not available!\n";
                // See if we have a text in TextCache that fits
@@ -399,11 +412,11 @@ int BufferView::Pimpl::resizeCurrentBuffer()
                        if (lyxerr.debugging())
                                textcache.show(lyxerr, "resizeCurrentBuffer");
 
-                       buffer_->resizeInsets(bv_);
+                       resizeInsets(bv_);
                } else {
                        lyxerr << "no text in cache!\n";
                        bv_->text = new LyXText(bv_);
-                       buffer_->resizeInsets(bv_);
+                       resizeInsets(bv_);
                        bv_->text->init(bv_);
                }
 
@@ -605,7 +618,7 @@ void BufferView::Pimpl::workAreaResize()
                                textcache.show(lyxerr, "Expose delete all");
                        textcache.clear();
                        // FIXME: this is already done in resizeCurrentBuffer() ??
-                       buffer_->resizeInsets(bv_);
+                       resizeInsets(bv_);
                } else if (heightChange) {
                        // fitCursor() ensures we don't jump back
                        // to the start of the document on vertical
@@ -643,7 +656,7 @@ void BufferView::Pimpl::update(LyXText * text, BufferView::UpdateCodes f)
        text->partialRebreak();
 
        if (text->inset_owner) {
-               text->inset_owner->setUpdateStatus(bv_, InsetText::NONE);
+               text->inset_owner->setUpdateStatus(InsetText::NONE);
                updateInset(text->inset_owner);
        } else {
                update();
@@ -662,7 +675,7 @@ void BufferView::Pimpl::update(BufferView::UpdateCodes f)
        text->partialRebreak();
 
        if (text->inset_owner) {
-               text->inset_owner->setUpdateStatus(bv_, InsetText::NONE);
+               text->inset_owner->setUpdateStatus(InsetText::NONE);
                updateInset(text->inset_owner);
        } else {
                update();
@@ -777,7 +790,7 @@ void BufferView::Pimpl::switchKeyMap()
        LyXText * text = bv_->getLyXText();
        if (text->real_current_font.isRightToLeft()
            && !(bv_->theLockingInset()
-                && bv_->theLockingInset()->lyxCode() == Inset::ERT_CODE))
+                && bv_->theLockingInset()->lyxCode() == InsetOld::ERT_CODE))
        {
                if (owner_->getIntl().keymap == Intl::PRIMARY)
                        owner_->getIntl().KeyMapSec();
@@ -853,7 +866,7 @@ void BufferView::Pimpl::stuffClipboard(string const & stuff) const
  */
 
 
-Inset * BufferView::Pimpl::getInsetByCode(Inset::Code code)
+InsetOld * BufferView::Pimpl::getInsetByCode(InsetOld::Code code)
 {
 #if 0
        LyXCursor cursor = bv_->getLyXText()->cursor;
@@ -946,11 +959,12 @@ void BufferView::Pimpl::MenuInsertLyXFile(string const & filen)
 
        string const disp_fn = MakeDisplayPath(filename);
        owner_->message(bformat(_("Inserting document %1$s..."), disp_fn));
-       bool const res = bv_->insertLyXFile(filename);
-       if (res)
-               owner_->message(bformat(_("Document %1$s inserted."), disp_fn));
+       if (bv_->insertLyXFile(filename))
+               owner_->message(bformat(_("Document %1$s inserted."),
+                                       disp_fn));
        else
-               owner_->message(bformat(_("Could not insert document %1$s"), disp_fn));
+               owner_->message(bformat(_("Could not insert document %1$s"),
+                                       disp_fn));
 }
 
 
@@ -973,7 +987,7 @@ void BufferView::Pimpl::trackChanges()
 #warning changes FIXME
                //moveCursorUpdate(false);
 
-               bool found = lyxfind::findNextChange(bv_);
+               bool found = lyx::find::findNextChange(bv_);
                if (found) {
                        owner_->getDialogs().show("changes");
                        return;
@@ -1136,7 +1150,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
                string label = ev.argument;
                if (label.empty()) {
                        InsetRef * inset =
-                               static_cast<InsetRef*>(getInsetByCode(Inset::REF_CODE));
+                               static_cast<InsetRef*>(getInsetByCode(InsetOld::REF_CODE));
                        if (inset) {
                                label = inset->getContents();
                                savePosition(0);
@@ -1206,7 +1220,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
        break;
 
        case LFUN_INSET_INSERT: {
-               Inset * inset = createInset(ev);
+               InsetOld * inset = createInset(ev);
                if (inset && insertInset(inset)) {
                        updateInset(inset);
 
@@ -1227,7 +1241,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
 
        case LFUN_FLOAT_LIST:
                if (tclass.floats().typeExist(ev.argument)) {
-                       Inset * inset = new InsetFloatList(ev.argument);
+                       InsetOld * inset = new InsetFloatList(ev.argument);
                        if (!insertInset(inset, tclass.defaultLayoutName()))
                                delete inset;
                } else {
@@ -1260,7 +1274,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
                params2string(*par, data);
 
                // Will the paragraph accept changes from the dialog?
-               Inset * const inset = par->inInset();
+               InsetOld * const inset = par->inInset();
                bool const accept =
                        !(inset && inset->forceDefaultParagraphs(inset));
 
@@ -1308,7 +1322,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
 #warning FIXME changes
                //moveCursorUpdate(false);
 
-               while (lyxfind::findNextChange(bv_)) {
+               while (lyx::find::findNextChange(bv_)) {
                        bv_->getLyXText()->acceptChange();
                }
                update(BufferView::SELECT);
@@ -1321,7 +1335,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
 #warning FIXME changes
                //moveCursorUpdate(false);
 
-               while (lyxfind::findNextChange(bv_)) {
+               while (lyx::find::findNextChange(bv_)) {
                        bv_->getLyXText()->rejectChange();
                }
                update(BufferView::SELECT);
@@ -1352,7 +1366,7 @@ bool BufferView::Pimpl::dispatch(FuncRequest const & ev_in)
 }
 
 
-bool BufferView::Pimpl::insertInset(Inset * inset, string const & lout)
+bool BufferView::Pimpl::insertInset(InsetOld * inset, string const & lout)
 {
        // if we are in a locking inset we should try to insert the
        // inset there otherwise this is a illegal function now
@@ -1363,7 +1377,7 @@ bool BufferView::Pimpl::insertInset(Inset * inset, string const & lout)
        }
 
        // not quite sure if we want this...
-       setCursorParUndo(bv_);
+       recordUndo(bv_, Undo::ATOMIC);
        freezeUndo();
 
        beforeChange(bv_->text);
@@ -1413,7 +1427,7 @@ bool BufferView::Pimpl::insertInset(Inset * inset, string const & lout)
 }
 
 
-void BufferView::Pimpl::updateInset(Inset * inset)
+void BufferView::Pimpl::updateInset(InsetOld * inset)
 {
        if (!inset || !available())
                return;
@@ -1438,7 +1452,7 @@ void BufferView::Pimpl::updateInset(Inset * inset)
        // then check if the inset is a top_level inset (has no owner)
        // if yes do the update as always otherwise we have to update the
        // toplevel inset where this inset is inside
-       Inset * tl_inset = inset;
+       InsetOld * tl_inset = inset;
        while (tl_inset->owner())
                tl_inset = tl_inset->owner();
        if (tl_inset == inset) {