#include "debug.h"
#include "LaTeXFeatures.h"
#include "Painter.h"
+#include "font.h"
+using std::ostream;
using std::max;
InsetSpecialChar::InsetSpecialChar(Kind k)
int InsetSpecialChar::ascent(Painter &, LyXFont const & font) const
{
- return font.maxAscent();
+ return lyxfont::maxAscent(font);
}
int InsetSpecialChar::descent(Painter &, LyXFont const & font) const
{
- return font.maxDescent();
+ return lyxfont::maxDescent(font);
}
switch (kind) {
case HYPHENATION:
{
- int w = font.textWidth("-", 1);
+ int w = lyxfont::width('-', font);
if (w > 5)
w -= 2; // to make it look shorter
return w;
}
case END_OF_SENTENCE:
{
- return font.textWidth(".", 1);
+ return lyxfont::width('.', font);
}
case LDOTS:
{
- return font.textWidth(". . .", 5);
+ return lyxfont::width(". . .", font);
}
case MENU_SEPARATOR:
{
- return font.textWidth(" x ", 3);
+ return lyxfont::width(" x ", font);
}
-#if 0
- case NEWLINE:
- {
- }
-#endif
case PROTECTED_SEPARATOR:
{
- return font.textWidth("x", 1);
+ return lyxfont::width('x', font);
}
}
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');
+ 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;
x += width(pain, font);
break;
}
-#if 0
- case NEWLINE:
- {
- }
-#endif
case PROTECTED_SEPARATOR:
{
float w = width(pain, font);
- int h = font.ascent('x');
+ int h = lyxfont::ascent('x', font);
int xp[4], yp[4];
xp[0] = int(x);
case END_OF_SENTENCE: command = "\\@."; break;
case LDOTS: command = "\\ldots{}"; break;
case MENU_SEPARATOR: command = "\\menuseparator"; break;
-#if 0
- case NEWLINE: command = "\\newline"; break;
-#endif
case PROTECTED_SEPARATOR:
- command = "\\protected_separator"; break;
+ //command = "\\protected_separator";
+ command = "~";
+ break;
}
os << "\\SpecialChar " << command << "\n";
}
kind = LDOTS;
else if (command == "\\menuseparator")
kind = MENU_SEPARATOR;
- else if (command == "\\protected_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(ostream & os, bool /*fragile*/,
bool free_space) const
{
switch (kind) {
return 0;
}
-
-int InsetSpecialChar::Linuxdoc(ostream & os) const
+int InsetSpecialChar::Ascii(ostream & os) const
{
switch (kind) {
- case HYPHENATION: os << ""; break;
- case END_OF_SENTENCE: os << ""; break;
+ case HYPHENATION: break;
+ case END_OF_SENTENCE: os << "."; break;
case LDOTS: os << "..."; break;
case MENU_SEPARATOR: os << "->"; break;
case PROTECTED_SEPARATOR: os << " "; break;
}
+int InsetSpecialChar::Linuxdoc(ostream & os) const
+{
+ return Ascii(os);
+}
+
+
int InsetSpecialChar::DocBook(ostream & os) const
{
- switch (kind) {
- case HYPHENATION: os << ""; break;
- case END_OF_SENTENCE: os << ""; break;
- case LDOTS: os << "..."; break;
- case MENU_SEPARATOR: os << "->"; break;
- case PROTECTED_SEPARATOR: os << " "; break;
- }
- return 0;
+ return Ascii(os);
}