#include "BufferParams.h"
#include "BufferView.h"
#include "Dimension.h"
+#include "Font.h"
#include "Language.h"
#include "LaTeXFeatures.h"
#include "Lexer.h"
/* codes used to read/write quotes to LyX files
* e ``english''
- * s ''spanish''
+ * s ''swedish''
* g ,,german``
* p ,,polish''
* f <<french>>
parseString(str);
}
-InsetQuotes::InsetQuotes(Buffer * buf, char_type c) : Inset(buf)
-{
- if (buf) {
- language_ = buf->params().quotes_language;
- times_ = buf->params().quotes_times;
- }
- setSide(c);
-}
-
-
InsetQuotes::InsetQuotes(Buffer * buf, char_type c, QuoteTimes t)
: Inset(buf), times_(t)
{
if (buf)
language_ = buf->params().quotes_language;
+ else
+ language_ = EnglishQuotes;
+
setSide(c);
}
-docstring InsetQuotes::name() const
+docstring InsetQuotes::layoutName() const
{
return from_ascii("Quotes");
}
docstring InsetQuotes::displayString() const
{
- Language const * loclang = buffer().params().language;
+ Language const * loclang =
+ isBufferValid() ? buffer().params().language : 0;
int const index = quote_index[side_][language_];
docstring retdisp = docstring(1, display_quote_char[times_][index]);
// in french, spaces are added inside double quotes
- if (times_ == DoubleQuotes && prefixIs(loclang->code(), "fr")) {
+ // FIXME: this should be done by a separate quote type.
+ if (times_ == DoubleQuotes && loclang && prefixIs(loclang->code(), "fr")) {
if (side_ == LeftQuote)
retdisp += ' ';
else
{
// FIXME: should we add a language or a font parameter member?
docstring const text = displayString();
-
+ FontInfo font = pi.base.font;
+ font.setPaintColor(pi.textColor(font.realColor()));
if (text.length() == 2 && text[0] == text[1]) {
- pi.pain.text(x, y, text[0], pi.base.font);
- int const t = theFontMetrics(pi.base.font)
+ pi.pain.text(x, y, text[0], font);
+ int const t = theFontMetrics(font)
.width(',');
- pi.pain.text(x + t, y, text[0], pi.base.font);
+ pi.pain.text(x + t, y, text[0], font);
} else {
- pi.pain.text(x, y, text, pi.base.font);
+ pi.pain.text(x, y, text, font);
}
}
}
-int InsetQuotes::latex(odocstream & os, OutputParams const & runparams) const
+void InsetQuotes::latex(otexstream & os, OutputParams const & runparams) const
{
const int quoteind = quote_index[side_][language_];
string qstr;
if (language_ == FrenchQuotes && times_ == DoubleQuotes
- && prefixIs(runparams.local_font->language()->code(), "fr")) {
+ && prefixIs(runparams.local_font->language()->code(), "fr")
+ && !runparams.use_polyglossia) {
if (side_ == LeftQuote)
qstr = "\\og "; //the spaces are important here
else
qstr = " \\fg{}"; //and here
- } else if (lyxrc.fontenc == "T1") {
+ } else if (lyxrc.fontenc == "T1" && !runparams.use_polyglossia) {
qstr = latex_quote_t1[times_][quoteind];
#ifdef DO_USE_DEFAULT_LANGUAGE
} else if (doclang == "default") {
#else
} else if (!runparams.use_babel) {
#endif
+ // these are also used by polyglossia
qstr = latex_quote_ot1[times_][quoteind];
} else {
qstr = latex_quote_babel[times_][quoteind];
}
// Always guard against unfortunate ligatures (!` ?`)
- if (prefixIs(qstr, "`"))
- qstr.insert(0, "{}");
+ if (prefixIs(qstr, "`")) {
+ char_type const lastchar = os.lastChar();
+ if (lastchar == '!' || lastchar == '?')
+ qstr.insert(0, "{}");
+ }
os << from_ascii(qstr);
- return 0;
}
-int InsetQuotes::plaintext(odocstream & os, OutputParams const &) const
+int InsetQuotes::plaintext(odocstringstream & os,
+ OutputParams const &, size_t) const
{
docstring const str = displayString();
os << str;
}
-int InsetQuotes::docbook(odocstream & os, OutputParams const &) const
-{
+docstring InsetQuotes::getQuoteEntity() const {
if (times_ == DoubleQuotes) {
if (side_ == LeftQuote)
- os << "“";
- else
- os << "”";
- } else {
- if (side_ == LeftQuote)
- os << "‘";
+ return from_ascii("“");
else
- os << "’";
+ return from_ascii("”");
}
+ if (side_ == LeftQuote)
+ return from_ascii("‘");
+ else
+ return from_ascii("’");
+}
+
+
+int InsetQuotes::docbook(odocstream & os, OutputParams const &) const
+{
+ os << getQuoteEntity();
return 0;
}
-docstring InsetQuotes::xhtml(XHTMLStream & xs, OutputParams const & op) const
+docstring InsetQuotes::xhtml(XHTMLStream & xs, OutputParams const &) const
{
- docbook(xs.os(), op);
+ xs << XHTMLStream::ESCAPE_NONE << getQuoteEntity();
return docstring();
}
-void InsetQuotes::tocString(odocstream & os) const
+void InsetQuotes::toString(odocstream & os) const
{
os << displayString();
}
+void InsetQuotes::forOutliner(docstring & os, size_t const, bool const) const
+{
+ os += displayString();
+}
+
+
void InsetQuotes::validate(LaTeXFeatures & features) const
{
- bool const use_babel = features.useBabel();
char type = quote_char[quote_index[side_][language_]];
#ifdef DO_USE_DEFAULT_LANGUAGE
if (features.bufferParams().language->lang() == "default"
#else
- if (!use_babel
+ if (!features.useBabel()
#endif
&& lyxrc.fontenc != "T1") {
if (times_ == SingleQuotes)