lyx_mirror/src/insets/InsetLayout.h

455 lines
12 KiB
C
Raw Normal View History

// -*- C++ -*-
/**
* \file InsetLayout.h
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Martin Vermeer
2020-12-05 22:17:02 +00:00
* \author Richard Kimberly Heck
*
* Full author contact details are available in file CREDITS.
*/
#ifndef INSET_LAYOUT_H
#define INSET_LAYOUT_H
#include "ColorCode.h"
#include "FontInfo.h"
#include "Layout.h"
#include "support/docstring.h"
#include <set>
#include <string>
namespace lyx {
class Lexer;
class TextClass;
2020-12-02 20:34:28 +00:00
enum class InsetDecoration : int {
CLASSIC,
MINIMALISTIC,
CONGLOMERATE,
DEFAULT
};
enum class InsetLyXType : int {
NOLYXTYPE,
CHARSTYLE,
CUSTOM,
END,
STANDARD
};
enum class InsetLaTeXType : int {
NOLATEXTYPE,
COMMAND,
ENVIRONMENT,
ILT_ERROR
};
///
class InsetLayout {
public:
///
InsetLayout() { labelfont_.setColor(Color_insetlabel); }
///
bool read(Lexer & lexrc, TextClass const & tclass,
bool validating = false);
///
docstring name() const { return name_; }
///
void setName(docstring const & n) { name_ = n; }
///
InsetLyXType lyxtype() const { return lyxtype_; }
///
docstring labelstring() const { return labelstring_; }
///
docstring menustring() const { return menustring_; }
///
bool contentaslabel() const { return contentaslabel_; }
///
InsetDecoration decoration() const { return decoration_; }
///
InsetLaTeXType latextype() const { return latextype_; }
///
std::string latexname() const { return latexname_; }
///
std::string latexparam() const { return latexparam_; }
///
docstring leftdelim() const { return leftdelim_; }
///
docstring rightdelim() const { return rightdelim_; }
///
bool inheritFont() const { return inheritfont_; }
///
FontInfo font() const { return font_; }
///
FontInfo labelfont() const { return labelfont_; }
///
ColorCode bgcolor() const { return bgcolor_; }
2017-07-03 17:45:58 +00:00
///
Layout::LaTeXArgMap const & latexargs() const { return latexargs_; }
///
Layout::LaTeXArgMap const & postcommandargs() const { return postcommandargs_; }
/// Returns latexargs() + postcommandargs().
2017-07-03 17:45:58 +00:00
/// But note that it returns a *copy*, not a reference, so do not do
/// anything like:
2014-04-07 14:57:22 +00:00
/// Layout::LaTeXArgMap::iterator it = args().begin();
/// Layout::LaTeXArgMap::iterator en = args().end();
/// Those are iterators for different containers.
Layout::LaTeXArgMap args() const;
///
2020-10-13 21:24:36 +00:00
int optArgs() const;
///
2020-10-13 21:24:36 +00:00
int requiredArgs() const;
///
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_; }
///
bool fixedwidthpreambleencoding() const { return fixedwidthpreambleencoding_; }
///
docstring counter() const { return counter_; }
///
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 { return htmlattr_; }
///
std::string const & htmlclass() const;
///
std::string const & htmlGetAttrString() const;
/// Tag for individual paragraphs in the inset. Default is none.
std::string const & htmlinnertag() const { return htmlinnertag_; }
2017-07-03 17:45:58 +00:00
/// 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_; }
///
inline std::string htmllabeltag() const { return "span"; }
///
2017-07-03 17:45:58 +00:00
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_; }
///
std::string docbooktag() const { return docbooktag_; }
///
std::string docbooktagtype() const;
///
std::string docbookattr() const { return docbookattr_; }
///
std::string docbookinnertag() const { return docbookinnertag_; }
///
std::string docbookinnertagtype() const;
///
std::string docbookinnerattr() const { return docbookinnerattr_; }
///
std::string const & docbookininfo() const;
///
bool docbooksection() const { return docbooksection_; }
///
bool docbooknotinpara() const { return docbooknotinpara_; }
///
bool docbookargumentbeforemaintag() const { return docbookargumentbeforemaintag_; }
///
bool docbookargumentaftermaintag() const { return docbookargumentaftermaintag_; }
///
std::string docbookwrappertag() const { return docbookwrappertag_; }
///
std::string docbookwrappertagtype() const;
///
std::string docbookwrapperattr() const { return docbookwrapperattr_; }
///
std::string docbookitemwrappertag() const { return docbookitemwrappertag_; }
///
std::string docbookitemwrappertagtype() const;
///
std::string docbookitemwrapperattr() const { return docbookitemwrapperattr_; }
///
std::string docbookitemtag() const { return docbookitemtag_; }
///
std::string docbookitemtagtype() const;
///
std::string docbookitemattr() const { return docbookitemattr_; }
///
bool docbooknofontinside() const { return docbooknofontinside_; }
///
bool docbookrenderasimage() const { return docbookrenderasimage_; }
///
std::set<std::string> required() const { return required_; }
///
bool isMultiPar() const { return multipar_; }
///
bool forcePlainLayout() const { return forceplain_; }
///
bool allowParagraphCustomization() const { return custompars_; }
///
bool isPassThru() const { return passthru_; }
///
2015-04-20 16:13:49 +00:00
docstring passThruChars() const { return passthru_chars_; }
///
std::string newlineCmd() const { return newline_cmd_; }
///
bool parbreakIsNewline() const { return parbreakisnewline_; }
///
bool parbreakIgnored() const { return parbreakignored_; }
///
bool isNeedProtect() const { return needprotect_; }
///
bool needsCProtect() const { return needcprotect_; }
/// Protection of some elements such as \ref and \cite
/// in \mbox (needed by commands building on soul or ulem)
bool isNeedMBoxProtect() const { return needmboxprotect_; }
///
bool isFreeSpacing() const { return freespacing_; }
///
bool isKeepEmpty() const { return keepempty_; }
///
bool forceLTR() const { return forceltr_; }
///
bool forceOwnlines() const { return forceownlines_; }
///
bool isInToc() const { return intoc_; }
///
bool spellcheck() const { return spellcheck_; }
///
bool resetsFont() const { return resetsfont_; }
Introduce a wrapper class for odocstream to help ensuring that no blank lines may be inadvertently output. This is achieved by using two special iomanip-like variables (breakln and safebreakln) in the lyx:: namespace. When they are inserted in the stream, a newline is output only if not already at the beginning of a line. The difference between breakln and safebreakln is that, if needed, the former outputs '\n' and the latter "%\n". In future, the new class will also be used for counting the number of newlines issued. Even if the infractrure for doing that is already in place, the counting is essentially still done the old way. There are still places in the code where the functionality of the class could be used, most probably. ATM, it is used for InsetTabular, InsetListings, InsetFloat, and InsetText. The Comment and GreyedOut insets required a special treatment and a new InsetLayout parameter (Display) has been introduced. The default for Display is "true", meaning that the corresponding latex environment is of "display" type, i.e., it stands on its own, whereas "false" means that the contents appear inline with the text. The latter is the case for both Comment and GreyedOut insets. Mostly, the only visible effects on latex exports should be the disappearing of some redundant % chars and the appearing/disappearing of null {} latex groups after a comment or lyxgreyedout environments (they are related to the presence or absence of a space immediately after those environments), as well as the fact that math environments are now started on their own lines. As a last thing, only the latex code between \begin{document} and \end{document} goes through the new class, the preamble being directly output through odocstream, as usual. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@37360 a592a061-630c-0410-9148-cb99ea01b6c8
2011-01-29 02:41:13 +00:00
///
bool isDisplay() const { return display_; }
///
bool forceLocalFontSwitch() const { return forcelocalfontswitch_; }
///
docstring const & obsoleted_by() const { return obsoleted_by_; }
///
bool addToToc() const { return add_to_toc_; }
///
std::string tocType() const { return toc_type_; }
///
bool isTocCaption() const { return is_toc_caption_; }
///
bool editExternally () const { return edit_external_; }
///
std::set<docstring> const & allowedInInsets() const { return allowed_in_insets_; }
///
std::set<docstring> const & allowedInLayouts() const { return allowed_in_layouts_; }
private:
///
void makeDefaultCSS() const;
///
std::string defaultCSSClass() const;
///
void readArgument(Lexer &);
///
docstring name_ = from_ascii("undefined");
/**
* 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), 'standard'.
*/
2020-12-02 20:34:28 +00:00
InsetLyXType lyxtype_ = InsetLyXType::STANDARD;
///
docstring labelstring_ = from_ascii("UNDEFINED");
///
docstring menustring_;
///
bool contentaslabel_ = false;
///
2020-12-02 20:34:28 +00:00
InsetDecoration decoration_ = InsetDecoration::DEFAULT;
///
2020-12-02 20:34:28 +00:00
InsetLaTeXType latextype_ = InsetLaTeXType::NOLATEXTYPE;
///
std::string latexname_;
///
std::string latexparam_;
///
docstring leftdelim_;
///
docstring rightdelim_;
///
FontInfo font_ = inherit_font;
///
FontInfo labelfont_ = sane_font;
///
bool inheritfont_ = true;
///
ColorCode bgcolor_ = Color_error;
///
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_;
///
bool fixedwidthpreambleencoding_ = false;
///
docstring refprefix_;
///
mutable std::string htmltag_;
///
mutable std::string htmlattr_;
///
mutable std::string htmlclass_;
/// cache
mutable std::string htmlfullattrs_;
///
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_ = false;
///
docstring htmlpreamble_;
///
bool htmlisblock_ = true;
///
std::string docbooktag_;
///
mutable std::string docbooktagtype_;
///
std::string docbookattr_;
///
std::string docbookinnertag_;
///
mutable std::string docbookinnertagtype_;
///
std::string docbookinnerattr_;
///
mutable std::string docbookininfo_;
///
bool docbooknotinpara_ = false;
///
bool docbookargumentbeforemaintag_ = false;
2023-04-02 10:31:41 +00:00
///
bool docbookargumentaftermaintag_ = false;
///
bool docbooksection_ = false;
///
std::string docbookwrappertag_;
///
mutable std::string docbookwrappertagtype_;
///
std::string docbookwrapperattr_;
///
std::string docbookitemtag_;
///
mutable std::string docbookitemtagtype_;
///
std::string docbookitemattr_;
///
std::string docbookitemwrappertag_;
///
mutable std::string docbookitemwrappertagtype_;
///
std::string docbookitemwrapperattr_;
///
bool docbooknofontinside_ = false;
///
bool docbookrenderasimage_ = false;
///
std::set<std::string> required_;
///
bool multipar_ = true;
2017-07-03 17:45:58 +00:00
///
bool custompars_ = true;
///
bool forceplain_ = false;
///
bool passthru_ = false;
///
2015-04-20 16:13:49 +00:00
docstring passthru_chars_;
///
std::string newline_cmd_;
///
bool parbreakisnewline_ = false;
///
bool parbreakignored_ = false;
///
bool freespacing_ = false;
///
bool keepempty_ = false;
///
bool forceltr_ = false;
///
bool forceownlines_ = false;
///
bool needprotect_ = false;
///
bool needcprotect_ = false;
///
bool needmboxprotect_ = false;
/// should the contents be written to TOC strings?
bool intoc_ = false;
/// check spelling of this inset?
bool spellcheck_ = true;
///
bool resetsfont_ = false;
Introduce a wrapper class for odocstream to help ensuring that no blank lines may be inadvertently output. This is achieved by using two special iomanip-like variables (breakln and safebreakln) in the lyx:: namespace. When they are inserted in the stream, a newline is output only if not already at the beginning of a line. The difference between breakln and safebreakln is that, if needed, the former outputs '\n' and the latter "%\n". In future, the new class will also be used for counting the number of newlines issued. Even if the infractrure for doing that is already in place, the counting is essentially still done the old way. There are still places in the code where the functionality of the class could be used, most probably. ATM, it is used for InsetTabular, InsetListings, InsetFloat, and InsetText. The Comment and GreyedOut insets required a special treatment and a new InsetLayout parameter (Display) has been introduced. The default for Display is "true", meaning that the corresponding latex environment is of "display" type, i.e., it stands on its own, whereas "false" means that the contents appear inline with the text. The latter is the case for both Comment and GreyedOut insets. Mostly, the only visible effects on latex exports should be the disappearing of some redundant % chars and the appearing/disappearing of null {} latex groups after a comment or lyxgreyedout environments (they are related to the presence or absence of a space immediately after those environments), as well as the fact that math environments are now started on their own lines. As a last thing, only the latex code between \begin{document} and \end{document} goes through the new class, the preamble being directly output through odocstream, as usual. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@37360 a592a061-630c-0410-9148-cb99ea01b6c8
2011-01-29 02:41:13 +00:00
///
bool display_ = true;
///
bool forcelocalfontswitch_ = false;
/** Name of an insetlayout that has replaced this insetlayout.
This is used to rename an insetlayout, while keeping backward
compatibility
*/
docstring obsoleted_by_;
///
Layout::LaTeXArgMap latexargs_;
///
Layout::LaTeXArgMap postcommandargs_;
///
bool add_to_toc_ = false;
///
std::string toc_type_;
///
bool is_toc_caption_ = false;
///
bool edit_external_ = false;
/// Insets that can hold insets with this InsetLayout
std::set<docstring> allowed_in_insets_;
/// Layouts that can hold insets with this InsetLayout
std::set<docstring> allowed_in_layouts_;
};
///
2020-12-02 20:34:28 +00:00
InsetLyXType translateLyXType(std::string const & str);
InsetDecoration translateDecoration(std::string const & str);
} // namespace lyx
#endif