]> git.lyx.org Git - lyx.git/blobdiff - src/Floating.cpp
DocBook: fix file inclusion.
[lyx.git] / src / Floating.cpp
index 7ee042c1e339855f7ae85bf986bd8d3d33cfbb8b..6ae52b4d2247f2af70e4eb743d320d5d1171689c 100644 (file)
@@ -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";
        }
 }