X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FFloating.cpp;h=cf48630f69bac3ee80794f60bcbe0c58a4068231;hb=5678dc566f8873b489c66ffa5772a74c387a6396;hp=d4e21dd078b79438df2169f11dff7550f59b7da5;hpb=9fbb35bb892fe5406ec9fbbf2846f983499d8d7b;p=lyx.git diff --git a/src/Floating.cpp b/src/Floating.cpp index d4e21dd078..cf48630f69 100644 --- a/src/Floating.cpp +++ b/src/Floating.cpp @@ -14,6 +14,9 @@ #include "Floating.h" +#include "support/debug.h" +#include "support/lstrings.h" + using namespace std; @@ -27,68 +30,22 @@ 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, string const & htmlTag, - string const & htmlClass, string const & htmlStyle, - bool builtin) - : type_(type), placement_(placement), ext_(ext), within_(within), - style_(style), name_(name), listName_(listName), htmlTag_(htmlTag), - htmlClass_(htmlClass), htmlStyle_(htmlStyle), builtin_(builtin) + string const & listName, std::string const & listCmd, + string const & refPrefix, + string const & htmlTag, string const & htmlAttrib, + string const & htmlStyle, bool needsfloat) + : floattype_(type), placement_(placement), ext_(ext), within_(within), + style_(style), name_(name), listname_(listName), listcommand_(listCmd), + refprefix_(refPrefix), needsfloatpkg_(needsfloat), html_tag_(htmlTag), + html_attrib_(htmlAttrib), html_style_(htmlStyle) {} -string const & Floating::type() const -{ - return type_; -} - - -string const & Floating::placement() const -{ - return placement_; -} - - -string const & Floating::ext() const -{ - return ext_; -} - - -string const & Floating::within() const -{ - return within_; -} - - -string const & Floating::style() const +string const & Floating::htmlAttrib() const { - return style_; -} - - -string const & Floating::name() const -{ - return name_; -} - - -string const & Floating::listName() const -{ - return listName_; -} - - -string const & Floating::htmlStyle() const -{ - return html_style_; -} - - -string const & Floating::htmlClass() const -{ - if (html_class_.empty()) - html_class_ = "float-" + type_; - return html_class_; + if (html_attrib_.empty()) + html_attrib_ = "class='float " + defaultCSSClass() + "'"; + return html_attrib_; } @@ -100,9 +57,25 @@ string const & Floating::htmlTag() const } -bool Floating::builtin() const -{ - return builtin_; +string Floating::defaultCSSClass() const +{ + if (!defaultcssclass_.empty()) + return defaultcssclass_; + string d; + string n = floattype_; + string::const_iterator it = n.begin(); + string::const_iterator en = n.end(); + for (; it != en; ++it) { + if (!isalpha(*it)) + d += "_"; + else if (islower(*it)) + d += *it; + else + d += support::lowercase(*it); + } + // are there other characters we need to remove? + defaultcssclass_ = "float-" + d; + return defaultcssclass_; }