4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
7 * \author Lars Gullik Bjønnes
9 * Full author contact details are available in file CREDITS.
15 #include "support/strfwd.h"
22 /** This is a "float layout" object. It contains the parameters for how to
23 * handle the different kinds of floats, default ones and user created ones.
24 * Objects of this class is stored in a container in FloatList. The different
25 * InsetFloat(s) have a pointer/reference through the name of the Floating
26 * so that it knows how the different floats should be handled.
31 Floating() : usesfloatpkg_(false), ispredefined_(false),
32 allowswide_(true), allowssideways_(true) {}
34 Floating(std::string const & type, std::string const & placement,
35 std::string const & ext, std::string const & within,
36 std::string const & style, std::string const & name,
37 std::string const & listName, std::string const & listCmd,
38 std::string const & refPrefix, std::string const & allowedplacement,
39 std::string const & htmlTag, std::string const & htmlAttrib,
40 docstring const & htmlStyle,
41 std::string const & docbookAttr, std::string const & docbookTagType,
42 std::string const & required, bool usesfloat, bool ispredefined,
43 bool allowswide, bool allowssideways);
45 std::string const & floattype() const { return floattype_; }
47 std::string docbookFloatType() const;
49 std::string const & placement() const { return placement_; }
51 std::string const & ext() const {return ext_; }
53 std::string const & within() const { return within_; }
55 std::string const & style() const { return style_; }
57 std::string const & name() const { return name_; }
58 /// the title of a list of this kind of float
59 std::string const & listName() const { return listname_; }
60 /// the command used to generate that list. this has to be given
61 /// if usesFloatPkg() is false, unless this float uses the same
62 /// auxfile as another defined previously. this should not contain
64 std::string const & listCommand() const { return listcommand_; }
65 /// prefix to use for formatted references to such floats
66 std::string const & refPrefix() const { return refprefix_; }
67 /// allowed placement options
68 std::string const & allowedPlacement() const { return allowedplacement_; }
70 bool usesFloatPkg() const { return usesfloatpkg_; }
71 /// allowed placement options
72 std::string const & required() const { return required_; }
74 bool isPredefined() const { return ispredefined_; }
76 bool allowsWide() const { return allowswide_; }
78 bool allowsSideways() const { return allowssideways_; }
79 /// style information, for preamble
80 docstring const & htmlStyle() const { return html_style_; }
81 /// class, for css, defaults to "float-" + type()
82 std::string const & htmlAttrib() const;
83 /// tag type, defaults to "div"
84 std::string const & htmlTag() const;
86 std::string docbookTag(bool hasTitle = false) const;
88 std::string docbookAttr() const;
90 std::string const & docbookTagType() const;
92 std::string const & docbookCaption() const;
95 std::string defaultCSSClass() const;
97 std::string floattype_;
99 std::string placement_;
109 std::string listname_;
111 std::string listcommand_;
113 std::string refprefix_;
115 std::string allowedplacement_;
117 std::string required_;
125 bool allowssideways_;
127 mutable std::string html_tag_;
129 mutable std::string html_attrib_;
131 mutable std::string defaultcssclass_;
133 docstring html_style_;
134 // There is no way to override the DocBook tag based on the layouts: half of it is determined by whether the float
135 // has a title or not, an information that is not available in the layouts.
136 /// attribute (mostly, role)
137 mutable std::string docbook_caption_;
138 /// caption tag (mostly, either caption or title)
139 std::string docbook_attr_;
140 /// DocBook tag type (block, paragraph, inline)
141 mutable std::string docbook_tag_type_;