]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetLayout.h
tex2lyx/text.cpp: fix typos
[lyx.git] / src / insets / InsetLayout.h
index 27eae62e563cf5dd25b2b0096fb05477be4c4202..4619abcb0a363fe520009af7d7cae1ce7677649b 100644 (file)
 namespace lyx {
 
 class Lexer;
-
-///
-enum InsetDecoration {
-       Deco_Classic,
-       Deco_Minimalistic,
-       Deco_Conglomerate,
-       Deco_Default
-};
+class TextClass;
 
 ///
 class InsetLayout {
@@ -39,54 +32,148 @@ public:
        ///
        InsetLayout();
        ///
-       bool read(Lexer & lexrc);
+       enum InsetDecoration {
+               CLASSIC,
+               MINIMALISTIC,
+               CONGLOMERATE,
+               DEFAULT
+       };
+       ///
+       enum InsetLyXType {
+               NOLYXTYPE,
+               CHARSTYLE,
+               CUSTOM,
+               ELEMENT,
+               END,
+               STANDARD
+       };
+       ///
+       enum InsetLaTeXType {
+               NOLATEXTYPE,
+               COMMAND,
+               ENVIRONMENT,
+               ILT_ERROR
+       };
+       ///
+       bool read(Lexer & lexrc, TextClass const & tclass);
+       ///
+       docstring name() const { return name_; }
+       ///
+       void setName(docstring const & n) { name_ = n; }
+       ///
+       InsetLyXType lyxtype() const { return lyxtype_; }
+       ///
+       docstring labelstring() const { return labelstring_; }
+       ///
+       bool contentaslabel() const { return contentaslabel_; }
        ///
-       docstring name() const { return name_; };
+       InsetDecoration decoration() const { return decoration_; }
        ///
-       std::string lyxtype() const { return lyxtype_; };
+       InsetLaTeXType latextype() const { return latextype_; }
        ///
-       docstring labelstring() const { return labelstring_; };
+       std::string latexname() const { return latexname_; }
        ///
-       InsetDecoration decoration() const { return decoration_; };
+       std::string latexparam() const { return latexparam_; }
        ///
-       std::string latextype() const { return latextype_; };
+       FontInfo font() const { return font_; }
        ///
-       std::string latexname() const { return latexname_; };
+       FontInfo labelfont() const { return labelfont_; }
        ///
-       std::string latexparam() const { return latexparam_; };
+       ColorCode bgcolor() const { return bgcolor_; }
        ///
-       FontInfo font() const { return font_; };
+       docstring preamble() const { return preamble_; }
+       /// Get language dependent macro definitions needed for this inset
+       docstring const langpreamble() const { return langpreamble_; }
+       /// Get language and babel dependent macro definitions needed for
+       /// this inset
+       docstring const babelpreamble() const { return babelpreamble_; }
        ///
-       FontInfo labelfont() const { return labelfont_; };
+       docstring counter() const { return counter_; }
        ///
-       ColorCode bgcolor() const { return bgcolor_; };
+       docstring refprefix() const { return refprefix_; }
+       /// The tag enclosing all the material in this inset. Default is "span".
+       std::string const & htmltag() const;
+       /// Additional attributes for inclusion with the start tag. Default (if
+       /// a tag is provided) is: class="name".
+       std::string const & htmlattr() const;
+       /// Tag for individual paragraphs in the inset. Default is none.
+       std::string const & htmlinnertag() const { return htmlinnertag_; }
+       /// Attributes for that tag. Default (if a tag is provided) is: 
+       /// class="name_inner".
+       std::string const & htmlinnerattr() const;
+       /// A label for this environment, possibly including a reference
+       /// to a counter. E.g., for footnote, it might be:
+       ///    \arabic{footnote}
+       /// No default.
+       /// FIXME Could we get this from the layout?
+       std::string const & htmllabel() const { return htmllabel_; }
        ///
-       std::string preamble() const { return preamble_; };
+       inline std::string htmllabeltag() const { return "span"; }
        ///
-       std::set<std::string> requires() const { return requires_; };
+       std::string htmllabelattr() const 
+               { return "class=\"" + defaultCSSClass() + "_label\""; }
+       /// CSS associated with this inset.
+       docstring htmlstyle() const;
+       /// Additional material for the header.
+       docstring htmlpreamble() const { return htmlpreamble_; }
+       /// Whether this inset represents a "block" of material, i.e., a set
+       /// of paragraphs of its own (true), or should be run into the previous
+       /// paragraph (false). Examples:
+       ///   For branches, this is false.
+       ///   For footnotes, this is true.
+       /// Defaults to true.
+       bool htmlisblock() const { return htmlisblock_; }
        ///
-       bool isMultiPar() const { return multipar_; };
+       std::set<std::string> requires() const { return requires_; }
        ///
-       bool isPassThru() const { return passthru_; };
+       bool isMultiPar() const { return multipar_; }
        ///
-       bool isNeedProtect() const { return needprotect_; };
+       bool forcePlainLayout() const { return forceplain_; }
        ///
-       bool isFreeSpacing() const { return freespacing_; };
+       bool allowParagraphCustomization() const { return custompars_; }
        ///
-       bool isKeepEmpty() const { return keepempty_; };
+       bool isPassThru() const { return passthru_; }
        ///
-       bool isForceLtr() const { return forceltr_; };
+       bool parbreakIsNewline() const { return parbreakisnewline_; }
+       ///
+       bool isNeedProtect() const { return needprotect_; }
+       ///
+       bool isFreeSpacing() const { return freespacing_; }
+       ///
+       bool isKeepEmpty() const { return keepempty_; }
+       ///
+       bool forceLTR() const { return forceltr_; }
+       ///
+       bool isInToc() const { return intoc_; }
+       ///
+       bool spellcheck() const { return spellcheck_; }
+       ///
+       bool resetsFont() const { return resetsfont_; }
+       ///
+       bool isDisplay() const { return display_; }
 private:
        ///
-       docstring name_;
+       void makeDefaultCSS() const;
+       ///
+       std::string defaultCSSClass() const;
        ///
-       std::string lyxtype_;
+       std::string defaultCSSLabelClass() const { return defaultCSSClass() + "_label"; }
+       ///
+       docstring name_;
+       /**
+               * This is only used (at present) to decide where to put them on the menus.
+               * Values are 'charstyle', 'custom' (things that by default look like a
+               * footnote), 'element' (docbook), 'standard'.
+               */
+       InsetLyXType lyxtype_;
        ///
        docstring labelstring_;
        ///
+       bool contentaslabel_;
+       ///
        InsetDecoration decoration_;
        ///
-       std::string latextype_;
+       InsetLaTeXType latextype_;
        ///
        std::string latexname_;
        ///
@@ -98,23 +185,71 @@ private:
        ///
        ColorCode bgcolor_;
        ///
-       std::string preamble_;
+       docstring counter_;
+       ///
+       docstring preamble_;
+       /// Language dependent macro definitions needed for this inset
+       docstring langpreamble_;
+       /// Language and babel dependent macro definitions needed for this inset
+       docstring babelpreamble_;
+       ///
+       docstring refprefix_;
+       ///
+       mutable std::string htmltag_;
+       ///
+       mutable std::string htmlattr_;
+       ///
+       std::string htmlinnertag_;
+       ///
+       mutable std::string htmlinnerattr_;
+       ///
+       std::string htmllabel_;
+       ///
+       docstring htmlstyle_;
+       /// Cache for default CSS info for this inset.
+       mutable docstring htmldefaultstyle_;
+       /// Cache for default CSS class.
+       mutable std::string defaultcssclass_;
+       /// Whether to force generation of default CSS even if some is given.
+       /// False by default.
+       bool htmlforcecss_;
+       ///
+       docstring htmlpreamble_;
+       ///
+       bool htmlisblock_;
        ///
        std::set<std::string> requires_;
        ///
        bool multipar_;
+       /// 
+       bool custompars_;
+       ///
+       bool forceplain_;
        ///
        bool passthru_;
        ///
-       bool needprotect_;
+       bool parbreakisnewline_;
        ///
        bool freespacing_;
        ///
        bool keepempty_;
        ///
        bool forceltr_;
+       ///
+       bool needprotect_;
+       /// should the contents be written to TOC strings?
+       bool intoc_;
+       /// check spelling of this inset?
+       bool spellcheck_;
+       ///
+       bool resetsfont_;
+       ///
+       bool display_;
 };
 
+///
+InsetLayout::InsetLyXType translateLyXType(std::string const & str);
+
 } // namespace lyx
 
 #endif