]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetInfo.cpp
Pure HTML output for math macros.
[lyx.git] / src / insets / InsetInfo.cpp
index 0df2fd59411f9cf6b4f4d81cc33cede5b95870e4..f521d3b46d8cb092dad18639105234027812c9f8 100644 (file)
@@ -25,7 +25,6 @@
 #include "LyXRC.h"
 #include "LyXVC.h"
 #include "Lexer.h"
-#include "MetricsInfo.h"
 #include "ParagraphParameters.h"
 
 #include "frontends/Application.h"
@@ -175,7 +174,8 @@ bool InsetInfo::validateModifyArgument(docstring const & arg) const
                return true;
        case BUFFER_INFO:
                return name == "name" || name == "path" || name == "class" ||
-                      name == "file-revision";
+                      name == "vcs-revision" || name == "vcs-tree-revision" ||
+                      name == "vcs-author" || name == "vcs-date" || name == "vcs-time";
        }
        return false;
 }
@@ -192,20 +192,20 @@ bool InsetInfo::getStatus(Cursor & cur, FuncRequest const & cmd,
                FuncStatus & flag) const
 {
        switch (cmd.action) {
-       case LFUN_MOUSE_PRESS:
-       case LFUN_MOUSE_RELEASE:
-       case LFUN_MOUSE_MOTION:
-       case LFUN_MOUSE_DOUBLE:
-       case LFUN_MOUSE_TRIPLE:
-       case LFUN_COPY:
+       case LFUN_INSET_SETTINGS:
                return InsetCollapsable::getStatus(cur, cmd, flag);
-
+               
        case LFUN_INSET_DIALOG_UPDATE:
-       case LFUN_INSET_MODIFY:
-       case LFUN_INSET_SETTINGS:
                flag.setEnabled(true);
                return true;
-
+               
+       case LFUN_INSET_MODIFY:
+               if (validateModifyArgument(cmd.argument())) {
+                       flag.setEnabled(true);
+                       return true;
+               }
+               //fall back
+               
        default:
                return false;
        }
@@ -216,19 +216,12 @@ void InsetInfo::doDispatch(Cursor & cur, FuncRequest & cmd)
 {
        // allow selection, copy but not cut, delete etc
        switch (cmd.action) {
-       case LFUN_MOUSE_PRESS:
-       case LFUN_MOUSE_RELEASE:
-       case LFUN_MOUSE_MOTION:
-       case LFUN_MOUSE_DOUBLE:
-       case LFUN_MOUSE_TRIPLE:
-       case LFUN_COPY:
        case LFUN_INSET_SETTINGS:
                InsetCollapsable::doDispatch(cur, cmd);
                break;
 
        case LFUN_INSET_MODIFY:
                setInfo(to_utf8(cmd.argument()));
-               cur.pos() = 0;
                break;
 
        default:
@@ -373,9 +366,21 @@ void InsetInfo::updateInfo()
                        setText(from_utf8(buffer().filePath()));
                else if (name_ == "class")
                        setText(from_utf8(bp.documentClass().name()));
-               else if (name_ == "file-revision" && buffer().lyxvc().inUse() &&
+               else if (name_ == "vcs-revision" && buffer().lyxvc().inUse() &&
                         !buffer().lyxvc().revisionInfo(LyXVC::File).empty())
                        setText(from_utf8(buffer().lyxvc().revisionInfo(LyXVC::File)));
+               else if (name_ == "vcs-tree-revision" && buffer().lyxvc().inUse() &&
+                        !buffer().lyxvc().revisionInfo(LyXVC::Tree).empty())
+                       setText(from_utf8(buffer().lyxvc().revisionInfo(LyXVC::Tree)));
+               else if (name_ == "vcs-author" && buffer().lyxvc().inUse() &&
+                        !buffer().lyxvc().revisionInfo(LyXVC::Author).empty())
+                       setText(from_utf8(buffer().lyxvc().revisionInfo(LyXVC::Author)));
+               else if (name_ == "vcs-time" && buffer().lyxvc().inUse() &&
+                        !buffer().lyxvc().revisionInfo(LyXVC::Time).empty())
+                       setText(from_utf8(buffer().lyxvc().revisionInfo(LyXVC::Time)));
+               else if (name_ == "vcs-date" && buffer().lyxvc().inUse() &&
+                        !buffer().lyxvc().revisionInfo(LyXVC::Date).empty())
+                       setText(from_utf8(buffer().lyxvc().revisionInfo(LyXVC::Date)));
                else
                        setText(_("Unknown buffer info"));
                break;