]> git.lyx.org Git - lyx.git/blob - src/lyxtextclass.h
3de520654cf62452683e3c4a2815efb7e67c51e3
[lyx.git] / src / lyxtextclass.h
1 // -*- C++ -*-
2 /**
3  * \file lyxtextclass.h
4  * This file is part of LyX, the document processor.
5  * Licence details can be found in the file COPYING.
6  *
7  * Full author contact details are available in file CREDITS.
8  */
9
10 #ifndef LYXTEXTCLASS_H
11 #define LYXTEXTCLASS_H
12
13 #include "lyxlayout.h"
14 #include "lyxlayout_ptr_fwd.h"
15
16 #include <boost/shared_ptr.hpp>
17
18 #include "support/std_string.h"
19 #include <vector>
20
21 class LyXLex;
22 class Counters;
23 class FloatList;
24
25 /// Stores the layout specification of a LyX document class.
26 class LyXTextClass {
27 public:
28         /// The individual styles comprising the document class
29         typedef std::vector<LyXLayout_ptr> LayoutList;
30         /// Enumerate the paragraph styles.
31         typedef LayoutList::const_iterator const_iterator;
32         /// Construct a layout with default values. Actual values loaded later.
33         explicit
34         LyXTextClass(string const & = string(),
35                      string const & = string(),
36                      string const & = string(),
37                      bool = false);
38
39         /// check whether the TeX class is available
40         bool isTeXClassAvailable() const;
41
42         /// paragraph styles begin iterator.
43         const_iterator begin() const { return layoutlist_.begin(); }
44         /// paragraph styles end iterator
45         const_iterator end() const { return layoutlist_.end(); }
46
47         /// Performs the read of the layout file.
48         bool Read(string const & filename, bool merge = false);
49         ///
50         void readOutputType(LyXLex &);
51         ///
52         void readTitleType(LyXLex &);
53         ///
54         void readMaxCounter(LyXLex &);
55         ///
56         void readClassOptions(LyXLex &);
57         ///
58         void readFloat(LyXLex &);
59         ///
60         void readCounter(LyXLex &);
61         ///
62         bool hasLayout(string const & name) const;
63
64         ///
65         LyXLayout_ptr const & operator[](string const & vname) const;
66
67         /// Sees to that the textclass structure has been loaded
68         bool load() const;
69
70         /// the list of floats defined in the document class
71         FloatList & floats();
72         /// the list of floats defined in the document class
73         FloatList const & floats() const;
74         /// The Counters present in this document class.
75         Counters & counters() const;
76         ///
77         string const & defaultLayoutName() const;
78         ///
79         LyXLayout_ptr const & defaultLayout() const;
80         ///
81         string const & name() const;
82         ///
83         string const & latexname() const;
84         ///
85         string const & description() const;
86         ///
87         string const & opt_fontsize() const;
88         ///
89         string const & opt_pagestyle() const;
90         ///
91         string const & options() const;
92         ///
93         string const & pagestyle() const;
94         ///
95         string const & preamble() const;
96
97         /// Packages that are already loaded by the class
98         enum Provides {
99                 ///
100                 nothing = 0,
101                 ///
102                 amsmath = 1,
103                 ///
104                 makeidx = 2,
105                 ///
106                 url = 4,
107                 ///
108                 natbib = 8
109         };
110         ///
111         bool provides(Provides p) const;
112
113         ///
114         unsigned int columns() const;
115         ///
116         enum PageSides {
117                 ///
118                 OneSide,
119                 ///
120                 TwoSides
121         };
122         ///
123         PageSides sides() const;
124         ///
125         int secnumdepth() const;
126         ///
127         int tocdepth() const;
128
129         /// Can be LaTeX, LinuxDoc, etc.
130         OutputType outputType() const;
131
132         ///
133         LyXFont const & defaultfont() const;
134
135         /// Text that dictates how wide the left margin is on the screen
136         string const & leftmargin() const;
137
138         /// Text that dictates how wide the right margin is on the screen
139         string const & rightmargin() const;
140         ///
141         int maxcounter() const;
142
143         /// The type of command used to produce a title
144         LYX_TITLE_LATEX_TYPES titletype() const;
145         /// The name of the title command
146         string const & titlename() const;
147
148         ///
149         int size() const;
150 private:
151         ///
152         bool delete_layout(string const &);
153         ///
154         bool do_readStyle(LyXLex &, LyXLayout &);
155         /// Layout file name
156         string name_;
157         /// document class name
158         string latexname_;
159         /// document class description
160         string description_;
161         /// Specific class options
162         string opt_fontsize_;
163         ///
164         string opt_pagestyle_;
165         ///
166         string options_;
167         ///
168         string pagestyle_;
169         ///
170         string defaultlayout_;
171         /// preamble text to support layout styles
172         string preamble_;
173         /// latex packages loaded by document class.
174         Provides provides_;
175         ///
176         unsigned int columns_;
177         ///
178         PageSides sides_;
179         /// header depth to have numbering
180         int secnumdepth_;
181         /// header depth to appear in table of contents
182         int tocdepth_;
183         /// Can be LaTeX, LinuxDoc, etc.
184         OutputType outputType_;
185         /** Base font. The paragraph and layout fonts are resolved against
186             this font. This has to be fully instantiated. Attributes
187             LyXFont::INHERIT, LyXFont::IGNORE, and LyXFont::TOGGLE are
188             extremely illegal.
189         */
190         LyXFont defaultfont_;
191         /// Text that dictates how wide the left margin is on the screen
192         string leftmargin_;
193
194         /// Text that dictates how wide the right margin is on the screen
195         string rightmargin_;
196         /// highest header level used in this layout.
197         int maxcounter_; // add approp. signedness
198
199         /// The type of command used to produce a title
200         LYX_TITLE_LATEX_TYPES titletype_;
201         /// The name of the title command
202         string titlename_;
203
204         /// Paragraph styles used in this layout
205         LayoutList layoutlist_;
206
207         /// available types of float, eg. figure, algorithm.
208         boost::shared_ptr<FloatList> floatlist_;
209
210         /// Types of counters, eg. sections, eqns, figures, avail. in document class.
211         boost::shared_ptr<Counters> ctrs_;
212
213         /// Has this layout file been loaded yet?
214         mutable bool loaded;
215
216         /// Is the TeX class available?
217         bool texClassAvail_;
218 };
219
220
221 /// Merge two different provides flags into one bit field record
222 inline
223 void operator|=(LyXTextClass::Provides & p1, LyXTextClass::Provides p2)
224 {
225         p1 = static_cast<LyXTextClass::Provides>(p1 | p2);
226 }
227
228
229 /// convert page sides option to text 1 or 2
230 std::ostream & operator<<(std::ostream & os, LyXTextClass::PageSides p);
231
232 #endif