]> git.lyx.org Git - lyx.git/blobdiff - src/bufferparams.C
more cursor dispatch
[lyx.git] / src / bufferparams.C
index d2b1ab5846a1b6c5f2f271aa2721b87cef4da3a5..0f119fe5731b17ae4706c195b7e08afb92146062 100644 (file)
 #include <config.h>
 
 #include "bufferparams.h"
+
+#include "author.h"
+#include "BranchList.h"
+#include "Bullet.h"
 #include "debug.h"
 #include "encoding.h"
 #include "gettext.h"
 #include "language.h"
 #include "LaTeXFeatures.h"
-#include "support/std_sstream.h"
+#include "LColor.h"
 #include "lyxlex.h"
+#include "lyxrc.h"
 #include "lyxtextclasslist.h"
+#include "outputparams.h"
 #include "tex-strings.h"
+#include "Spacing.h"
 #include "texrow.h"
+#include "vspace.h"
 
 #include "frontends/Alert.h"
 
 #include "support/lyxalgo.h" // for lyx::count
 
+#include <boost/array.hpp>
 
-using namespace lyx::support;
+#include "support/std_sstream.h"
+
+namespace support = lyx::support;
+using lyx::support::bformat;
+using lyx::support::rtrim;
+using lyx::support::tokenPos;
 
-using std::ostream;
 using std::endl;
+using std::string;
+using std::istringstream;
+using std::ostream;
+using std::ostringstream;
 using std::pair;
 
 
+struct BufferParams::Impl
+{
+       Impl();
+
+       AuthorList authorlist;
+       BranchList branchlist;
+       boost::array<Bullet, 4> temp_bullets;
+       boost::array<Bullet, 4> user_defined_bullets;
+       Spacing spacing;
+       /** This is the amount of space used for paragraph_separation "skip",
+        * and for detached paragraphs in "indented" documents.
+        */
+       VSpace defskip;
+};
+
+
+BufferParams::Impl::Impl()
+       : defskip(VSpace::MEDSKIP)
+{
+       // set initial author
+       authorlist.record(Author(lyxrc.user_name, lyxrc.user_email));
+}
+
+
+BufferParams::Impl *
+BufferParams::MemoryTraits::clone(BufferParams::Impl const * ptr)
+{
+       return new BufferParams::Impl(*ptr);
+}
+
+
+void BufferParams::MemoryTraits::destroy(BufferParams::Impl * ptr)
+{
+       delete ptr;
+}
+
+
 BufferParams::BufferParams()
-       // Initialize textclass to point to article. if `first' is
-       // true in the returned pair, then `second' is the textclass
-       // number; if it is false, second is 0. In both cases, second
-       // is what we want.
-       : textclass(textclasslist.NumberOfClass("article").second)
+       : // Initialize textclass to point to article. if `first' is
+         // true in the returned pair, then `second' is the textclass
+         // number; if it is false, second is 0. In both cases, second
+         // is what we want.
+       textclass(textclasslist.NumberOfClass("article").second),
+       pimpl_(new Impl)
 {
        paragraph_separation = PARSEP_INDENT;
-       defskip = VSpace(VSpace::MEDSKIP);
        quotes_language = InsetQuotes::EnglishQ;
        quotes_times = InsetQuotes::DoubleQ;
        fontsize = "default";
@@ -73,12 +127,92 @@ BufferParams::BufferParams()
        pagestyle = "default";
        compressed = false;
        for (int iter = 0; iter < 4; ++iter) {
-               user_defined_bullets[iter] = ITEMIZE_DEFAULTS[iter];
-               temp_bullets[iter] = ITEMIZE_DEFAULTS[iter];
+               user_defined_bullet(iter) = ITEMIZE_DEFAULTS[iter];
+               temp_bullet(iter) = ITEMIZE_DEFAULTS[iter];
        }
 }
 
 
