namespace lyx {
InsetLayout::InsetLayout() :
- name_(from_ascii("undefined")), labelstring_(from_ascii("UNDEFINED")),
- decoration_(InsetLayout::Default),
- font_(sane_font), labelfont_(sane_font), bgcolor_(Color_error),
+ name_(from_ascii("undefined")), lyxtype_(STANDARD),
+ labelstring_(from_ascii("UNDEFINED")), decoration_(DEFAULT),
+ latextype_(NOLATEXTYPE), font_(sane_font),
+ labelfont_(sane_font), bgcolor_(Color_error),
multipar_(false), custompars_(false), forceplain_(true),
passthru_(false), needprotect_(false), freespacing_(false),
keepempty_(false), forceltr_(false)
InsetLayout::InsetDecoration translateDecoration(std::string const & str)
{
if (support::compare_ascii_no_case(str, "classic") == 0)
- return InsetLayout::Classic;
+ return InsetLayout::CLASSIC;
if (support::compare_ascii_no_case(str, "minimalistic") == 0)
- return InsetLayout::Minimalistic;
+ return InsetLayout::MINIMALISTIC;
if (support::compare_ascii_no_case(str, "conglomerate") == 0)
- return InsetLayout::Conglomerate;
- return InsetLayout::Default;
+ return InsetLayout::CONGLOMERATE;
+ return InsetLayout::DEFAULT;
+}
+
+InsetLayout::InsetLaTeXType translateLaTeXType(std::string const & str)
+{
+ if (support::compare_ascii_no_case(str, "command") == 0)
+ return InsetLayout::COMMAND;
+ if (support::compare_ascii_no_case(str, "environment") == 0)
+ return InsetLayout::ENVIRONMENT;
+ if (support::compare_ascii_no_case(str, "none") == 0)
+ return InsetLayout::NOLATEXTYPE;
+ return InsetLayout::ILT_ERROR;
}
}
break;
}
switch (le) {
- case IL_LYXTYPE:
- lex >> lyxtype_;
+ // FIXME
+ // Perhaps a mroe elegant way to deal with the next two would be the
+ // way this sort of thing is handled in Layout::read(), namely, by
+ // using the Lexer.
+ case IL_LYXTYPE: {
+ string lt;
+ lex >> lt;
+ lyxtype_ = translateLyXType(lt);
+ if (lyxtype_ == NOLYXTYPE)
+ LYXERR0("Unknown LyXType `" << lt << "'.");
break;
- case IL_LATEXTYPE:
- lex >> latextype_;
+ }
+ case IL_LATEXTYPE: {
+ string lt;
+ lex >> lt;
+ latextype_ = translateLaTeXType(lt);
+ if (latextype_ == ILT_ERROR)
+ LYXERR0("Unknown LaTeXType `" << lt << "'.");
break;
+ }
case IL_LABELSTRING:
lex >> labelstring_;
break;
return true;
}
+
+InsetLayout::InsetLyXType translateLyXType(std::string const & str)
+{
+
+ if (support::compare_ascii_no_case(str, "charstyle") == 0)
+ return InsetLayout::CHARSTYLE;
+ if (support::compare_ascii_no_case(str, "custom") == 0)
+ return InsetLayout::CUSTOM;
+ if (support::compare_ascii_no_case(str, "element") == 0)
+ return InsetLayout::ELEMENT;
+ if (support::compare_ascii_no_case(str, "end") == 0)
+ return InsetLayout::END;
+ if (support::compare_ascii_no_case(str, "standard") == 0)
+ return InsetLayout::STANDARD;
+ return InsetLayout::NOLYXTYPE;
+}
+
} //namespace lyx