]> git.lyx.org Git - lyx.git/blobdiff - src/Floating.cpp
Move several common types to support/types.h
[lyx.git] / src / Floating.cpp
index 8cfdf8d746e94c960a49cdfcddea116b981beadc..fa93b97f44464c4b5d61b5a738dc4aac150b6441 100644 (file)
  */
 
 #include <config.h>
+#include <set>
 
 #include "Floating.h"
 
 #include "support/debug.h"
 #include "support/lstrings.h"
+#include "support/textutils.h"
 
 using namespace std;
 
@@ -23,27 +25,50 @@ using namespace std;
 namespace lyx {
 
 
-Floating::Floating()
-{}
-
-
 Floating::Floating(string const & type, string const & placement,
                   string const & ext, string const & within,
                   string const & style, string const & name,
-                  string const & listName, std::string const & listCmd, 
-                        string const & htmlTag, string const & htmlAttrib, 
-                        string const & htmlStyle, bool needsfloat)
+                  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 & docbookAttr, string const & docbookTagType,
+           string const & required, bool usesfloat, bool ispredefined,
+                  bool allowswide, bool allowssideways)
        : floattype_(type), placement_(placement), ext_(ext), within_(within),
          style_(style), name_(name), listname_(listName), listcommand_(listCmd),
-         needsfloatpkg_(needsfloat), html_tag_(htmlTag), html_attrib_(htmlAttrib), 
-         html_style_(htmlStyle)
+         refprefix_(refPrefix), allowedplacement_(allowedplacement), required_(required),
+         usesfloatpkg_(usesfloat), ispredefined_(ispredefined),
+         allowswide_(allowswide), allowssideways_(allowssideways),
+         html_tag_(htmlTag), html_attrib_(htmlAttrib), html_style_(htmlStyle),
+         docbook_attr_(docbookAttr), docbook_tag_type_(docbookTagType)
 {}
 
 
+std::string Floating::docbookFloatType() const
+{
+       // TODO: configure this in the layouts?
+       if (floattype_ == "figure" || floattype_ == "graph" ||
+                       floattype_ == "chart" || floattype_ == "scheme")  {
+               return "figure";
+       } else if (floattype_ == "table" || floattype_ == "tableau") {
+               return "table";
+       } else if (floattype_ == "algorithm") {
+               return "algorithm";
+       } else if (floattype_ == "video") {
+               return "video";
+       } 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())
-               html_attrib_ = "class='float " + defaultCSSClass() + "'";
+               html_attrib_ = "class='" + defaultCSSClass() + "'";
        return html_attrib_;
 }
 
@@ -57,7 +82,7 @@ string const & Floating::htmlTag() const
 
 
 string Floating::defaultCSSClass() const
-{ 
+{
        if (!defaultcssclass_.empty())
                return defaultcssclass_;
        string d;
@@ -65,9 +90,9 @@ string Floating::defaultCSSClass() const
        string::const_iterator it = n.begin();
        string::const_iterator en = n.end();
        for (; it != en; ++it) {
-               if (!isalpha(*it))
+               if (!isAlphaASCII(*it))
                        d += "_";
-               else if (islower(*it))
+               else if (isLower(*it))
                        d += *it;
                else
                        d += support::lowercase(*it);
@@ -78,4 +103,52 @@ string Floating::defaultCSSClass() const
 }
 
 
+string Floating::docbookAttr() const
+{
+       std::set<std::string> achemso = { "chart", "graph", "scheme" };
+       // For algorithms, a type attribute must be mentioned, if not already present in docbook_attr_.
+       if (docbookFloatType() == "algorithm" && docbook_attr_.find("type=") != std::string::npos)
+               return docbook_attr_ + " type='algorithm'";
+       // Specific floats for achemso.
+       else if (docbookFloatType() == "figure" && achemso.find(floattype_) != achemso.end())
+               return docbook_attr_ + " type='" + floattype_ + "'";
+       else
+               return docbook_attr_;
+}
+
+
+string Floating::docbookTag(bool hasTitle) const
+{
+       // TODO: configure this in the layouts?
+       if (docbookFloatType() == "figure" || docbookFloatType() == "algorithm" || docbookFloatType() == "video") {
+               return hasTitle ? "figure" : "informalfigure";
+       } else if (docbookFloatType() == "table") {
+               return hasTitle ? "table" : "informaltable";
+       } else {
+               // If nothing matches, return something that will not be valid.
+               LYXERR0("Unrecognised float type: " + floattype());
+               return "float";
+       }
+}
+
+
+string const & Floating::docbookTagType() const
+{
+       if (docbook_tag_type_ != "block" && docbook_tag_type_ != "paragraph" && docbook_tag_type_ != "inline")
+               docbook_tag_type_ = "block";
+       return docbook_tag_type_;
+}
+
+
+string const & Floating::docbookCaption() const
+{
+       docbook_caption_ = "";
+       if (floattype_ == "figure" || floattype_ == "algorithm")
+               docbook_caption_ = "title";
+       else if (floattype_ == "table" || floattype_ == "tableau")
+               docbook_caption_ = "caption";
+       return docbook_caption_;
+}
+
+
 } // namespace lyx