+BufferParams::~BufferParams()
+{}
+
+
+AuthorList & BufferParams::authors()
+{
+       return pimpl_->authorlist;
+}
+
+
+AuthorList const & BufferParams::authors() const
+{
+       return pimpl_->authorlist;
+}
+
+
+BranchList & BufferParams::branchlist()
+{
+       return pimpl_->branchlist;
+}
+
+
+BranchList const & BufferParams::branchlist() const
+{
+       return pimpl_->branchlist;
+}
+
+
+Bullet & BufferParams::temp_bullet(lyx::size_type index)
+{
+       BOOST_ASSERT(index < 4);
+       return pimpl_->temp_bullets[index];
+}
+
+
+Bullet const & BufferParams::temp_bullet(lyx::size_type index) const
+{
+       BOOST_ASSERT(index < 4);
+       return pimpl_->temp_bullets[index];
+}
+
+
+Bullet & BufferParams::user_defined_bullet(lyx::size_type index)
+{
+       BOOST_ASSERT(index < 4);
+       return pimpl_->user_defined_bullets[index];
+}
+
+
+Bullet const & BufferParams::user_defined_bullet(lyx::size_type index) const
+{
+       BOOST_ASSERT(index < 4);
+       return pimpl_->user_defined_bullets[index];
+}
+
+
+Spacing & BufferParams::spacing()
+{
+       return pimpl_->spacing;
+}
+
+
+Spacing const & BufferParams::spacing() const
+{
+       return pimpl_->spacing;
+}
+
+
+VSpace const & BufferParams::getDefSkip() const
+{
+       return pimpl_->defskip;
+}
+
+
+void BufferParams::setDefSkip(VSpace const & vs)
+{
+       pimpl_->defskip = vs;
+}
+
+
 string const BufferParams::readToken(LyXLex & lex, string const & token)
 {
        if (token == "\\textclass") {
@@ -121,7 +255,7 @@ string const BufferParams::readToken(LyXLex & lex, string const & token)
                        static_cast<PARSEP>(tmpret);
        } else if (token == "\\defskip") {
                lex.nextToken();
-               defskip = VSpace(lex.getString());
+               pimpl_->defskip = VSpace(lex.getString());
        } else if (token == "\\quotes_language") {
                // FIXME: should be params.readQuotes()
                int tmpret = lex.findToken(string_quotes_language);
@@ -193,34 +327,36 @@ string const BufferParams::readToken(LyXLex & lex, string const & token)
        } else if (token == "\\branch") {
                lex.nextToken();
                string branch = lex.getString();
-               branchlist.add(branch);
+               branchlist().add(branch);
                while (true) {
                        lex.nextToken();
                        string const tok = lex.getString();
                        if (tok == "\\end_branch")
                                break;
+                       Branch * branch_ptr = branchlist().find(branch);
                        if (tok == "\\selected") {
                                lex.nextToken();
-                               branchlist.setSelected(branch, lex.getInteger());
+                               if (branch_ptr)
+                                       branch_ptr->setSelected(lex.getInteger());
                        }
                        // not yet operational
                        if (tok == "\\color") {
                                lex.nextToken();
                                string color = lex.getString();
-                               branchlist.setColor(branch, color);
+                               if (branch_ptr)
+                                       branch_ptr->setColor(color);
                                // Update also the LColor table:
-                               if (color == "none") 
+                               if (color == "none")
                                        color = lcolor.getX11Name(LColor::background);
-                               lcolor.fill(static_cast<LColor::color>(lcolor.size()), 
-                                               branch, color);
+                               lcolor.setColor(lcolor.getFromLyXName(branch), color);
                        }
                }
        } else if (token == "\\author") {
                lex.nextToken();
-               istringstream ss(STRCONV(lex.getString()));
+               istringstream ss(lex.getString());
                Author a;
                ss >> a;
-               author_map.push_back(authorlist.record(a));
+               author_map.push_back(pimpl_->authorlist.record(a));
        } else if (token == "\\paperorientation") {
                int tmpret = lex.findToken(string_orientation);
                if (tmpret == -1)
@@ -276,16 +412,16 @@ string const BufferParams::readToken(LyXLex & lex, string const & token)
                int const index = lex.getInteger();
                lex.nextToken();
                int temp_int = lex.getInteger();
-               user_defined_bullets[index].setFont(temp_int);
-               temp_bullets[index].setFont(temp_int);
+               user_defined_bullet(index).setFont(temp_int);
+               temp_bullet(index).setFont(temp_int);
                lex.nextToken();
                temp_int = lex.getInteger();
-               user_defined_bullets[index].setCharacter(temp_int);
-               temp_bullets[index].setCharacter(temp_int);
+               user_defined_bullet(index).setCharacter(temp_int);
+               temp_bullet(index).setCharacter(temp_int);
                lex.nextToken();
                temp_int = lex.getInteger();
-               user_defined_bullets[index].setSize(temp_int);
-               temp_bullets[index].setSize(temp_int);
+               user_defined_bullet(index).setSize(temp_int);
+               temp_bullet(index).setSize(temp_int);
                lex.nextToken();
                string const temp_str = lex.getString();
                if (temp_str != "\\end_bullet") {
@@ -315,8 +451,8 @@ string const BufferParams::readToken(LyXLex & lex, string const & token)
                        temp_str = lex.getString();
                }
 
-               user_defined_bullets[index].setText(sum_str);
-               temp_bullets[index].setText(sum_str);
+               user_defined_bullet(index).setText(sum_str);
+               temp_bullet(index).setText(sum_str);
        } else if (token == "\\secnumdepth") {
                lex.nextToken();
                secnumdepth = lex.getInteger();
@@ -347,7 +483,7 @@ string const BufferParams::readToken(LyXLex & lex, string const & token)
                if (first_par)
                        par->params().spacing(Spacing(tmp_space, tmp_val));
 #endif
-               spacing.set(tmp_space, tmp_val);
+               spacing().set(tmp_space, tmp_val);
        } else if (token == "\\float_placement") {
                lex.nextToken();
                float_placement = lex.getString();
@@ -393,7 +529,7 @@ void BufferParams::writeFile(ostream & os) const
        }
        os << "\\paperfontsize " << fontsize << '\n';
 
-       spacing.writeFile(os);
+       spacing().writeFile(os);
 
        os << "\\papersize " << string_papersize[papersize2]
           << "\n\\paperpackage " << string_paperpackages[paperpackage]
@@ -404,13 +540,13 @@ void BufferParams::writeFile(ostream & os) const
           << "\n\\paperorientation " << string_orientation[orientation]
           << '\n';
 
-       std::list<Branch>::const_iterator it = branchlist.begin();
-       std::list<Branch>::const_iterator end = branchlist.end();
+       std::list<Branch>::const_iterator it = branchlist().begin();
+       std::list<Branch>::const_iterator end = branchlist().end();
        for (; it != end; ++it) {
                os << "\\branch " << it->getBranch()
-                  << "\n\\selected " << it->getSelected()      
-                  << "\n\\color " << it->getColor()    
-                  << "\n\\end_branch" 
+                  << "\n\\selected " << it->getSelected()
+                  << "\n\\color " << it->getColor()
+                  << "\n\\end_branch"
                   << "\n";
        }
 
@@ -445,7 +581,7 @@ void BufferParams::writeFile(ostream & os) const
           << "\n\\tocdepth " << tocdepth
           << "\n\\paragraph_separation "
           << string_paragraph_separation[paragraph_separation]
-          << "\n\\defskip " << defskip.asLyXCommand()
+          << "\n\\defskip " << getDefSkip().asLyXCommand()
           << "\n\\quotes_language "
           << string_quotes_language[quotes_language] << '\n';
        switch (quotes_times) {
@@ -459,21 +595,21 @@ void BufferParams::writeFile(ostream & os) const
           << "\n\\papersides " << sides
           << "\n\\paperpagestyle " << pagestyle << '\n';
        for (int i = 0; i < 4; ++i) {
-               if (user_defined_bullets[i] != ITEMIZE_DEFAULTS[i]) {
-                       if (user_defined_bullets[i].getFont() != -1) {
+               if (user_defined_bullet(i) != ITEMIZE_DEFAULTS[i]) {
+                       if (user_defined_bullet(i).getFont() != -1) {
                                os << "\\bullet " << i
                                   << "\n\t"
-                                  << user_defined_bullets[i].getFont()
+                                  << user_defined_bullet(i).getFont()
                                   << "\n\t"
-                                  << user_defined_bullets[i].getCharacter()
+                                  << user_defined_bullet(i).getCharacter()
                                   << "\n\t"
-                                  << user_defined_bullets[i].getSize()
+                                  << user_defined_bullet(i).getSize()
                                   << "\n\\end_bullet\n";
                        }
                        else {
                                os << "\\bulletLaTeX " << i
                                   << "\n\t\""
-                                  << user_defined_bullets[i].getText()
+                                  << user_defined_bullet(i).getText()
                                   << "\"\n\\end_bullet\n";
                        }
                }
@@ -482,8 +618,8 @@ void BufferParams::writeFile(ostream & os) const
        os << "\\tracking_changes " << tracking_changes << "\n";
 
        if (tracking_changes) {
-               AuthorList::Authors::const_iterator it = authorlist.begin();
-               AuthorList::Authors::const_iterator end = authorlist.end();
+               AuthorList::Authors::const_iterator it = pimpl_->authorlist.begin();
+               AuthorList::Authors::const_iterator end = pimpl_->authorlist.end();
                for (; it != end; ++it) {
                        os << "\\author " << it->second << "\n";
                }
@@ -580,7 +716,7 @@ bool BufferParams::writeLaTeX(ostream & os, LaTeXFeatures & features,
                clsoptions << options << ',';
        }
 
-       string strOptions(STRCONV(clsoptions.str()));
+       string strOptions(clsoptions.str());
        if (!strOptions.empty()) {
                strOptions = rtrim(strOptions, ",");
                os << '[' << strOptions << ']';
@@ -758,7 +894,7 @@ bool BufferParams::writeLaTeX(ostream & os, LaTeXFeatures & features,
        }
 
        if (paragraph_separation) {
-               switch (defskip.kind()) {
+               switch (getDefSkip().kind()) {
                case VSpace::SMALLSKIP:
                        os << "\\setlength\\parskip{\\smallskipamount}\n";
                        break;
@@ -770,7 +906,7 @@ bool BufferParams::writeLaTeX(ostream & os, LaTeXFeatures & features,
                        break;
                case VSpace::LENGTH:
                        os << "\\setlength\\parskip{"
-                          << defskip.length().asLatexString()
+                          << getDefSkip().length().asLatexString()
                           << "}\n";
                        break;
                default: // should never happen // Then delete it.
@@ -823,7 +959,7 @@ bool BufferParams::writeLaTeX(ostream & os, LaTeXFeatures & features,
        // at \begin{document} time -- JMarc
        string bullets_def;
        for (int i = 0; i < 4; ++i) {
-               if (user_defined_bullets[i] != ITEMIZE_DEFAULTS[i]) {
+               if (user_defined_bullet(i) != ITEMIZE_DEFAULTS[i]) {
                        if (bullets_def.empty())
                                bullets_def="\\AtBeginDocument{\n";
                        bullets_def += "  \\renewcommand{\\labelitemi";
@@ -842,7 +978,7 @@ bool BufferParams::writeLaTeX(ostream & os, LaTeXFeatures & features,
                                break;
                        }
                        bullets_def += "}{" +
-                               user_defined_bullets[i].getText()
+                               user_defined_bullet(i).getText()
                                + "}\n";
                }
        }
@@ -857,7 +993,7 @@ bool BufferParams::writeLaTeX(ostream & os, LaTeXFeatures & features,
                if (!lyxrc.language_global_options
                    && tmp == "\\usepackage{babel}")
                        tmp = string("\\usepackage[") +
-                               STRCONV(language_options.str()) +
+                               language_options.str() +
                                "]{babel}";
                lyxpreamble += tmp + "\n";
                lyxpreamble += features.getBabelOptions();