#include <config.h>
-#include "BufferView.h"
-#include "ColorSet.h"
-#include "LyXRC.h"
#include "MetricsInfo.h"
+#include "LyXRC.h"
+
#include "insets/Inset.h"
#include "mathed/MathSupport.h"
#include "frontends/FontMetrics.h"
#include "frontends/Painter.h"
-#include "support/docstring.h"
-#include "support/lassert.h"
-#include "support/RefChanger.h"
-
using namespace std;
augmentFont(font, name);
font.setSize(rc->old.font.size());
font.setStyle(rc->old.font.style());
- if (name != "lyxtex"
+ if (name == "emph") {
+ font.setColor(oldcolor);
+ if (rc->old.font.shape() != UP_SHAPE)
+ font.setShape(UP_SHAPE);
+ else
+ font.setShape(ITALIC_SHAPE);
+ } else if (name != "lyxtex"
&& ((isTextFont(oldname) && oldcolor != Color_foreground)
|| (isMathFont(oldname) && oldcolor != Color_math)))
font.setColor(oldcolor);
{
switch (mode) {
case Inset::UNDECIDED_MODE:
- return Changer();
+ return noChange();
case Inset::TEXT_MODE:
- return isMathFont(fontname) ? changeFontSet("textnormal") : Changer();
+ return isMathFont(fontname) ? changeFontSet("textnormal") : noChange();
case Inset::MATH_MODE:
// FIXME:
// \textit{\ensuremath{\text{a}}}
// should appear in italics
- return isTextFont(fontname) ? changeFontSet("mathnormal"): Changer();
+ return isTextFont(fontname) ? changeFontSet("mathnormal"): noChange();
}
- return Changer();
+ return noChange();
}
fi.setFamily(SYMBOL_FAMILY);
else
// Math style is only taken into account in the case of mu
- fi.setStyle(FONT_STYLE_TEXT);
+ fi.setStyle(TEXT_STYLE);
return len.inPixels(textwidth, theFontMetrics(fi).em());
}
/////////////////////////////////////////////////////////////////////////
MetricsInfo::MetricsInfo(BufferView * bv, FontInfo font, int textwidth,
- MacroContext const & mc)
- : base(bv, font, textwidth), macrocontext(mc)
+ MacroContext const & mc, bool vm)
+ : base(bv, font, textwidth), macrocontext(mc), vmode(vm)
{}
/////////////////////////////////////////////////////////////////////////
PainterInfo::PainterInfo(BufferView * bv, lyx::frontend::Painter & painter)
- : pain(painter), ltr_pos(false), change_(), selected(false),
- do_spellcheck(true), full_repaint(true), background_color(Color_background)
+ : pain(painter), ltr_pos(false), change(), selected(false),
+ do_spellcheck(true), full_repaint(true), background_color(Color_background),
+ leftx(0), rightx(0)
{
base.bv = bv;
}
ColorCode PainterInfo::backgroundColor(Inset const * inset, bool sel) const
{
- ColorCode const color_bg = inset->backgroundColor(*this);
-
if (selected && sel)
// This inset is in a selection
return Color_selection;
- else {
+
+ // special handling for inset background
+ if (inset != nullptr) {
+ if (pain.develMode() && !inset->isBufferValid())
+ // This inset is in error
+ return Color_error;
+
+ ColorCode const color_bg = inset->backgroundColor(*this);
if (color_bg != Color_none)
// This inset has its own color
return color_bg;
- else {
- if (background_color == Color_none)
- // This inset has no own color and does not inherit a color
- return Color_background;
- else
- // This inset has no own color, but inherits a color
- return background_color;
- }
}
+
+ if (background_color == Color_none)
+ // This inset has no own color and does not inherit a color
+ return Color_background;
+
+ // This inset has no own color, but inherits a color
+ return background_color;
}
Color PainterInfo::textColor(Color const & color) const
{
- if (change_.changed())
- return change_.color();
+ if (change.changed())
+ return change.color();
if (selected)
return Color_selectiontext;
return color;
Changer MetricsBase::changeScript()
{
switch (font.style()) {
- case FONT_STYLE_DISPLAY:
- case FONT_STYLE_TEXT:
- return font.changeStyle(FONT_STYLE_SCRIPT);
- case FONT_STYLE_SCRIPT:
- case FONT_STYLE_SCRIPTSCRIPT:
- return font.changeStyle(FONT_STYLE_SCRIPTSCRIPT);
- case FONT_STYLE_INHERIT:
- case FONT_STYLE_IGNORE:
- return Changer();
+ case DISPLAY_STYLE:
+ case TEXT_STYLE:
+ return font.changeStyle(SCRIPT_STYLE);
+ case SCRIPT_STYLE:
+ case SCRIPTSCRIPT_STYLE:
+ return font.changeStyle(SCRIPTSCRIPT_STYLE);
+ case INHERIT_STYLE:
+ case IGNORE_STYLE:
+ return noChange();
}
//remove Warning
- return Changer();
+ return noChange();
}
Changer MetricsBase::changeFrac()
{
switch (font.style()) {
- case FONT_STYLE_DISPLAY:
- return font.changeStyle(FONT_STYLE_TEXT);
- case FONT_STYLE_TEXT:
- return font.changeStyle(FONT_STYLE_SCRIPT);
- case FONT_STYLE_SCRIPT:
- case FONT_STYLE_SCRIPTSCRIPT:
- return font.changeStyle(FONT_STYLE_SCRIPTSCRIPT);
- case FONT_STYLE_INHERIT:
- case FONT_STYLE_IGNORE:
- return Changer();
+ case DISPLAY_STYLE:
+ return font.changeStyle(TEXT_STYLE);
+ case TEXT_STYLE:
+ return font.changeStyle(SCRIPT_STYLE);
+ case SCRIPT_STYLE:
+ case SCRIPTSCRIPT_STYLE:
+ return font.changeStyle(SCRIPTSCRIPT_STYLE);
+ case INHERIT_STYLE:
+ case IGNORE_STYLE:
+ return noChange();
}
//remove Warning
- return Changer();
+ return noChange();
}
-Changer MetricsBase::changeArray()
+Changer MetricsBase::changeArray(bool small)
{
- return (font.style() == FONT_STYLE_DISPLAY) ? font.changeStyle(FONT_STYLE_TEXT)
- : Changer();
+ if (small)
+ return font.changeStyle(SCRIPT_STYLE);
+ return (font.style() == DISPLAY_STYLE) ? font.changeStyle(TEXT_STYLE)
+ : noChange();
}