#endif
#include "insetspecialchar.h"
-#include "lyxdraw.h"
#include "debug.h"
#include "LaTeXFeatures.h"
+#include "BufferView.h"
+#include "Painter.h"
+#include "font.h"
+
+using std::ostream;
+using std::max;
InsetSpecialChar::InsetSpecialChar(Kind k)
: kind(k)
{}
-int InsetSpecialChar::Ascent(LyXFont const & font) const
+int InsetSpecialChar::ascent(BufferView *, LyXFont const & font) const
{
- return font.maxAscent();
+ return lyxfont::maxAscent(font);
}
-int InsetSpecialChar::Descent(LyXFont const & font) const
+int InsetSpecialChar::descent(BufferView *, LyXFont const & font) const
{
- return font.maxDescent();
+ return lyxfont::maxDescent(font);
}
-int InsetSpecialChar::Width(LyXFont const & font) const
+int InsetSpecialChar::width(BufferView *, LyXFont const & font) const
{
- LyXFont f = font;
switch (kind) {
case HYPHENATION:
{
- int w = f.textWidth("-", 1);
+ int w = lyxfont::width('-', font);
if (w > 5)
w -= 2; // to make it look shorter
return w;
}
case END_OF_SENTENCE:
{
- return f.textWidth(".", 1);
+ return lyxfont::width('.', font);
}
case LDOTS:
{
- return f.textWidth(". . .", 5);
+ return lyxfont::width(". . .", font);
+ }
+ case MENU_SEPARATOR:
+ {
+ return lyxfont::width(" x ", font);
}
- case MENU_SEPARATOR: {
- return f.textWidth(" x ", 3);
+ case PROTECTED_SEPARATOR:
+ {
+ return lyxfont::width('x', font);
}
+
}
return 1; // To shut up gcc
}
-void InsetSpecialChar::Draw(LyXFont font, LyXScreen & scr,
- int baseline, float & x)
+void InsetSpecialChar::draw(BufferView * bv, LyXFont const & f,
+ int baseline, float & x, bool) const
{
+ Painter & pain = bv->painter();
+ LyXFont font(f);
+
switch (kind) {
case HYPHENATION:
{
- font.setColor(LyXFont::MAGENTA);
- scr.drawText(font, "-", 1, baseline, int(x));
- x += Width(font);
+ font.setColor(LColor::special);
+ pain.text(int(x), baseline, "-", font);
+ x += width(bv, font);
break;
}
case END_OF_SENTENCE:
{
- font.setColor(LyXFont::MAGENTA);
- scr.drawText(font, ".", 1, baseline, int(x));
- x += Width(font);
+ font.setColor(LColor::special);
+ pain.text(int(x), baseline, ".", font);
+ x += width(bv, font);
break;
}
case LDOTS:
{
- font.setColor(LyXFont::MAGENTA);
- scr.drawText(font, ". . .", 5, baseline, int(x));
- x += Width(font);
+ font.setColor(LColor::special);
+ pain.text(int(x), baseline, ". . .", font);
+ x += width(bv, font);
break;
}
case MENU_SEPARATOR:
{
// A triangle the width and height of an 'x'
- int w = font.textWidth("x", 1);
- int ox = font.textWidth(" ", 1) + int(x);
- int h = font.ascent('x');
- XPoint p[4];
- p[0].x = ox; p[0].y = baseline;
- p[1].x = ox; p[1].y = baseline - h;
- p[2].x = ox + w;p[2].y = baseline - h/2;
- p[3].x = ox; p[3].y = baseline;
- scr.drawLines(getGC(gc_copy), p, 4);
- x += Width(font);
+ int w = lyxfont::width('x', font);
+ int ox = lyxfont::width(' ', font) + int(x);
+ int h = lyxfont::ascent('x', font);
+ int xp[4], yp[4];
+
+ xp[0] = ox; yp[0] = baseline;
+ xp[1] = ox; yp[1] = baseline - h;
+ xp[2] = ox + w; yp[2] = baseline - h/2;
+ xp[3] = ox; yp[3] = baseline;
+
+ pain.lines(xp, yp, 4, LColor::special);
+ x += width(bv, font);
+ break;
+ }
+ case PROTECTED_SEPARATOR:
+ {
+ float w = width(bv, font);
+ int h = lyxfont::ascent('x', font);
+ int xp[4], yp[4];
+
+ xp[0] = int(x);
+ yp[0] = baseline - max(h / 4, 1);
+
+ xp[1] = int(x);
+ yp[1] = baseline;
+
+ xp[2] = int(x + w);
+ yp[2] = baseline;
+
+ xp[3] = int(x + w);
+ yp[3] = baseline - max(h / 4, 1);
+
+ pain.lines(xp, yp, 4, LColor::special);
+ x += w;
+ break;
}
}
}
// In lyxf3 this will be just LaTeX
-void InsetSpecialChar::Write(ostream & os)
+void InsetSpecialChar::Write(Buffer const *, ostream & os) const
{
string command;
switch (kind) {
case END_OF_SENTENCE: command = "\\@."; break;
case LDOTS: command = "\\ldots{}"; break;
case MENU_SEPARATOR: command = "\\menuseparator"; break;
+ case PROTECTED_SEPARATOR:
+ //command = "\\protected_separator";
+ command = "~";
+ break;
}
os << "\\SpecialChar " << command << "\n";
}
// This function will not be necessary when lyx3
-void InsetSpecialChar::Read(LyXLex & lex)
+void InsetSpecialChar::Read(Buffer const *, LyXLex & lex)
{
lex.nextToken();
string command = lex.GetString();
kind = LDOTS;
else if (command == "\\menuseparator")
kind = MENU_SEPARATOR;
+ else if (command == "\\protected_separator"
+ || command == "~")
+ kind = PROTECTED_SEPARATOR;
else
lex.printError("InsetSpecialChar: Unknown kind: `$$Token'");
}
-int InsetSpecialChar::Latex(ostream & os, signed char /*fragile*/)
+int InsetSpecialChar::Latex(Buffer const *, ostream & os, bool /*fragile*/,
+ bool free_space) const
{
- string command;
- signed char dummy = 0;
- Latex(command, dummy);
- os << command;
+ switch (kind) {
+ case HYPHENATION: os << "\\-"; break;
+ case END_OF_SENTENCE: os << "\\@."; break;
+ case LDOTS: os << "\\ldots{}"; break;
+ case MENU_SEPARATOR: os << "\\lyxarrow{}"; break;
+ case PROTECTED_SEPARATOR: os << (free_space ? " " : "~"); break;
+ }
return 0;
}
-
-int InsetSpecialChar::Latex(string & file, signed char /*fragile*/)
+int InsetSpecialChar::Ascii(Buffer const *, ostream & os, int) const
{
switch (kind) {
- case HYPHENATION: file += "\\-"; break;
- case END_OF_SENTENCE: file += "\\@."; break;
- case LDOTS: file += "\\ldots{}"; break;
- case MENU_SEPARATOR: file += "\\lyxarrow{}"; break;
+ case HYPHENATION: break;
+ case END_OF_SENTENCE: os << "."; break;
+ case LDOTS: os << "..."; break;
+ case MENU_SEPARATOR: os << "->"; break;
+ case PROTECTED_SEPARATOR: os << " "; break;
}
return 0;
}
-int InsetSpecialChar::Linuxdoc(string & file)
+int InsetSpecialChar::Linuxdoc(Buffer const * buf, ostream & os) const
{
- switch (kind) {
- case HYPHENATION: file += ""; break;
- case END_OF_SENTENCE: file += ""; break;
- case LDOTS: file += "..."; break;
- case MENU_SEPARATOR: file += "->"; break;
- }
- return 0;
+ return Ascii(buf, os, 0);
}
-int InsetSpecialChar::DocBook(string & file)
+int InsetSpecialChar::DocBook(Buffer const * buf, ostream & os) const
{
- switch (kind) {
- case HYPHENATION: file += ""; break;
- case END_OF_SENTENCE: file += ""; break;
- case LDOTS: file += "..."; break;
- case MENU_SEPARATOR: file += "->"; break;
- }
- return 0;
+ return Ascii(buf, os, 0);
}
-Inset * InsetSpecialChar::Clone() const
+Inset * InsetSpecialChar::Clone(Buffer const &) const
{
return new InsetSpecialChar(kind);
}