]> git.lyx.org Git - lyx.git/blobdiff - src/lyxfunc.C
Fix small bug in reading \set_color in lyxrc
[lyx.git] / src / lyxfunc.C
index cad7b6ac4cf42c2b8917df24426161db8e26aae0..01f949df91e99fe43fac748ea13a041cc94fbd63 100644 (file)
@@ -28,10 +28,12 @@ using std::istringstream;
 #pragma implementation
 #endif
 
+#include "version.h"
 #include "lyxlookup.h"
 #include "kbmap.h"
 #include "lyxfunc.h"
 #include "bufferlist.h"
+#include "ColorHandler.h"
 #include "lyxserver.h"
 #include "lyx.h"
 #include "intl.h"
@@ -49,13 +51,20 @@ using std::istringstream;
 #include "insets/insetindex.h"
 #include "insets/insetinclude.h"
 #include "insets/insetbib.h"
+#include "insets/insetcite.h"
 #include "insets/insettext.h"
 #include "insets/insetert.h"
+#include "insets/insetexternal.h"
 #include "insets/insetgraphics.h"
 #include "insets/insetfoot.h"
+#include "insets/insetmarginal.h"
+#include "insets/insetminipage.h"
+#include "insets/insetfloat.h"
+#include "insets/insetlist.h"
 #include "insets/insettabular.h"
+#include "insets/insettheorem.h"
+#include "insets/insetcaption.h"
 #include "mathed/formulamacro.h"
-#include "toolbar.h"
 #include "spellchecker.h" // RVDK_PATCH_5
 #include "minibuffer.h"
 #include "vspace.h"
@@ -77,8 +86,15 @@ using std::istringstream;
 #include "layout.h"
 #include "WorkArea.h"
 #include "lyxfr1.h"
-#include "menus.h"
 #include "bufferview_funcs.h"
+#include "frontends/Dialogs.h"
+#include "frontends/Toolbar.h"
+#ifdef NEW_MENUBAR
+#include "frontends/Menubar.h"
+#else
+#include "menus.h"
+#endif
+#include "FloatList.h"
 
 using std::pair;
 using std::endl;
@@ -87,10 +103,10 @@ extern bool cursor_follows_scrollbar;
 
 extern void InsertAsciiFile(BufferView *, string const &, bool);
 extern void math_insert_symbol(char const *);
-extern Bool math_insert_greek(char const); // why "Bool"?
+extern bool math_insert_greek(char);
 extern BufferList bufferlist;
 extern LyXServer * lyxserver;
-extern short greek_kb_flag;
+extern int greek_kb_flag;
 extern FD_form_toc * fd_form_toc;
 extern bool selection_possible;
 
@@ -107,20 +123,13 @@ extern void MenuSendto();
 extern void QuitLyX();
 extern void MenuFax(Buffer *);
 extern void MenuExport(Buffer *, string const &);
-
-#define XFORMS_CLIPBOARD 1
-
-#ifndef XFORMS_CLIPBOARD
-extern void MenuPasteSelection(char at);
-#endif
+extern void show_symbols_form(LyXFunc *);
 
 extern LyXAction lyxaction;
 // (alkis)
 extern tex_accent_struct get_accent(kb_action action);
 
 extern void AutoSave(BufferView *);
-extern void SetUpdateTimer(float timer = 0.3);
-extern void FreeUpdateTimer();
 extern bool PreviewDVI(Buffer *);
 extern bool PreviewPostscript(Buffer *);
 extern void MenuInsertLabel(char const *);
@@ -170,17 +179,13 @@ void LyXFunc::moveCursorUpdate(bool selecting)
        if (selecting || owner->view()->text->mark_set) {
                owner->view()->text->SetSelection();
                owner->view()->toggleToggle();
-               //owner->view()->update(0);
-               //} else {
-               //owner->view()->update(-2); // this IS necessary
-               // (Matthias) 
        }
-       owner->view()->update(0);
+       owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
        owner->view()->showCursor();
        
        /* ---> Everytime the cursor is moved, show the current font state. */
        // should this too me moved out of this func?
-       //owner->getMiniBuffer()->Set(CurrentState());
+       //owner->showState();
        owner->view()->setState();
 }
 
@@ -190,7 +195,7 @@ int LyXFunc::processKeyEvent(XEvent * ev)
        char s_r[10];
        string argument;
        XKeyEvent * keyevent = &ev->xkey;
-       KeySym keysym_return;
+       KeySym keysym_return = 0;
 
        int num_bytes = LyXLookupString(ev, s_r, 10, &keysym_return);
        s_r[num_bytes] = '\0';
@@ -219,12 +224,12 @@ int LyXFunc::processKeyEvent(XEvent * ev)
        if (owner->view()->available() && tli && (keysym_return==XK_Escape)) {
                if (tli == tli->GetLockingInset()) {
                        owner->view()->unlockInset(tli);
-                       owner->view()->text->CursorRight();
+                       owner->view()->text->CursorRight(owner->view());
                        moveCursorUpdate(false);
-                       owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+                       owner->showState();
                } else {
                        tli->UnlockInsetInInset(owner->view(),
-                                               tli->GetLockingInset());
+                                               tli->GetLockingInset(),true);
                }
                return 0;
        }
@@ -324,13 +329,13 @@ LyXFunc::func_status LyXFunc::getStatus(int ac) const
        
        if (lyxaction.isPseudoAction(ac)) 
                action = lyxaction.retrieveActionArg(ac, argument);
-       else 
+       else
                action = static_cast<kb_action>(ac);
        
        if (action == LFUN_UNKNOWN_ACTION) {
                setErrorMessage(N_("Unknown action"));
                return LyXFunc::Unknown;
-       } 
+       }
        
        // Check whether we need a buffer
        if (!lyxaction.funcHasFlag(action, LyXAction::NoBuffer)) {
@@ -344,6 +349,7 @@ LyXFunc::func_status LyXFunc::getStatus(int ac) const
                                // no
                                setErrorMessage(N_("Document is read-only"));
                                flag |= LyXFunc::Disabled;
+                               return flag;
                        }
                } else {
                        // no
@@ -353,9 +359,6 @@ LyXFunc::func_status LyXFunc::getStatus(int ac) const
                }
        }
 
-       if (flag & LyXFunc::Disabled)
-               return flag;
-
        // I would really like to avoid having this switch and rather try to
        // encode this in the function itself.
         static bool noLaTeX = lyxrc.latex_command == "none";
