// -*- C++ -*-
-/* This file is part of
- * ======================================================
-*
-* LyX, The Document Processor
-*
-* Copyright (C) 1995 Matthias Ettrich
-*
-*======================================================*/
-
-#ifndef _LAYOUT_H
-#define _LAYOUT_H
-
-#ifdef __GNUG__
-#pragma interface
-#endif
-
-#include "definitions.h"
-#include "lyxlex.h"
-#include "lyxfont.h"
-#include "Spacing.h"
-
-/// Reads the style files
-void LyXSetStyle();
+/**
+ * \file layout.h
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
+ *
+ * \author Lars Gullik Bjønnes
+ * \author Jean-Marc Lasgouttes
+ *
+ * Full author contact details are available in file CREDITS.
+ */
+
+#ifndef LAYOUT_H
+#define LAYOUT_H
+
+namespace lyx {
/// The different output types
enum OutputType {
- ///
- LATEX,
///
- LINUXDOC,
+ LATEX = 1,
///
DOCBOOK,
///
LITERATE
};
+
/// The different margin types
enum LYX_MARGIN_TYPE {
///
- MARGIN_MANUAL,
+ MARGIN_MANUAL = 1,
///
MARGIN_FIRST_DYNAMIC,
///
MARGIN_RIGHT_ADDRESS_BOX
};
+
///
-enum LYX_ALIGNMENT {
+enum LyXAlignment {
+ ///
+ LYX_ALIGN_NONE = 0,
///
LYX_ALIGN_BLOCK = 1,
///
///
LYX_ALIGN_LAYOUT = 16,
///
- LYX_ALIGN_SPECIAL = 32
+ LYX_ALIGN_SPECIAL = 32
};
+///
+inline
+void operator|=(LyXAlignment & la1, LyXAlignment la2) {
+ la1 = static_cast<LyXAlignment>(la1 | la2);
+}
+
+
/// The different LaTeX-Types
enum LYX_LATEX_TYPES {
///
- LATEX_PARAGRAPH,
+ LATEX_PARAGRAPH = 1,
///
LATEX_COMMAND,
///
///
LATEX_ITEM_ENVIRONMENT,
///
+ LATEX_BIB_ENVIRONMENT,
+ ///
LATEX_LIST_ENVIRONMENT
};
+
+/// The different title types
+enum LYX_TITLE_LATEX_TYPES {
+ ///
+ TITLE_COMMAND_AFTER = 1,
+ ///
+ TITLE_ENVIRONMENT
+};
+
+
/// The different label types
enum LYX_LABEL_TYPES {
///
///
LABEL_MANUAL,
///
- LABEL_BIBLIO,
+ LABEL_BIBLIO,
///
LABEL_TOP_ENVIRONMENT,
///
///
LABEL_SENSITIVE,
///
- LABEL_COUNTER_CHAPTER,
- ///
- LABEL_COUNTER_SECTION,
- ///
- LABEL_COUNTER_SUBSECTION,
- ///
- LABEL_COUNTER_SUBSUBSECTION,
- ///
- LABEL_COUNTER_PARAGRAPH,
- ///
- LABEL_COUNTER_SUBPARAGRAPH,
- ///
- LABEL_COUNTER_ENUMI,
- ///
- LABEL_COUNTER_ENUMII,
- ///
- LABEL_COUNTER_ENUMIII,
+ LABEL_COUNTER,
///
- LABEL_COUNTER_ENUMIV,
+ LABEL_ENUMERATE,
///
- LABEL_FIRST_COUNTER = LABEL_COUNTER_CHAPTER
+ LABEL_ITEMIZE
};
-/* Fix labels are printed flushright, manual labels flushleft.
-* MARGIN_MANUAL and MARGIN_FIRST_DYNAMIC are *only* for LABEL_MANUAL,
-* MARGIN_DYNAMIC and MARGIN_STATIC are *not* for LABEL_MANUAL.
-* This seems a funny restriction, but I think other combinations are
-* not needed, so I will not change it yet.
-* Correction: MARGIN_FIRST_DYNAMIC also usable with LABEL_STATIC */
-
-
-/* There is a parindent and a parskip. Which one is used depends on the
-* paragraph_separation-flag of the text-object.
-* BUT: parindent is only thrown away, if a parskip is defined! So if you
-* want a space between the paragraphs and a parindent at the same time,
-* you should set parskip to zero and use topsep, parsep and bottomsep.
-*
-* The standard layout is an exception: its parindent is only set, if the
-* previous paragraph is standard too. Well, this is LateX and it is good! */
-
-
-/// Attributes of a layout/paragraph environment
-class LyXLayoutList;
///
-class LyXLayout {
-public:
- ///
- LyXLayout ();
-
- ///
- ~LyXLayout ();
-
+enum LYX_END_LABEL_TYPES {
///
- void Copy (LyXLayout const &l);
-
- ///
- bool Read (LyXLex&, LyXLayoutList *);
-
- /// Name of the layout/paragraph environment
- string name;
-
- /// Name of an layout that has replaced this layout.
- /** This is used to rename a layout, while keeping backward
- compatibility
- */
- string obsoleted_by;
-
- /// Default font for this layout/environment
- /** The main font for this kind of environment. If an attribute has
- LyXFont::INHERITED_*, it means that the value is specified by
- the defaultfont for the entire layout. If we are nested, the font
- is inherited from the font in the environment one level up until the
- font is resolved. The values LyXFont::IGNORE_* and LyXFont::TOGGLE
- are illegal here.
- */
- LyXFont font;
-
- /// Default font for labels
- /** Interpretation the same as for font above */
- LyXFont labelfont;
-
- /// Resolved version of the font for this layout/environment
- /** This is a resolved version the default font. The font is resolved
- against the defaultfont of the entire layout. */
- LyXFont resfont;
-
- /// Resolved version of the font used for labels
- /** This is a resolved version the label font. The font is resolved
- against the defaultfont of the entire layout. */
- LyXFont reslabelfont;
-
- /// Text that dictates how wide the left margin is on the screen
- string leftmargin;
-
- /// Text that dictates how wide the right margin is on the screen
- string rightmargin;
-
- /// Text that dictates how much space to leave after a potential label
- string labelsep;
-
- /// Text that dictates how much space to leave before a potential label
- string labelindent;
-
- /// Text that dictates the width of the indentation of indented paragraphs
- string parindent;
-
- /// Label string. "Abstract", "Reference", "Caption"...
- string labelstring;
-
- /// Label string inside appendix. "Appendix", ...
- string labelstring_appendix;
-
- /// LaTeX name for environment
- string latexname;
-
- /// LaTeX parameter for environment
- string latexparam; //arrae970411
-
- /// Macro definitions needed for this layout
- string preamble;
-
+ END_LABEL_NO_LABEL,
///
- float parskip;
-
+ END_LABEL_BOX,
///
- float itemsep;
-
+ END_LABEL_FILLED_BOX,
///
- float topsep;
-
+ END_LABEL_STATIC,
///
- float bottomsep;
-
- ///
- float labelbottomsep;
-
+ END_LABEL_ENUM_FIRST = END_LABEL_NO_LABEL,
///
- float parsep;
-
- ///
- Spacing spacing;
-
- ///
- char align; // add approp. signedness
-
- ///
- char alignpossible; // add approp. signedness
-
- ///
- char labeltype; // add approp. signedness
-
- ///
- char margintype; // add approp. signedness
-
- ///
- bool fill_top;
-
- ///
- bool fill_bottom;
-
- ///
- bool newline_allowed;
-
- ///
- bool nextnoindent;
-
- ///
- bool free_spacing;
- /// true when the fragile commands in the paragraph need to be
- /// \protect'ed.
- bool needprotect;
- /// true when empty paragraphs should be kept.
- bool keepempty;
- ///
- bool isParagraph() const {
- return latextype == LATEX_PARAGRAPH;
- }
- ///
- bool isCommand() const {
- return latextype == LATEX_COMMAND;
- }
- ///
- bool isEnvironment() const {
- return (latextype == LATEX_ENVIRONMENT
- || latextype == LATEX_ITEM_ENVIRONMENT
- || latextype == LATEX_LIST_ENVIRONMENT);
- }
- /// Type of LaTeX object
- LYX_LATEX_TYPES latextype;
- /// Does this object belong in the title part of the document?
- bool intitle;
-};
-
-
-///
-class LyXLayoutList {
-public:
- ///
- LyXLayoutList();
- ///
- ~LyXLayoutList();
- ///
- void Add (LyXLayout *l);
- ///
- bool Delete (string const &name);
- ///
- LyXLayout *GetLayout (string const &name);
- ///
- LyXLayout *ToAr();
- ///
- int GetNum();
- ///
- void Clean();
-private:
- ///
- struct LyXLayoutL {
- ///
- LyXLayout* layout;
- ///
- LyXLayoutL *next;
- };
- ///
- LyXLayoutL * l;
- ///
- LyXLayoutL *eol;
- ///
- int num_layouts;
+ END_LABEL_ENUM_LAST = END_LABEL_STATIC
};
+/* Fix labels are printed flushright, manual labels flushleft.
+ * MARGIN_MANUAL and MARGIN_FIRST_DYNAMIC are *only* for LABEL_MANUAL,
+ * MARGIN_DYNAMIC and MARGIN_STATIC are *not* for LABEL_MANUAL.
+ * This seems a funny restriction, but I think other combinations are
+ * not needed, so I will not change it yet.
+ * Correction: MARGIN_FIRST_DYNAMIC also usable with LABEL_STATIC
+ */
-///
-class LyXTextClass {
-public:
- ///
- LyXTextClass (string const & = string(),
- string const & = string(),
- string const & = string());
- ///
- ~LyXTextClass();
-
- /// Not a real copy, just reference!
- void Copy (LyXTextClass const &l);
- /// Reads a textclass structure from file
- int Read (string const & filename, LyXLayoutList *list = 0);
+/* There is a parindent and a parskip. Which one is used depends on the
+ * paragraph_separation-flag of the text-object.
+ * BUT: parindent is only thrown away, if a parskip is defined! So if you
+ * want a space between the paragraphs and a parindent at the same time,
+ * you should set parskip to zero and use topsep, parsep and bottomsep.
+ *
+ * The standard layout is an exception: its parindent is only set, if the
+ * previous paragraph is standard too. Well, this is LateX and it is good!
+ */
- /// Sees to that the textclass structure has been loaded
- void load();
-
- ///
- string name;
- ///
- string latexname;
- ///
- string description;
- ///
- OutputType output_type;
-
- /// Specific class options
- string opt_fontsize;
- ///
- string opt_pagestyle;
- ///
- string options;
-
- /// Packages that are already loaded by the class
- bool provides_amsmath;
- ///
- bool provides_makeidx;
- ///
- bool provides_url;
-
- /// Base font. This one has to be fully instantiated.
- /** Base font. The paragraph and layout fonts are resolved against
- this font. Attributes LyXFont::INHERIT, LyXFont::IGNORE, and
- LyXFont::TOGGLE are extremely illegal.
- */
- LyXFont defaultfont;
- /// Array of styles in this textclass
- LyXLayout* style;
- ///
- unsigned char number_of_defined_layouts;
- ///
- unsigned char columns;
- ///
- unsigned char sides;
- ///
- signed char secnumdepth;
- ///
- signed char tocdepth;
- ///
- string pagestyle;
- ///
- string preamble;
- ///
- /// Text that dictates how wide the left margin is on the screen
- string leftmargin;
- ///
- /// Text that dictates how wide the right margin is on the screen
- string rightmargin;
- ///
- char maxcounter; // add approp. signedness
-private:
- /// Has this layout file been loaded yet?
- bool loaded;
-};
-
-
-///
-class LyXTextClassList {
-public:
- ///
- LyXTextClassList();
-
- ///
- ~LyXTextClassList();
-
- /// Gets layout structure from layout number and textclass number
- LyXLayout *Style(char textclass, char layout);
-
- /// Gets layout number from textclass number and layout name
- char NumberOfLayout(char textclass, string const & name); // add approp. signedness
-
- /// Gets a layout name from layout number and textclass number
- string NameOfLayout(char textclass, char layout); // add approp. signedness
-
- /// Gets textclass number from name
- /** Returns -1 if textclass name does not exist */
- signed char NumberOfClass(string const & textclass);
-
- ///
- string NameOfClass(char number); // add approp. signedness
-
- ///
- string LatexnameOfClass(char number); // add approp. signedness
-
- ///
- string DescOfClass(char number); // add approp. signedness
-
- ///
- LyXTextClass * TextClass(char textclass); // add approp. signedness
-
- /// Read textclass list
- /** Returns false if this fails */
- bool Read();
-
- /// Load textclass
- /** Returns false if this fails */
- bool Load(const char number);
-private:
- ///
- struct LyXTextClassL {
- ///
- LyXTextClass * textclass;
- ///
- LyXTextClassL * next;
- };
-
- ///
- LyXTextClassL * l;
-
- ///
- int num_textclass;
-
- /// After reading, this arrays holds the textclasses
- LyXTextClass * ar;
-
- /// Add a textclass to list
- void Add (LyXTextClass *l);
-
- /// Convert final linked list to array
- /** We read the textclasses into a linked list. After the reading,
- the list is converted to an array, and the linked list is nuked. */
- void ToAr();
-};
+} // namespace lyx
-/// Should not be declared here!! (Lgb) Why not? (Asger)
-extern LyXTextClassList lyxstyle;
-
#endif