#include <config.h>
#include "MetricsInfo.h"
-#include "BufferView.h"
-#include "Cursor.h"
#include "LyXRC.h"
#include "frontends/FontMetrics.h"
#include "frontends/Painter.h"
+#include <map>
+
using namespace std;
string const oldname = fontname;
fontname = name;
if (isMathFont(name) || isMathFont(oldname))
- font = isTextFont(name) ? bv->cursor().getFont().fontInfo()
- : sane_font;
+ font = isTextFont(name) ? outer_font : sane_font;
augmentFont(font, name);
- font.setSize(rc->old.font.size());
+ if (isTextFont(name) && isMathFont(oldname))
+ font.setSize(rc->old.outer_font.size());
+ else
+ font.setSize(rc->old.font.size());
font.setStyle(rc->old.font.style());
if (name == "emph") {
font.setColor(oldcolor);
}
+Changer MetricsBase::changeFontSize(string const & size, bool mathmode)
+{
+ map<string, FontSize> sizes = {
+ {"tiny", TINY_SIZE},
+ {"scriptsize", SCRIPT_SIZE},
+ {"footnotesize", FOOTNOTE_SIZE},
+ {"small", SMALL_SIZE},
+ {"normalsize", NORMAL_SIZE},
+ {"large", LARGE_SIZE},
+ {"Large", LARGER_SIZE},
+ {"LARGE", LARGEST_SIZE},
+ {"huge", HUGE_SIZE},
+ {"Huge", HUGER_SIZE}
+ };
+ RefChanger<MetricsBase> rc = make_save(*this);
+ // In math mode we only record the size in outer_font
+ if (mathmode)
+ outer_font.setSize(sizes[size]);
+ else
+ font.setSize(sizes[size]);
+ return rc;
+}
+
+
Changer MetricsBase::changeEnsureMath(Inset::mode_type mode)
{
switch (mode) {
// special handling for inset background
if (inset != nullptr) {
- if (pain.develMode() && !inset->isBufferValid())
+ if (pain.develMode() && !inset->isBufferValid()) {
+ LYXERR0("Invalid or no buffer set in " << insetName(inset->lyxCode()));
// This inset is in error
return Color_error;
+ }
ColorCode const color_bg = inset->backgroundColor(*this);
if (color_bg != Color_none)