]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetInfo.cpp
Pure HTML output for math macros.
[lyx.git] / src / insets / InsetInfo.cpp
index 10b16bbef1bf4811ea7be2463aace67c6947fb7e..f521d3b46d8cb092dad18639105234027812c9f8 100644 (file)
@@ -23,8 +23,8 @@
 #include "LayoutFile.h"
 #include "LyXAction.h"
 #include "LyXRC.h"
+#include "LyXVC.h"
 #include "Lexer.h"
-#include "MetricsInfo.h"
 #include "ParagraphParameters.h"
 
 #include "frontends/Application.h"
@@ -173,7 +173,9 @@ bool InsetInfo::validateModifyArgument(docstring const & arg) const
        case TEXTCLASS_INFO:
                return true;
        case BUFFER_INFO:
-               return name == "name" || name == "path" || name == "class";
+               return name == "name" || name == "path" || name == "class" ||
+                      name == "vcs-revision" || name == "vcs-tree-revision" ||
+                      name == "vcs-author" || name == "vcs-date" || name == "vcs-time";
        }
        return false;
 }
@@ -190,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;
        }
@@ -214,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:
@@ -371,6 +366,21 @@ void InsetInfo::updateInfo()
                        setText(from_utf8(buffer().filePath()));
                else if (name_ == "class")
                        setText(from_utf8(bp.documentClass().name()));
+               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;