@@ -363,8 +366,8 @@ LyXFunc::func_status LyXFunc::getStatus(int ac) const
         switch (action) {
        case LFUN_PREVIEW:
                disable = noLaTeX || lyxrc.view_dvi_command == "none";
-               break;  
-       case LFUN_PREVIEWPS: 
+               break;
+       case LFUN_PREVIEWPS:
                disable = noLaTeX || lyxrc.view_ps_command == "none";
                break;
        case LFUN_RUNLATEX:
@@ -375,23 +378,34 @@ LyXFunc::func_status LyXFunc::getStatus(int ac) const
                disable = noLaTeX || lyxrc.print_command == "none";
                break;
        case LFUN_FAX:
-               disable = noLaTeX || lyxrc.fax_command == "none"; 
+               disable = noLaTeX || lyxrc.fax_command == "none";
                break;
        case LFUN_IMPORT:
-               if (argument == "latex")
+               if (argument == "latex" || argument == "noweb")
                        disable = lyxrc.relyx_command == "none";
-               if (argument == "linuxdoc")
+               else if (argument == "linuxdoc")
                        disable = lyxrc.linuxdoc_to_lyx_command == "none";
                break;
        case LFUN_EXPORT:
-               if (argument == "dvi" || argument == "postscript")
+               if (argument == "latex")
+                       disable = ! buf->isLatex();
+               else if (argument == "linuxdoc")
+                       disable = ! buf->isLinuxDoc();
+               else if (argument == "docbook")
+                       disable = ! buf->isDocBook();
+               else if (argument == "dvi" || argument == "postscript")
                        disable = noLaTeX;
-               if (argument == "html")
-                       disable = lyxrc.html_command == "none";
-               if (argument == "html-linuxdoc")
-                       disable = lyxrc.linuxdoc_to_html_command == "none";
-               if (argument == "html-docbook")
-                       disable = lyxrc.docbook_to_html_command == "none";
+               else if (argument == "html")
+                       disable = (! buf->isLatex() 
+                                  || lyxrc.html_command == "none");
+               else if (argument == "html-linuxdoc")
+                       disable = (! buf->isLinuxDoc() 
+                                  || lyxrc.linuxdoc_to_html_command == "none");
+               else if (argument == "html-docbook")
+                       disable = (! buf->isDocBook() 
+                                  || lyxrc.docbook_to_html_command == "none");
+               else if (argument == "custom")
+                       disable == ! buf->isLatex();
                break;
        case LFUN_UNDO:
                disable = buf->undostack.empty();
@@ -405,8 +419,27 @@ LyXFunc::func_status LyXFunc::getStatus(int ac) const
        case LFUN_RUNCHKTEX:
                disable = lyxrc.chktex_command == "none";
                break;
+       case LFUN_BUILDPROG:
+               disable = (lyxrc.literate_command == "none" 
+                          || ! buf->isLiterate());
+#ifndef NEW_TABULAR
        case LFUN_LAYOUT_TABLE:
-               disable = ! owner->view()->text->cursor.par->table;
+               disable = ! owner->view()->text->cursor.par()->table;
+               break;
+#endif
+       case LFUN_VC_REGISTER:
+               disable = buf->lyxvc.inUse();
+               break;
+       case LFUN_VC_CHECKIN:
+               disable = !buf->lyxvc.inUse() || buf->isReadonly();
+               break;
+       case LFUN_VC_CHECKOUT:
+               disable = !buf->lyxvc.inUse() || !buf->isReadonly();
+               break;
+       case LFUN_VC_REVERT:
+       case LFUN_VC_UNDO:
+       case LFUN_VC_HISTORY:
+               disable = !buf->lyxvc.inUse();
                break;
        default:
                break;
@@ -540,11 +573,10 @@ string LyXFunc::Dispatch(int ac,
        if (owner->view()->available() &&
            owner->view()->the_locking_inset) {
                UpdatableInset::RESULT result;
-               if (action > 1
-                   || (action == LFUN_UNKNOWN_ACTION
-                       && keyseq.length >= -1)) {
-                       if (action == LFUN_UNKNOWN_ACTION
-                           && argument.empty()) {
+               if ((action > 1) || ((action == LFUN_UNKNOWN_ACTION) &&
+                                    (keyseq.length >= -1)))
+               {
+                       if ((action==LFUN_UNKNOWN_ACTION) && argument.empty()){
                                argument = keyseq.getiso();
                        }
                        // Undo/Redo pre 0.13 is a bit tricky for insets.
@@ -552,15 +584,15 @@ string LyXFunc::Dispatch(int ac,
                                int slx, sly;
                                UpdatableInset * inset = 
                                        owner->view()->the_locking_inset;
-                               inset->GetCursorPos(slx, sly);
+                               inset->GetCursorPos(owner->view(), slx, sly);
                                owner->view()->unlockInset(inset);
                                owner->view()->menuUndo();
-                               if (owner->view()->text->cursor.par->
-                                   IsInset(owner->view()->text->cursor.pos)) {
+                               if (owner->view()->text->cursor.par()->
+                                   IsInset(owner->view()->text->cursor.pos())) {
                                        inset = static_cast<UpdatableInset*>(
-                                               owner->view()->text->cursor.par->
+                                               owner->view()->text->cursor.par()->
                                                GetInset(owner->view()->text->
-                                                        cursor.pos));
+                                                        cursor.pos()));
                                } else {
                                        inset = 0;
                                }
@@ -571,13 +603,13 @@ string LyXFunc::Dispatch(int ac,
                                int slx, sly;
                                UpdatableInset * inset = owner->view()->
                                        the_locking_inset;
-                               inset->GetCursorPos(slx, sly);
+                               inset->GetCursorPos(owner->view(), slx, sly);
                                owner->view()->unlockInset(inset);
                                owner->view()->menuRedo();
                                inset = static_cast<UpdatableInset*>(
-                                       owner->view()->text->cursor.par->
+                                       owner->view()->text->cursor.par()->
                                        GetInset(owner->view()->text->
-                                                cursor.pos));
+                                                cursor.pos()));
                                if (inset)
                                        inset->Edit(owner->view(),slx,sly,0); 
                                return string();
@@ -593,31 +625,28 @@ string LyXFunc::Dispatch(int ac,
                                case LFUN_UNKNOWN_ACTION:
                                case LFUN_BREAKPARAGRAPH:
                                case LFUN_BREAKLINE:
-                                       owner->view()->text->CursorRight();
+                                       owner->view()->text->CursorRight(owner->view());
                                        owner->view()->setState();
-                                       owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+                                       owner->showState();
                                        break;
                                case LFUN_RIGHT:
-                                       if (!owner->view()->text->cursor.par->isRightToLeftPar()) {
-                                               owner->view()->text->CursorRight();
+                                       if (!owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params)) {
+                                               owner->view()->text->CursorRight(owner->view());
                                                moveCursorUpdate(false);
-                                               owner->getMiniBuffer()->
-                                                       Set(CurrentState(owner->view()));
+                                               owner->showState();
                                        }
                                        return string();
                                case LFUN_LEFT: 
-                                       if (owner->view()->text->cursor.par->isRightToLeftPar()) {
-                                               owner->view()->text->CursorRight();
+                                       if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params)) {
+                                               owner->view()->text->CursorRight(owner->view());
                                                moveCursorUpdate(false);
-                                               owner->getMiniBuffer()->
-                                                       Set(CurrentState(owner->view()));
+                                               owner->showState();
                                        }
                                        return string();
                                case LFUN_DOWN:
-                                       owner->view()->text->CursorDown();
+                                       owner->view()->text->CursorDown(owner->view());
                                        moveCursorUpdate(false);
-                                       owner->getMiniBuffer()->
-                                               Set(CurrentState(owner->view()));
+                                       owner->showState();
                                        return string();
                                default:
                                        break;
@@ -644,11 +673,11 @@ string LyXFunc::Dispatch(int ac,
 
                if (!searched_string.empty() &&
                    ((action == LFUN_WORDFINDBACKWARD) ? 
-                    ltCur->SearchBackward(searched_string.c_str()) :
-                    ltCur->SearchForward(searched_string.c_str()))) {
+                    ltCur->SearchBackward(owner->view(), searched_string.c_str()) :
+                    ltCur->SearchForward(owner->view(), searched_string.c_str()))) {
 
                        // ??? What is that ???
-                       owner->view()->update(-2);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
 
                        // ??? Needed ???
                        // clear the selection (if there is any) 
@@ -657,7 +686,7 @@ string LyXFunc::Dispatch(int ac,
 
                        // Move cursor so that successive C-s 's will not stand in place. 
                        if( action == LFUN_WORDFINDFORWARD ) 
-                               owner->view()->text->CursorRightOneWord();
+                               owner->view()->text->CursorRightOneWord(owner->view());
                        owner->view()->text->FinishUndo();
                        moveCursorUpdate(false);
 
@@ -676,7 +705,7 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_PREFIX:
        {
                if (owner->view()->available()) {
-                       owner->view()->update(-2);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                }
                string buf;
                keyseq.print(buf, true);
@@ -723,8 +752,8 @@ string LyXFunc::Dispatch(int ac,
                
        case LFUN_APPENDIX:
                if (owner->view()->available()) {
-                       owner->view()->text->toggleAppendix();
-                       owner->view()->update(1);
+                       owner->view()->text->toggleAppendix(owner->view());
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                }
                break;
 
@@ -791,9 +820,9 @@ string LyXFunc::Dispatch(int ac,
                break;
                
        case LFUN_MENUPRINT:
-               MenuPrint(owner->buffer());
+               owner->getDialogs()->showPrint();
                break;
-               
+
        case LFUN_FAX:
                MenuFax(owner->buffer());
                break;
@@ -811,6 +840,18 @@ string LyXFunc::Dispatch(int ac,
                break;
                
        case LFUN_TOCVIEW:
+       case LFUN_LOFVIEW:
+       case LFUN_LOTVIEW:
+       case LFUN_LOAVIEW:
+       {
+               Buffer::TocType type = Buffer::TOC_TOC;
+               if (action == LFUN_LOFVIEW)
+                       type = Buffer::TOC_LOF;
+               else if (action == LFUN_LOTVIEW)
+                       type = Buffer::TOC_LOT;
+               else if (action == LFUN_LOAVIEW)
+                       type = Buffer::TOC_LOA;
+               fl_set_choice(fd_form_toc->toctype,type + 1);
                TocUpdateCB(0, 0);
                if (fd_form_toc->form_toc->visible) {
                        fl_raise_form(fd_form_toc->form_toc);
@@ -827,7 +868,7 @@ string LyXFunc::Dispatch(int ac,
                        fl_set_form_minsize(fd_form_toc->form_toc, ow, oh);
                }
                break;
-               
+       }       
        case LFUN_TOC_INSERT:
        {
                Inset * new_inset = new InsetTOC(owner->buffer());
@@ -861,14 +902,18 @@ string LyXFunc::Dispatch(int ac,
        }
                
        case LFUN_TABLE:
+#ifndef NEW_TABULAR
                Table();
+#else
+               owner->getDialogs()->showTabularCreate();
+#endif
                break;
                
        case LFUN_FIGURE:
                Figure();
                break;
 
-       case LFUN_INSERT_GRAPHICS:
+       case LFUN_INSET_GRAPHICS:
        {
                Inset * new_inset = new InsetGraphics;
                if (!owner->view()->insertInset(new_inset))
@@ -907,11 +952,7 @@ string LyXFunc::Dispatch(int ac,
        {
                bool asPara = false;
                if (argument == "paragraph") asPara = true;
-#ifdef XFORMS_CLIPBOARD
-               owner->view()->pasteSelection(asPara);
-#else
-               MenuPasteSelection(asPara);
-#endif
+               owner->view()->pasteClipboard(asPara);
        }
        break;
        
@@ -947,10 +988,12 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_GOTONOTE:
                owner->view()->gotoNote();
                break;
-               
+
+#ifndef NEW_INSETS
        case LFUN_OPENSTUFF:
                owner->view()->openStuff();
                break;
+#endif
                
        case LFUN_HYPHENATION:
                owner->view()->hyphenationPoint();
@@ -987,30 +1030,30 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_FREE:
                Free(owner->view());
                owner->view()->setState();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_TEX:
                Tex(owner->view());
                owner->view()->setState();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
-               
+#ifndef NEW_INSETS             
        case LFUN_MELT:
                Melt(owner->view());
                break;
-               
+#endif
        case LFUN_RECONFIGURE:
                Reconfigure(owner->view());
                break;
-
+#ifndef NEW_INSETS
        case LFUN_FOOTMELT:
                if (owner->view()->available()
                    && !owner->view()->text->selection
-                   && owner->view()->text->cursor.par->footnoteflag
+                   && owner->view()->text->cursor.par()->footnoteflag
                    != LyXParagraph::NO_FOOTNOTE)
                        { // only melt footnotes with FOOTMELT, not margins etc
-                               if(owner->view()->text->cursor.par->footnotekind == LyXParagraph::FOOTNOTE)
+                               if(owner->view()->text->cursor.par()->footnotekind == LyXParagraph::FOOTNOTE)
                                        Melt(owner->view());
                        }
                else
@@ -1021,16 +1064,56 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_MARGINMELT:
                if (owner->view()->available()
                    && !owner->view()->text->selection
-                   && owner->view()->text->cursor.par->footnoteflag
+                   && owner->view()->text->cursor.par()->footnoteflag
                    != LyXParagraph::NO_FOOTNOTE) {
                        // only melt margins
-                       if(owner->view()->text->cursor.par->footnotekind == LyXParagraph::MARGIN)
+                       if(owner->view()->text->cursor.par()->footnotekind == LyXParagraph::MARGIN)
                                Melt(owner->view());
                } else
                        Margin(owner->view()); 
                owner->view()->setState();
                break;
-               
+#endif
+       case LFUN_HELP_COPYRIGHT:
+               owner->getDialogs()->showCopyright();
+               break;
+
+       case LFUN_HELP_CREDITS:
+               owner->getDialogs()->showCredits();
+               break;
+
+        case LFUN_HELP_OPEN: {
+               string arg = argument;
+               if (arg.empty()) {
+                       setErrorMessage(N_("Missing argument"));
+                       break;
+               }
+               ProhibitInput(owner->view());
+               string fname = i18nLibFileSearch("doc", arg, "lyx");
+               if (fname.empty()) {
+                       lyxerr << "LyX: unable to find documentation file `"
+                              << arg << "'. Bad installation?" << endl;
+                       AllowInput(owner->view());
+                       break;
+               }
+               owner->getMiniBuffer()->Set(_("Opening help file"),
+                                           MakeDisplayPath(fname),"...");
+               owner->view()->buffer(bufferlist.loadLyXFile(fname,false));
+               AllowInput(owner->view());
+               break;
+        }
+
+       case LFUN_HELP_VERSION: 
+               ProhibitInput(owner->view());
+               fl_show_message((string(_("LyX Version ")) + LYX_VERSION 
+                                + _(" of ") + LYX_RELEASE).c_str(),
+                               (_("Library directory: ")
+                                + MakeDisplayPath(system_lyxdir)).c_str(),
+                               (_("User directory: ") 
+                                + MakeDisplayPath(user_lyxdir)).c_str());
+               AllowInput(owner->view());
+               break;
+
                // --- version control -------------------------------
        case LFUN_VC_REGISTER:
        {
@@ -1075,6 +1158,11 @@ string LyXFunc::Dispatch(int ac,
        
        // --- buffers ----------------------------------------
 
+        case LFUN_SWITCHBUFFER:
+                owner->view()->buffer(bufferlist.getBuffer(argument));
+               break;
+
+
        case LFUN_FILE_INSERT:
        {
                MenuInsertLyXFile(argument);
@@ -1156,14 +1244,11 @@ string LyXFunc::Dispatch(int ac,
                if (current_layout != layout.second) {
                        owner->view()->hideCursor();
                        current_layout = layout.second;
-                       owner->view()->update(-2);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                        owner->view()->text->
-                               SetLayout(layout.second);
-                       owner->getToolbar()->combox->
-                               select(owner->view()->
-                                      text->cursor.par->
-                                      GetLayout() + 1);
-                       owner->view()->update(1);
+                               SetLayout(owner->view(), layout.second);
+                       owner->setLayout(layout.second);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                        owner->view()->setState();
                }
        }
@@ -1206,60 +1291,58 @@ string LyXFunc::Dispatch(int ac,
                break;
                
        case LFUN_DROP_LAYOUTS_CHOICE:
-               owner->getToolbar()->combox->Show();
+               owner->getToolbar()->openLayoutList();
                break;
 
        case LFUN_LANGUAGE:
-       {
                Lang(owner->view(), argument);
                owner->view()->setState();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
-       }
+               owner->showState();
                break;
 
        case LFUN_EMPH:
                Emph(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
-               
+
        case LFUN_BOLD:
                Bold(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_NOUN:
                Noun(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_CODE:
                Code(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_SANS:
                Sans(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_ROMAN:
                Roman(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_DEFAULT:
                StyleReset(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_UNDERLINE:
                Underline(owner->view());
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_FONT_SIZE:
                FontSize(owner->view(), argument);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_FONT_STATE:
@@ -1267,27 +1350,24 @@ string LyXFunc::Dispatch(int ac,
                break;
                
        case LFUN_UPCASE_WORD:
-               owner->view()->update(-2);
-               FreeUpdateTimer();
-               owner->view()->text->ChangeWordCase(LyXText::text_uppercase);
-               owner->view()->update(1);
-               SetUpdateTimer();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->ChangeWordCase(owner->view(),
+                                                   LyXText::text_uppercase);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                break;
                
        case LFUN_LOWCASE_WORD:
-               owner->view()->update(-2);
-               FreeUpdateTimer();
-               owner->view()->text->ChangeWordCase(LyXText::text_lowercase);
-               owner->view()->update(1);
-               SetUpdateTimer();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->ChangeWordCase(owner->view(),
+                                                   LyXText::text_lowercase);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                break;
                
        case LFUN_CAPITALIZE_WORD:
-               owner->view()->update(-2);
-               FreeUpdateTimer();
-               owner->view()->text->ChangeWordCase(LyXText::text_capitalization);
-               owner->view()->update(1);
-               SetUpdateTimer();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->ChangeWordCase(owner->view(),
+                                                   LyXText::text_capitalization);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                break;
                
        case LFUN_INSERT_LABEL:
@@ -1338,7 +1418,11 @@ string LyXFunc::Dispatch(int ac,
        break;
                
        case LFUN_MENU_OPEN_BY_NAME:
+#ifdef NEW_MENUBAR
+               owner->getMenubar()->openByName(argument);
+#else
                owner->getMenus()->openByName(argument);
+#endif
                break; // RVDK_PATCH_5
                
        case LFUN_SPELLCHECK:
@@ -1350,27 +1434,27 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_RIGHT:
        {
                LyXText * tmptext = owner->view()->text;
-               bool is_rtl = tmptext->cursor.par->isRightToLeftPar();
+               bool is_rtl = tmptext->cursor.par()->isRightToLeftPar(owner->buffer()->params);
                if(!tmptext->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                if (is_rtl)
-                       tmptext->CursorLeft();
-               if (tmptext->cursor.pos < tmptext->cursor.par->Last()
-                   && tmptext->cursor.par->GetChar(tmptext->cursor.pos)
+                       tmptext->CursorLeft(owner->view(), false);
+               if (tmptext->cursor.pos() < tmptext->cursor.par()->Last()
+                   && tmptext->cursor.par()->GetChar(tmptext->cursor.pos())
                    == LyXParagraph::META_INSET
-                   && tmptext->cursor.par->GetInset(tmptext->cursor.pos)
-                   && tmptext->cursor.par->GetInset(tmptext->cursor.pos)->Editable() == Inset::HIGHLY_EDITABLE){
-                       Inset * tmpinset = tmptext->cursor.par->GetInset(tmptext->cursor.pos);
+                   && tmptext->cursor.par()->GetInset(tmptext->cursor.pos())
+                   && tmptext->cursor.par()->GetInset(tmptext->cursor.pos())->Editable() == Inset::HIGHLY_EDITABLE){
+                       Inset * tmpinset = tmptext->cursor.par()->GetInset(tmptext->cursor.pos());
                        setMessage(tmpinset->EditMessage());
                        tmpinset->Edit(owner->view(), 0, 0, 0);
                        break;
                }
                if (!is_rtl)
-                       tmptext->CursorRight();
+                       tmptext->CursorRight(owner->view(), false);
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
        }
        break;
                
@@ -1379,302 +1463,304 @@ string LyXFunc::Dispatch(int ac,
                // This is soooo ugly. Isn`t it possible to make
                // it simpler? (Lgb)
                LyXText * txt = owner->view()->text;
-               bool is_rtl = txt->cursor.par->isRightToLeftPar();
+               bool is_rtl = txt->cursor.par()->isRightToLeftPar(owner->buffer()->params);
                if(!txt->mark_set) owner->view()->beforeChange();
-               owner->view()->update(-2);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                if (!is_rtl)
-                       txt->CursorLeft();
-               if (txt->cursor.pos < txt->cursor.par->Last()
-                   && txt->cursor.par->GetChar(txt->cursor.pos)
+                       txt->CursorLeft(owner->view(), false);
+               if (txt->cursor.pos() < txt->cursor.par()->Last()
+                   && txt->cursor.par()->GetChar(txt->cursor.pos())
                    == LyXParagraph::META_INSET
-                   && txt->cursor.par->GetInset(txt->cursor.pos)
-                   && txt->cursor.par->GetInset(txt->cursor.pos)->Editable() == Inset::HIGHLY_EDITABLE) {
-                       Inset * tmpinset = txt->cursor.par->GetInset(txt->cursor.pos);
+                   && txt->cursor.par()->GetInset(txt->cursor.pos())
+                   && txt->cursor.par()->GetInset(txt->cursor.pos())->Editable() == Inset::HIGHLY_EDITABLE) {
+                       Inset * tmpinset = txt->cursor.par()->GetInset(txt->cursor.pos());
                        setMessage(tmpinset->EditMessage());
-                       LyXFont font = txt->GetFont(txt->cursor.par,
-                                                   txt->cursor.pos);
+                       LyXFont font = txt->GetFont(owner->view()->buffer(),
+                                                   txt->cursor.par(),
+                                                   txt->cursor.pos());
                        tmpinset->Edit(owner->view(),
-                                      tmpinset->x() + tmpinset->width(owner->view()->painter(),font),
-                                      tmpinset->descent(owner->view()->painter(),font),
+                                      tmpinset->x() +
+                                      tmpinset->width(owner->view(),font),
+                                      tmpinset->descent(owner->view(),font),
                                       0);
                        break;
                }
                if  (is_rtl)
-                       txt->CursorRight();
+                       txt->CursorRight(owner->view(), false);
 
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
        }
        break;
                
        case LFUN_UP:
                if(!owner->view()->text->mark_set) owner->view()->beforeChange();
-               owner->view()->update(-3);
-               owner->view()->text->CursorUp();
+               owner->view()->update(BufferView::UPDATE);
+               owner->view()->text->CursorUp(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_DOWN:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-3);
-               owner->view()->text->CursorDown();
+               owner->view()->update(BufferView::UPDATE);
+               owner->view()->text->CursorDown(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
 
        case LFUN_UP_PARAGRAPH:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-3);
-               owner->view()->text->CursorUpParagraph();
+               owner->view()->update(BufferView::UPDATE);
+               owner->view()->text->CursorUpParagraph(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_DOWN_PARAGRAPH:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-3);
-               owner->view()->text->CursorDownParagraph();
+               owner->view()->update(BufferView::UPDATE);
+               owner->view()->text->CursorDownParagraph(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_PRIOR:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-3);
+               owner->view()->update(BufferView::UPDATE);
                owner->view()->cursorPrevious();
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_NEXT:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-3);
+               owner->view()->update(BufferView::UPDATE);
                owner->view()->cursorNext();
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_HOME:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               owner->view()->text->CursorHome();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorHome(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_END:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               owner->view()->text->CursorEnd();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorEnd(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
+       case LFUN_SHIFT_TAB:
        case LFUN_TAB:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               owner->view()->text->CursorTab();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorTab(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_WORDRIGHT:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               if (owner->view()->text->cursor.par->isRightToLeftPar())
-                       owner->view()->text->CursorLeftOneWord();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params))
+                       owner->view()->text->CursorLeftOneWord(owner->view());
                else
-                       owner->view()->text->CursorRightOneWord();
+                       owner->view()->text->CursorRightOneWord(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_WORDLEFT:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               if (owner->view()->text->cursor.par->isRightToLeftPar())
-                       owner->view()->text->CursorRightOneWord();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params))
+                       owner->view()->text->CursorRightOneWord(owner->view());
                else
-                       owner->view()->text->CursorLeftOneWord();
+                       owner->view()->text->CursorLeftOneWord(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_BEGINNINGBUF:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               owner->view()->text->CursorTop();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorTop(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_ENDBUF:
                if(!owner->view()->text->mark_set)
                        owner->view()->beforeChange();
-               owner->view()->update(-2);
-               owner->view()->text->CursorBottom();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorBottom(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
 
       
                /* cursor selection ---------------------------- */
        case LFUN_RIGHTSEL:
-               owner->view()->update(-2);
-               if (owner->view()->text->cursor.par->isRightToLeftPar())
-                       owner->view()->text->CursorLeft();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params))
+                       owner->view()->text->CursorLeft(owner->view());
                else
-                       owner->view()->text->CursorRight();
+                       owner->view()->text->CursorRight(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_LEFTSEL:
-               owner->view()->update(-2);
-               if (owner->view()->text->cursor.par->isRightToLeftPar())
-                       owner->view()->text->CursorRight();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params))
+                       owner->view()->text->CursorRight(owner->view());
                else
-                       owner->view()->text->CursorLeft();
+                       owner->view()->text->CursorLeft(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_UPSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorUp();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorUp(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_DOWNSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorDown();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorDown(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
 
        case LFUN_UP_PARAGRAPHSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorUpParagraph();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorUpParagraph(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_DOWN_PARAGRAPHSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorDownParagraph();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorDownParagraph(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_PRIORSEL:
-               owner->view()->update(-2);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                owner->view()->cursorPrevious();
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_NEXTSEL:
-               owner->view()->update(-2);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                owner->view()->cursorNext();
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_HOMESEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorHome();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorHome(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_ENDSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorEnd();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorEnd(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_WORDRIGHTSEL:
-               owner->view()->update(-2);
-               if (owner->view()->text->cursor.par->isRightToLeftPar())
-                       owner->view()->text->CursorLeftOneWord();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params))
+                       owner->view()->text->CursorLeftOneWord(owner->view());
                else
-                       owner->view()->text->CursorRightOneWord();
+                       owner->view()->text->CursorRightOneWord(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_WORDLEFTSEL:
-               owner->view()->update(-2);
-               if (owner->view()->text->cursor.par->isRightToLeftPar())
-                       owner->view()->text->CursorRightOneWord();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               if (owner->view()->text->cursor.par()->isRightToLeftPar(owner->buffer()->params))
+                       owner->view()->text->CursorRightOneWord(owner->view());
                else
-                       owner->view()->text->CursorLeftOneWord();
+                       owner->view()->text->CursorLeftOneWord(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_BEGINNINGBUFSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorTop();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorTop(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
        case LFUN_ENDBUFSEL:
-               owner->view()->update(-2);
-               owner->view()->text->CursorBottom();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->CursorBottom(owner->view());
                owner->view()->text->FinishUndo();
                moveCursorUpdate(true);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
 
                // --- text changing commands ------------------------
        case LFUN_BREAKLINE:
                owner->view()->beforeChange();
-               owner->view()->text->InsertChar(LyXParagraph::META_NEWLINE);
-               owner->view()->update(1);
-               SetUpdateTimer(0.01);
+               owner->view()->text->InsertChar(owner->view(), LyXParagraph::META_NEWLINE);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                moveCursorUpdate(false);
                break;
                
@@ -1682,11 +1768,11 @@ string LyXFunc::Dispatch(int ac,
        {
                LyXLayout const & style =
                        textclasslist.Style(owner->view()->buffer()->params.textclass,
-                                           owner->view()->text->cursor.par->GetLayout());
+                                           owner->view()->text->cursor.par()->GetLayout());
 
                if (style.free_spacing) {
-                       owner->view()->text->InsertChar(' ');
-                       owner->view()->update(-1);
+                       owner->view()->text->InsertChar(owner->view(), ' ');
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                } else {
                        owner->view()->protectedBlank();
                }
@@ -1697,12 +1783,12 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_SETMARK:
                if(owner->view()->text->mark_set) {
                        owner->view()->beforeChange();
-                       owner->view()->update(0);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                        setMessage(N_("Mark removed"));
                } else {
                        owner->view()->beforeChange();
                        owner->view()->text->mark_set = 1;
-                       owner->view()->update(0);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                        setMessage(N_("Mark set"));
                }
                owner->view()->text->sel_cursor = 
@@ -1710,21 +1796,19 @@ string LyXFunc::Dispatch(int ac,
                break;
                
        case LFUN_DELETE:
-               FreeUpdateTimer();
                if (!owner->view()->text->selection) {
-                       owner->view()->text->Delete();
+                       owner->view()->text->Delete(owner->view());
                        owner->view()->text->sel_cursor = 
                                owner->view()->text->cursor;
-                       owner->view()->update(1);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                        // It is possible to make it a lot faster still
                        // just comment out the lone below...
                        owner->view()->showCursor();
                } else {
                        owner->view()->cut();
                }
-               SetUpdateTimer();
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                owner->view()->setState();
                break;
 
@@ -1734,81 +1818,74 @@ string LyXFunc::Dispatch(int ac,
                
                LyXCursor cursor = owner->view()->text->cursor;
 
-               FreeUpdateTimer();
                if (!owner->view()->text->selection) {
-                       if (cursor.pos == cursor.par->Last()) {
-                               owner->view()->text->CursorRight();
+                       if (cursor.pos() == cursor.par()->Last()) {
+                               owner->view()->text->CursorRight(owner->view());
                                cursor = owner->view()->text->cursor;
-                               if (cursor.pos == 0
-                                   && !(cursor.par->added_space_top 
+                               if (cursor.pos() == 0
+                                   && !(cursor.par()->added_space_top 
                                         == VSpace (VSpace::NONE))) {
                                        owner->view()->text->SetParagraph
-                                               (cursor.par->line_top,
-                                                cursor.par->line_bottom,
-                                                cursor.par->pagebreak_top, 
-                                                cursor.par->pagebreak_bottom,
+                                               (owner->view(),
+                                                cursor.par()->line_top,
+                                                cursor.par()->line_bottom,
+                                                cursor.par()->pagebreak_top, 
+                                                cursor.par()->pagebreak_bottom,
                                                 VSpace(VSpace::NONE), 
-                                                cursor.par->added_space_bottom,
-                                                cursor.par->align, 
-                                                cursor.par->labelwidthstring, 0);
-                                       owner->view()->text->CursorLeft();
-                                       owner->view()->update (1);
+                                                cursor.par()->added_space_bottom,
+                                                cursor.par()->align, 
+                                                cursor.par()->labelwidthstring, 0);
+                                       owner->view()->text->CursorLeft(owner->view());
+                                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                                } else {
-                                       owner->view()->text->CursorLeft();
-                                       owner->view()->text->Delete();
+                                       owner->view()->text->CursorLeft(owner->view());
+                                       owner->view()->text->Delete(owner->view());
                                        owner->view()->text->sel_cursor = 
                                                owner->view()->text->cursor;
-                                       owner->view()->update(1);
+                                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                                }
                        } else {
-                               owner->view()->text->Delete();
+                               owner->view()->text->Delete(owner->view());
                                owner->view()->text->sel_cursor = 
                                        owner->view()->text->cursor;
-                               owner->view()->update(1);
+                               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                        }
                } else {
                        owner->view()->cut();
                }
-               SetUpdateTimer();
        }
        break;
 
        /* -------> Delete word forward. */
        case LFUN_DELETE_WORD_FORWARD:
-               owner->view()->update(-2);
-               FreeUpdateTimer();
-               owner->view()->text->DeleteWordForward();
-               owner->view()->update( 1 );
-               SetUpdateTimer();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->DeleteWordForward(owner->view());
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
 
                /* -------> Delete word backward. */
        case LFUN_DELETE_WORD_BACKWARD:
-               owner->view()->update(-2);
-               FreeUpdateTimer();
-               owner->view()->text->DeleteWordBackward();
-               owner->view()->update( 1 );
-               SetUpdateTimer();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->DeleteWordBackward(owner->view());
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                moveCursorUpdate(false);
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
                
                /* -------> Kill to end of line. */
        case LFUN_DELETE_LINE_FORWARD:
-               FreeUpdateTimer();
-               owner->view()->update(-2);
-               owner->view()->text->DeleteLineForward();
-               owner->view()->update( 1 );
-               SetUpdateTimer();
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
+               owner->view()->text->DeleteLineForward(owner->view());
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                moveCursorUpdate(false);
                break;
                
                /* -------> Set mark off. */
        case LFUN_MARK_OFF:
                owner->view()->beforeChange();
-               owner->view()->update(0);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                owner->view()->text->sel_cursor = 
                        owner->view()->text->cursor;
                setMessage(N_("Mark off"));
@@ -1818,7 +1895,7 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_MARK_ON:
                owner->view()->beforeChange();
                owner->view()->text->mark_set = 1;
-               owner->view()->update( 0 );
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR);
                owner->view()->text->sel_cursor = 
                        owner->view()->text->cursor;
                setMessage(N_("Mark on"));
@@ -1826,13 +1903,12 @@ string LyXFunc::Dispatch(int ac,
                
        case LFUN_BACKSPACE:
        {
-               FreeUpdateTimer();
                if (!owner->view()->text->selection) {
                        if (owner->getIntl()->getTrans()->backspace()) {
-                               owner->view()->text->Backspace();
+                               owner->view()->text->Backspace(owner->view());
                                owner->view()->text->sel_cursor = 
                                        owner->view()->text->cursor;
-                               owner->view()->update(1);
+                               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                                // It is possible to make it a lot faster still
                                // just comment out the lone below...
                                owner->view()->showCursor();
@@ -1840,8 +1916,7 @@ string LyXFunc::Dispatch(int ac,
                } else {
                        owner->view()->cut();
                }
-               SetUpdateTimer();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                owner->view()->setState();
        }
        break;
@@ -1852,55 +1927,52 @@ string LyXFunc::Dispatch(int ac,
                
                LyXCursor cursor = owner->view()->text->cursor;
                
-               FreeUpdateTimer();
                if (!owner->view()->text->selection) {
-                       if (cursor.pos == 0 
-                           && !(cursor.par->added_space_top 
+                       if (cursor.pos() == 0 
+                           && !(cursor.par()->added_space_top 
                                 == VSpace (VSpace::NONE))) {
                                owner->view()->text->SetParagraph 
-                                       (cursor.par->line_top,      
-                                        cursor.par->line_bottom,
-                                        cursor.par->pagebreak_top, 
-                                        cursor.par->pagebreak_bottom,
-                                        VSpace(VSpace::NONE), cursor.par->added_space_bottom,
-                                        cursor.par->align, 
-                                        cursor.par->labelwidthstring, 0);
-                               owner->view()->update (1);
+                                       (owner->view(),
+                                        cursor.par()->line_top,      
+                                        cursor.par()->line_bottom,
+                                        cursor.par()->pagebreak_top, 
+                                        cursor.par()->pagebreak_bottom,
+                                        VSpace(VSpace::NONE), cursor.par()->added_space_bottom,
+                                        cursor.par()->align, 
+                                        cursor.par()->labelwidthstring, 0);
+                               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                        } else {
-                               owner->view()->text->Backspace();
+                               owner->view()->text->Backspace(owner->view());
                                owner->view()->text->sel_cursor 
                                        = cursor;
-                               owner->view()->update(1);
+                               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                        }
                } else
                        owner->view()->cut();
-               SetUpdateTimer();
        }
        break;
 
        case LFUN_BREAKPARAGRAPH:
        {
                owner->view()->beforeChange();
-               owner->view()->text->BreakParagraph(0);
-               owner->view()->update(1);
-               SetUpdateTimer(0.01);
+               owner->view()->text->BreakParagraph(owner->view(), 0);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                owner->view()->text->sel_cursor = 
                        owner->view()->text->cursor;
                owner->view()->setState();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
        }
 
        case LFUN_BREAKPARAGRAPHKEEPLAYOUT:
        {
                owner->view()->beforeChange();
-               owner->view()->text->BreakParagraph(1);
-               owner->view()->update(1);
-               SetUpdateTimer(0.01);
+               owner->view()->text->BreakParagraph(owner->view(), 1);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                owner->view()->text->sel_cursor = 
                        owner->view()->text->cursor;
                owner->view()->setState();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
                break;
        }
        
@@ -1913,33 +1985,35 @@ string LyXFunc::Dispatch(int ac,
                LyXCursor cursor = owner->view()->text->cursor;
                
                owner->view()->beforeChange();
-               if (cursor.pos == 0) {
-                       if (cursor.par->added_space_top == VSpace(VSpace::NONE)) {
+               if (cursor.pos() == 0) {
+                       if (cursor.par()->added_space_top == VSpace(VSpace::NONE)) {
                                owner->view()->text->SetParagraph
-                                       (cursor.par->line_top,      
-                                        cursor.par->line_bottom,
-                                        cursor.par->pagebreak_top, 
-                                        cursor.par->pagebreak_bottom,
-                                        VSpace(VSpace::DEFSKIP), cursor.par->added_space_bottom,
-                                        cursor.par->align, 
-                                        cursor.par->labelwidthstring, 1);
-                               owner->view()->update(1);
+                                       (owner->view(),
+                                        cursor.par()->line_top,      
+                                        cursor.par()->line_bottom,
+                                        cursor.par()->pagebreak_top, 
+                                        cursor.par()->pagebreak_bottom,
+                                        VSpace(VSpace::DEFSKIP), cursor.par()->added_space_bottom,
+                                        cursor.par()->align, 
+                                        cursor.par()->labelwidthstring, 1);
+                               //owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                        } 
                }
                else {
-                       owner->view()->text->BreakParagraph(0);
-                       owner->view()->update(1);
+                       owner->view()->text->BreakParagraph(owner->view(), 0);
+                       //owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                }
-               SetUpdateTimer(0.01);
+
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                owner->view()->text->sel_cursor = cursor;
                owner->view()->setState();
-               owner->getMiniBuffer()->Set(CurrentState(owner->view()));
+               owner->showState();
        }
        break;
 
        case LFUN_PARAGRAPH_SPACING:
        {
-               LyXParagraph * par = owner->view()->text->cursor.par;
+               LyXParagraph * par = owner->view()->text->cursor.par();
                Spacing::Space cur_spacing = par->spacing.getSpace();
                float cur_value = 1.0;
                if (cur_spacing == Spacing::Other) {
@@ -1979,17 +2053,16 @@ string LyXFunc::Dispatch(int ac,
                }
                if (cur_spacing != new_spacing || cur_value != new_value) {
                        par->spacing.set(new_spacing, new_value);
-                       owner->view()->text->RedoParagraph();
-                       owner->view()->update(-1);
+                       owner->view()->text->RedoParagraph(owner->view());
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                }
        }
        break;
        
        case LFUN_QUOTE:
                owner->view()->beforeChange();
-               owner->view()->text->InsertChar('\"');  // This " matches the single quote in the code
-               owner->view()->update(1);
-               SetUpdateTimer();
+               owner->view()->text->InsertChar(owner->view(), '\"');  // This " matches the single quote in the code
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                 moveCursorUpdate(false);
                break;
 
@@ -2010,16 +2083,27 @@ string LyXFunc::Dispatch(int ac,
        
        case LFUN_INSET_TEXT:
        {
-               InsetText * new_inset = new InsetText(owner->buffer());
+               InsetText * new_inset = new InsetText;
                if (owner->view()->insertInset(new_inset))
                        new_inset->Edit(owner->view(), 0, 0, 0);
                else
                        delete new_inset;
        }
        break;
+       
        case LFUN_INSET_ERT:
        {
-               InsetERT * new_inset = new InsetERT(owner->buffer());
+               InsetERT * new_inset = new InsetERT;
+               if (owner->view()->insertInset(new_inset))
+                       new_inset->Edit(owner->view(), 0, 0, 0);
+               else
+                       delete new_inset;
+       }
+       break;
+       
+       case LFUN_INSET_EXTERNAL:
+       {
+               InsetExternal * new_inset = new InsetExternal;
                if (owner->view()->insertInset(new_inset))
                        new_inset->Edit(owner->view(), 0, 0, 0);
                else
@@ -2029,7 +2113,64 @@ string LyXFunc::Dispatch(int ac,
        
        case LFUN_INSET_FOOTNOTE:
        {
-               InsetFoot * new_inset = new InsetFoot(owner->buffer());
+               InsetFoot * new_inset = new InsetFoot;
+               if (owner->view()->insertInset(new_inset))
+                       new_inset->Edit(owner->view(), 0, 0, 0);
+               else
+                       delete new_inset;
+       }
+       break;
+
+       case LFUN_INSET_MARGINAL:
+       {
+               InsetMarginal * new_inset = new InsetMarginal;
+               if (owner->view()->insertInset(new_inset))
+                       new_inset->Edit(owner->view(), 0, 0, 0);
+               else
+                       delete new_inset;
+       }
+       break;
+
+       case LFUN_INSET_MINIPAGE:
+       {
+               InsetMinipage * new_inset = new InsetMinipage;
+               if (owner->view()->insertInset(new_inset))
+                       new_inset->Edit(owner->view(), 0, 0, 0);
+               else
+                       delete new_inset;
+       }
+       break;
+
+       case LFUN_INSET_FLOAT:
+       {
+               // check if the float type exist
+               if (floatList.typeExist(argument)) {
+                       InsetFloat * new_inset = new InsetFloat(argument);
+                       if (owner->view()->insertInset(new_inset))
+                               new_inset->Edit(owner->view(), 0, 0, 0);
+                       else
+                               delete new_inset;
+               } else {
+                       lyxerr << "Non-existant float type: "
+                              << argument << endl;
+               }
+               
+       }
+       break;
+
+       case LFUN_INSET_LIST:
+       {
+               InsetList * new_inset = new InsetList;
+               if (owner->view()->insertInset(new_inset))
+                       new_inset->Edit(owner->view(), 0, 0, 0);
+               else
+                       delete new_inset;
+       }
+       break;
+
+       case LFUN_INSET_THEOREM:
+       {
+               InsetTheorem * new_inset = new InsetTheorem;
                if (owner->view()->insertInset(new_inset))
                        new_inset->Edit(owner->view(), 0, 0, 0);
                else
@@ -2037,12 +2178,32 @@ string LyXFunc::Dispatch(int ac,
        }
        break;
 
+       case LFUN_INSET_CAPTION:
+       {
+               // Do we have a locking inset...
+               if (owner->view()->the_locking_inset) {
+                       lyxerr << "Locking inset code: "
+                              << owner->view()->the_locking_inset->LyxCode();
+                       InsetCaption * new_inset = new InsetCaption;
+                       new_inset->setOwner(owner->view()->the_locking_inset);
+                       new_inset->SetAutoBreakRows(true);
+                       new_inset->SetDrawFrame(0, InsetText::LOCKED);
+                       new_inset->SetFrameColor(0, LColor::footnoteframe);
+                       if (owner->view()->insertInset(new_inset))
+                               new_inset->Edit(owner->view(), 0, 0, 0);
+                       else
+                               delete new_inset;
+               }
+       }
+       break;
+       
        case LFUN_INSET_TABULAR:
        {
                int r = 2, c = 2;
                if (!argument.empty())
-                       sscanf(argument.c_str(),"%d%d",&r,&c);
-               InsetTabular * new_inset = new InsetTabular(owner->buffer(),r,c);
+                       sscanf(argument.c_str(),"%d%d", &r, &c);
+               InsetTabular * new_inset =
+                       new InsetTabular(owner->buffer(), r, c);
                if (owner->view()->insertInset(new_inset))
                        new_inset->Edit(owner->view(), 0, 0, 0);
                else
@@ -2055,13 +2216,13 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_CHARATCURSOR:
        {
                LyXParagraph::size_type pos = 
-                       owner->view()->text->cursor.pos;
-               if(pos < owner->view()->text->cursor.par->size())
+                       owner->view()->text->cursor.pos();
+               if(pos < owner->view()->text->cursor.par()->size())
                        //dispatch_buffer = owner->view()->text->
-                       //      cursor.par->text[pos];
+                       //      cursor.par()->text[pos];
                        dispatch_buffer =
                                owner->view()->text->
-                               cursor.par->GetChar(pos);
+                               cursor.par()->GetChar(pos);
                else
                        dispatch_buffer = "EOF";
        }
@@ -2069,8 +2230,8 @@ string LyXFunc::Dispatch(int ac,
        
        case LFUN_GETXY:
                dispatch_buffer = 
-                       tostr(owner->view()->text->cursor.x) + ' '
-                       + tostr(owner->view()->text->cursor.y);
+                       tostr(owner->view()->text->cursor.x()) + ' '
+                       + tostr(owner->view()->text->cursor.y());
                break;
                
        case LFUN_SETXY:
@@ -2078,13 +2239,13 @@ string LyXFunc::Dispatch(int ac,
                int  x;
                long y;
                sscanf(argument.c_str(), " %d %ld", &x, &y);
-               owner->view()->text->SetCursorFromCoordinates(x, y);
+               owner->view()->text->SetCursorFromCoordinates(owner->view(), x, y);
        }
        break;
        
        case LFUN_GETLAYOUT:
                dispatch_buffer =  
-                       tostr(owner->view()->text->cursor.par->layout);
+                       tostr(owner->view()->text->cursor.par()->layout);
                break;
                        
        case LFUN_GETFONT:
@@ -2192,9 +2353,8 @@ string LyXFunc::Dispatch(int ac,
                keyseq.length = 0;
                
                // copied verbatim from do_accent_char
-               owner->view()->update(1);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
 
-               SetUpdateTimer();
                owner->view()->text->sel_cursor = 
                        owner->view()->text->cursor;
        }   
@@ -2204,15 +2364,7 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_PUSH_TOOLBAR:
        {
                int nth = strToInt(argument);
-               if (lyxerr.debugging(Debug::TOOLBAR)) {
-                       lyxerr << "LFUN_PUSH_TOOLBAR: argument = `"
-                              << argument << "'\n"
-                              << "LFUN_PUSH_TOOLBAR: nth = `"
-                              << nth << "'" << endl;
-               }
-               
                if (nth <= 0) {
-                       LyXBell();
                        setErrorMessage(N_("Push-toolbar needs argument > 0"));
                } else {
                        owner->getToolbar()->push(nth);
@@ -2222,7 +2374,7 @@ string LyXFunc::Dispatch(int ac,
        
        case LFUN_ADD_TO_TOOLBAR:
        {
-               if (lyxerr.debugging(Debug::TOOLBAR)) {
+               if (lyxerr.debugging(Debug::GUI)) {
                        lyxerr << "LFUN_ADD_TO_TOOLBAR:"
                                "argument = `" << argument << '\'' << endl;
                }
@@ -2230,7 +2382,6 @@ string LyXFunc::Dispatch(int ac,
                //lyxerr <<string("Argument: ") + argument);
                //lyxerr <<string("Tmp     : ") + tmp);
                if (tmp.empty()) {
-                       LyXBell();
                        setErrorMessage(N_("Usage: toolbar-add-to <LyX command>"));
                } else {
                        owner->getToolbar()->add(argument, false);
@@ -2311,8 +2462,7 @@ string LyXFunc::Dispatch(int ac,
        break;
 
        case LFUN_MATH_MODE:   // Open or create a math inset
-       {
-               
+       {               
                if (owner->view()->available())
                        owner->view()->open_new_inset(new InsetFormula);
                setMessage(N_("Math editor mode"));
@@ -2323,30 +2473,32 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_MATH_LIMITS:
        {
                setErrorMessage(N_("This is only allowed in math mode!"));
+       
+       }
+       break;
+
+       case LFUN_MATH_PANEL:
+       {
+               show_symbols_form(this);
        }
        break;
        
+       case LFUN_CREATE_CITATION:
+       {
+               owner->getDialogs()->createCitation( argument );
+       }
+       break;
+                   
        case LFUN_INSERT_CITATION:
-       {   
-               InsetCitation * new_inset = new InsetCitation();
-               // ale970405
-               // The note, if any, must be after the key, delimited
-               // by a | so both key and remark can have spaces.
-               if (!argument.empty()) {
-                       string lsarg(argument);
-                       if (contains(lsarg, "|")) {
-                               new_inset->setContents(token(lsarg, '|', 0));
-                               new_inset->setOptions(token(lsarg, '|', 1));
-                       } else
-                               new_inset->setContents(lsarg);
-                       if (!owner->view()->insertInset(new_inset))
-                               delete new_inset;
-               } else {
-                       if (owner->view()->insertInset(new_inset))
-                               new_inset->Edit(owner->view(), 0, 0, 0);
-                       else
-                               delete new_inset;
-               }
+       {
+               string keys = token(argument, '|', 0);
+               string text = token(argument, '|', 1);
+
+               InsetCitation * inset = new InsetCitation( keys, text );
+               if (!owner->view()->insertInset(inset))
+                       delete inset;
+               else
+                       owner->view()->updateInset( inset, true );
        }
        break;
                    
@@ -2407,7 +2559,7 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_INDEX_INSERT_LAST:
        {
                // Can't do that at the beginning of a paragraph.
-               if (owner->view()->text->cursor.pos - 1 < 0)
+               if (owner->view()->text->cursor.pos() - 1 < 0)
                        break;
 
                InsetIndex * new_inset = new InsetIndex();
@@ -2420,12 +2572,12 @@ string LyXFunc::Dispatch(int ac,
                        //reh 98/09/21
                        //get the current word for an argument
                        LyXParagraph::size_type lastpos = 
-                               owner->view()->text->cursor.pos - 1;
+                               owner->view()->text->cursor.pos() - 1;
                        // Get the current word. note that this must be done
                        // before inserting the inset, or the inset will
                        // break the word
                        string curstring(owner->view()
-                                        ->text->cursor.par->GetWord(lastpos));
+                                        ->text->cursor.par()->GetWord(lastpos));
 
                        //make the new inset and write the current word into it
                        InsetIndex * new_inset = new InsetIndex();
@@ -2441,7 +2593,7 @@ string LyXFunc::Dispatch(int ac,
 
                                // move the cursor to the returned value of lastpos
                                // but only for the auto-insert
-                               owner->view()->text->cursor.pos = lastpos;
+                               owner->view()->text->cursor.pos(lastpos);
                        }
 
                        //put the new inset into the buffer.
@@ -2499,7 +2651,7 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_INSERT_NOTE:
                owner->view()->insertNote();
                break;
-               
+#ifndef NEW_INSETS
        case LFUN_INSERTFOOTNOTE: 
        {
                LyXParagraph::footnote_kind kind;
@@ -2521,12 +2673,12 @@ string LyXFunc::Dispatch(int ac,
                        setErrorMessage(N_("Unknown kind of footnote"));
                        break;
                }
-               owner->view()->text->InsertFootnoteEnvironment(kind);
-               owner->view()->update(1);
+               owner->view()->text->InsertFootnoteEnvironment(owner->view(), kind);
+               owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                owner->view()->setState();
        }
        break;
-       
+#endif 
        case LFUN_BUFFERBULLETSSELECT:
                bulletForm();
                break;
@@ -2554,12 +2706,11 @@ string LyXFunc::Dispatch(int ac,
        case LFUN_SELFINSERT:
        {
                for (string::size_type i = 0; i < argument.length(); ++i) {
-                       owner->view()->text->InsertChar(argument[i]);
+                       owner->view()->text->InsertChar(owner->view(), argument[i]);
                        // This needs to be in the loop, or else we
                        // won't break lines correctly. (Asger)
-                       owner->view()->update(1);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                }
-               SetUpdateTimer();
                owner->view()->text->sel_cursor = 
                        owner->view()->text->cursor;
                moveCursorUpdate(false);
@@ -2579,25 +2730,23 @@ string LyXFunc::Dispatch(int ac,
 
        case LFUN_DATE_INSERT:  // jdblair: date-insert cmd
        {
-               char datetmp[32];
-               int datetmp_len;
-               time_t now_time_t;
-               struct tm *now_tm;
-               static string arg;
+               struct tm * now_tm;
                
-               now_time_t = time(NULL);
+               time_t now_time_t = time(NULL);
                now_tm = localtime(&now_time_t);
-               (void)setlocale(LC_TIME, "");
+               setlocale(LC_TIME, "");
+               string arg;
                if (!argument.empty())
                        arg = argument;
-               else if (arg.empty())
+               else 
                        arg = lyxrc.date_insert_format;
-               datetmp_len = (int) strftime(datetmp, 32, arg.c_str(), now_tm);
+               char datetmp[32];
+               int datetmp_len = strftime(datetmp, 32, arg.c_str(), now_tm);
                for (int i = 0; i < datetmp_len; i++) {
-                       owner->view()->text->InsertChar(datetmp[i]);
-                       owner->view()->update(1);
+                       owner->view()->text->InsertChar(owner->view(), datetmp[i]);
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                }
-               SetUpdateTimer();
+
                owner->view()->text->sel_cursor = owner->view()->text->cursor;
                moveCursorUpdate(false);
        }
@@ -2609,7 +2758,31 @@ string LyXFunc::Dispatch(int ac,
                lyxrc.write("preferences");
        }
        break;
-       
+
+       case LFUN_SET_COLOR:
+       {
+               string lyx_name, x11_name;
+               x11_name = split(argument, lyx_name, ' ');
+               if (lyx_name.empty() || x11_name.empty()) {
+                       LyXBell();
+                       setErrorMessage(N_("Syntax: set-color <lyx_name>"
+                                               " <x11_name>"));
+                       break;
+                       }
+
+               if (!lcolor.setColor(lyx_name, x11_name)) {
+                       static string err1 (N_("Set-color \""));
+                       static string err2 (N_("\" failed - color is undefined "
+                                               "or may not be redefined"));
+                       LyXBell();
+                       setErrorMessage(err1 + lyx_name + err2);
+                       break;
+               }
+               lyxColorHandler->updateColor(lcolor.getFromLyXName(lyx_name));
+               owner->view()->redraw();
+               break;
+       }
+
        case LFUN_UNKNOWN_ACTION:
        {
                if(!owner->buffer()) {
@@ -2634,8 +2807,8 @@ string LyXFunc::Dispatch(int ac,
                
                        if ( lyxrc.auto_region_delete ) {
                                if (owner->view()->text->selection){
-                                       owner->view()->text->CutSelection(false);
-                                       owner->view()->update(-1);
+                                       owner->view()->text->CutSelection(owner->view(), false);
+                                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
                                }
                        }
                        
@@ -2650,8 +2823,7 @@ string LyXFunc::Dispatch(int ac,
                                        owner->getIntl()->getTrans()->TranslateAndInsert(argument[i], owner->view()->text);
                        }
 
-                       owner->view()->update(1);
-                       SetUpdateTimer();
+                       owner->view()->update(BufferView::SELECT|BufferView::FITCUR|BufferView::CHANGE);
 
                        owner->view()->text->sel_cursor = 
                                owner->view()->text->cursor;
@@ -2915,7 +3087,6 @@ void LyXFunc::doImportHelper(
 
        // notify user of import ahead
        string displaypath = MakeDisplayPath(filename);
-       owner->view()->buffer(bufferlist.newFile(lyxfile, string()));
        owner->getMiniBuffer()->Set(_("Importing"), displaypath, "...");
 
        // call real importer
@@ -2931,6 +3102,7 @@ void LyXFunc::doImportHelper(
 static
 bool doImportASCIIasLines(BufferView * view, string const & filename)
 {
+       view->buffer(bufferlist.newFile(filename, string()));
        InsertAsciiFile(view, filename, false);
        return true;
 }
@@ -2938,24 +3110,35 @@ bool doImportASCIIasLines(BufferView * view, string const & filename)
 static
 bool doImportASCIIasParagraphs(BufferView * view, string const & filename)
 {
+       view->buffer(bufferlist.newFile(filename, string()));
        InsertAsciiFile(view, filename, true);
        return true;
 }
 
 static
-bool doImportLaTeX(BufferView *, string const & filename)
+bool doImportLaTeX(BufferView * view, string const & filename)
 {
        ImportLaTeX myImport(filename);
        Buffer * openbuf = myImport.run();
-       return openbuf != NULL;         
+       if (openbuf) { 
+               view->buffer(openbuf);
+               return true;
+       }
+       else
+               return false;
 }
 
 static
-bool doImportNoweb(BufferView *, string const & filename)
+bool doImportNoweb(BufferView * view, string const & filename)
 {
        ImportNoweb myImport(filename);
        Buffer * openbuf = myImport.run();
-       return openbuf != NULL;         
+       if (openbuf) { 
+               view->buffer(openbuf);
+               return true;
+       }
+       else
+               return false;
 }
 
 static
@@ -3075,7 +3258,7 @@ void LyXFunc::CloseBuffer()
                        // need this otherwise SEGV may occur while trying to
                        // set variables that don't exist
                        // since there's no current buffer
-                       CloseAllBufferRelatedPopups();
+                       owner->getDialogs()->hideBufferDependent();
                }
                else {
                        owner->view()->buffer(bufferlist.first());
@@ -3088,8 +3271,8 @@ Inset * LyXFunc::getInsetByCode(Inset::Code code)
 {
        LyXCursor cursor = owner->view()->text->cursor;
        Buffer * buffer = owner->view()->buffer();
-       for (Buffer::inset_iterator it = Buffer::inset_iterator(cursor.par,
-                                                               cursor.pos);
+       for (Buffer::inset_iterator it = Buffer::inset_iterator(cursor.par(),
+                                                               cursor.pos());
             it != buffer->inset_iterator_end(); ++it) {
                if ((*it)->LyxCode() == code)
                        return *it;