]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/MathMacro.cpp
Improve the list of equations
[lyx.git] / src / mathed / MathMacro.cpp
index 89f8200193ae74ea2083486624db3d8f15aab1be..1311bc9c2ce49d405f093622c72c0ded4cbdd94e 100644 (file)
@@ -140,6 +140,15 @@ public:
        void htmlize(HtmlStream & ms) const { ms << mathMacro_->cell(idx_); }
        ///
        void octave(OctaveStream & os) const { os << mathMacro_->cell(idx_); }
+       ///
+       MathClass mathClass() const
+       {
+               return MC_UNKNOWN;
+               // This can be refined once the pointer issues are fixed. I did not
+               // notice any immediate crash with the following code, but it is risky
+               // nevertheless:
+               //return mathMacro_->cell(idx_).mathClass();
+       }
 
 private:
        ///
@@ -823,16 +832,21 @@ size_t MathMacro::appetite() const
 
 MathClass MathMacro::mathClass() const
 {
-       // this only affects intelligent splitting since global macros are always
-       // linearised.
+       // This can be just a heuristic, since it is only considered for display
+       // when the macro is not linearised. Therefore it affects:
+       // * The spacing of the inset while being edited,
+       // * Intelligent splitting
+       // * Cursor word movement (Ctrl-Arrow).
        if (MacroData const * m = macroBackup()) {
+               // If it is a global macro and is defined explicitly
                if (m->symbol()) {
-                       MathClass mc = string_to_class(d->macroBackup_.symbol()->extra);
+                       MathClass mc = string_to_class(m->symbol()->extra);
                        if (mc != MC_UNKNOWN)
                                return mc;
                }
        }
-       return MC_ORD;
+       // Otherwise guess from the expanded macro
+       return d->expanded_.mathClass();
 }