X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FFloating.cpp;h=6ae52b4d2247f2af70e4eb743d320d5d1171689c;hb=d1b9af3b1dede776f92910378f538f881a68d28e;hp=fe3c72c28d49fd2e5b4f9518ffe3d31d7f4faa42;hpb=08a58242c157868efc5b3d52577e09f898725198;p=lyx.git diff --git a/src/Floating.cpp b/src/Floating.cpp index fe3c72c28d..6ae52b4d22 100644 --- a/src/Floating.cpp +++ b/src/Floating.cpp @@ -30,7 +30,7 @@ Floating::Floating(string const & type, string const & placement, string const & listName, std::string const & listCmd, string const & refPrefix, std::string const & allowedplacement, string const & htmlTag, string const & htmlAttrib, - docstring const & htmlStyle, string const & docbookTag, + docstring const & htmlStyle, string const & docbookAttr, string const & docbookTagType, string const & required, bool usesfloat, bool ispredefined, bool allowswide, bool allowssideways) @@ -44,6 +44,25 @@ Floating::Floating(string const & type, string const & placement, {} +std::string Floating::docbookFloatType() const +{ + // TODO: configure this in the layouts? + if (floattype_ == "figure") { + return "figure"; + } else if (floattype_ == "table" || floattype_ == "tableau") { + return "table"; + } else if (floattype_ == "algorithm") { + // TODO: no good translation for now! Figures are the closest match, as they can contain text. + // Solvable as soon as https://github.com/docbook/docbook/issues/157 has a definitive answer. + return "algorithm"; + } else { + // If nothing matches, return something that will not be valid. + LYXERR0("Unrecognised float type: " + floattype_); + return "unknown"; + } +} + + string const & Floating::htmlAttrib() const { if (html_attrib_.empty()) @@ -91,17 +110,17 @@ string const & Floating::docbookAttr() const string Floating::docbookTag(bool hasTitle) const { // TODO: configure this in the layouts? - if (floattype_ == "figure") { + if (docbookFloatType() == "figure") { return hasTitle ? "figure" : "informalfigure"; - } else if (floattype_ == "table" || floattype_ == "tableau") { + } else if (docbookFloatType() == "table") { return hasTitle ? "table" : "informaltable"; - } else if (floattype_ == "algorithm") { + } else if (docbookFloatType() == "algorithm") { // TODO: no good translation for now! Figures are the closest match, as they can contain text. // Solvable as soon as https://github.com/docbook/docbook/issues/157 has a definitive answer. return "figure"; } else { // If nothing matches, return something that will not be valid. - LYXERR0("Unrecognised float type: " + floattype_); + LYXERR0("Unrecognised float type: " + floattype()); return "float"; } }