- LyXFont font(LyXFont::ALL_IGNORE);
- font.setFamily(LyXFont::SANS_FAMILY);
- toggleAndShow(bv, font);
-}
-
-
-void roman(BufferView * bv)
-{
- LyXFont font(LyXFont::ALL_IGNORE);
- font.setFamily(LyXFont::ROMAN_FAMILY);
- toggleAndShow(bv, font);
-}
-
-
-void styleReset(BufferView * bv)
-{
-#ifndef INHERIT_LANG
- LyXFont font(LyXFont::ALL_INHERIT, ignore_language);
-#else
- LyXFont font(LyXFont::ALL_INHERIT);
-#endif
- toggleAndShow(bv, font);
-}
-
-
-void underline(BufferView * bv)
-{
- LyXFont font(LyXFont::ALL_IGNORE);
- font.setUnderbar(LyXFont::TOGGLE);
- toggleAndShow(bv, font);
-}
-
-
-void fontSize(BufferView * bv, string const & size)
-{
- LyXFont font(LyXFont::ALL_IGNORE);
- font.setLyXSize(size);
- toggleAndShow(bv, font);
-}
-
-
-// Returns the current font and depth as a message.
-string const currentState(BufferView * bv)
-{
- ostringstream state;
-
- if (bv->available()) {
- // I think we should only show changes from the default
- // font. (Asger)
- LyXText * text = bv->getLyXText();
- Buffer * buffer = bv->buffer();
- LyXFont font = text->real_current_font;
- LyXFont const & defaultfont =
- textclasslist[buffer->params.textclass].defaultfont();
- font.reduce(defaultfont);
-
- state << _("Font:") << ' '
- << font.stateText(&buffer->params);
-
- // The paragraph depth
- int depth = text->getDepth();
- if (depth > 0)
- state << _(", Depth: ") << depth;
-
- // The paragraph spacing, but only if different from
- // buffer spacing.
- if (!text->cursor.par()->params().spacing().isDefault()) {
- Spacing::Space cur_space =
- text->cursor.par()->params().spacing().getSpace();
- state << _(", Spacing: ");
-
- switch (cur_space) {
- case Spacing::Single:
- state << _("Single");
-
- break;
- case Spacing::Onehalf:
- state << _("Onehalf");
- break;
- case Spacing::Double:
- state << _("Double");
- break;
- case Spacing::Other:
- state << _("Other (")
- << text->cursor.par()->params().spacing().getValue()
- << ")";
- break;
- case Spacing::Default:
- // should never happen, do nothing
- break;
- }
+ istringstream is(data);
+ LyXLex lex(0,0);
+ lex.setStream(is);
+
+ int nset = 0;
+ while (lex.isOK()) {
+ string token;
+ if (lex.next())
+ token = lex.getString();
+
+ if (token.empty() || !lex.next())
+ break;
+
+ if (token == "family") {
+ int const next = lex.getInteger();
+ font.setFamily(LyXFont::FONT_FAMILY(next));
+
+ } else if (token == "series") {
+ int const next = lex.getInteger();
+ font.setSeries(LyXFont::FONT_SERIES(next));
+
+ } else if (token == "shape") {
+ int const next = lex.getInteger();
+ font.setShape(LyXFont::FONT_SHAPE(next));
+
+ } else if (token == "size") {
+ int const next = lex.getInteger();
+ font.setSize(LyXFont::FONT_SIZE(next));
+
+ } else if (token == "emph" || token == "underbar" ||
+ token == "noun" || token == "number") {
+
+ int const next = lex.getInteger();
+ LyXFont::FONT_MISC_STATE const misc =
+ LyXFont::FONT_MISC_STATE(next);
+
+ if (token == "emph")
+ font.setEmph(misc);
+ else if (token == "underbar")
+ font.setUnderbar(misc);
+ else if (token == "noun")
+ font.setNoun(misc);
+ else if (token == "number")
+ font.setNumber(misc);
+
+ } else if (token == "color") {
+ int const next = lex.getInteger();
+ font.setColor(LColor::color(next));
+
+ } else if (token == "language") {
+ string const next = lex.getString();
+ if (next == "ignore")
+ font.setLanguage(ignore_language);
+ else
+ font.setLanguage(languages.getLanguage(next));
+
+ } else if (token == "toggleall") {
+ toggle = lex.getBool();
+
+ } else {
+ // Unrecognised token
+ break;