commit c4aca5705b149511d9311aba8cbb94254a801756
Author: Enrico Forestieri <for...@lyx.org>
Date:   Fri Sep 16 02:15:52 2016 +0200

    Correctly distinguish ERT macros from predefined ones such as \alpha
---
 src/Cursor.cpp |    7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)

diff --git a/src/Cursor.cpp b/src/Cursor.cpp
index 6485fc4..72c723b 100644
--- a/src/Cursor.cpp
+++ b/src/Cursor.cpp
@@ -1426,9 +1426,9 @@ bool Cursor::macroModeClose()
        InsetMathNest * const in = inset().asInsetMath()->asNestInset();
        if (in && in->interpretString(*this, s))
                return true;
-       bool const ert_macro = !buffer()->getMacro(name, *this, false);
-       MathAtom atom = ert_macro ? createInsetMath(name, buffer())
-                                 : MathAtom(new MathMacro(buffer(), name));
+       bool const user_macro = buffer()->getMacro(name, *this, false);
+       MathAtom atom = user_macro ? MathAtom(new MathMacro(buffer(), name))
+                                  : createInsetMath(name, buffer());
 
        // try to put argument into macro, if we just inserted a macro
        bool macroArg = false;
@@ -1455,6 +1455,7 @@ bool Cursor::macroModeClose()
        bool keep_mathmode = it != words.end() && (it->second.inset == "font"
                                                || it->second.inset == "oldfont"
                                                || it->second.inset == "mbox");
+       bool ert_macro = !user_macro && it == words.end();
 
        if (in && in->currentMode() == Inset::TEXT_MODE
            && atom.nucleus()->currentMode() == Inset::MATH_MODE

Reply via email to