]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/qt2/QDocument.C
Get rid of the static_casts.
[lyx.git] / src / frontends / qt2 / QDocument.C
index 6b261c589f28b525325679391b9f06c58e026f95..13dec25629563e26985df0465fb40acabcee6702 100644 (file)
@@ -10,7 +10,6 @@
 
 #include <config.h>
 
-
 #include "qt_helpers.h"
 
 #include "ControlDocument.h"
 #include "frnt_lang.h"
 #include "lyxrc.h" // defaultUnit
 #include "tex-strings.h" // tex_graphics
-#include "support/lstrings.h" // tostr()
+#include "support/tostr.h"
 #include "support/filetools.h" // LibFileSearch()
+#include "support/BoostFormat.h"
 #include "lyxtextclasslist.h"
 #include "vspace.h"
 #include "bufferparams.h"
 #include "qt_helpers.h"
+#include "floatplacement.h"
 
 #include <qpushbutton.h>
 #include <qmultilineedit.h>
 #include <qradiobutton.h>
 #include <qcombobox.h>
 #include <qcheckbox.h>
-#include <qspinbox.h>
+#include <qslider.h>
 #include <qlineedit.h>
 #include <qstringlist.h>
 #include "lengthcombo.h"
@@ -51,7 +52,7 @@ typedef Qt2CB<ControlDocument, Qt2DB<QDocumentDialog> > base_class;
 
 
 QDocument::QDocument()
-       : base_class(qt_("LyX: Document Settings"))
+       : base_class(_("LyX: Document Settings"))
 {
        vector<frnt::LanguagePair> const langs = frnt::getLanguageData(false);
        lang_ = getSecond(langs);
@@ -101,11 +102,11 @@ void QDocument::build_dialog()
        // packages
        for (int n = 0; tex_graphics[n][0]; ++n) {
                QString enc = tex_graphics[n];
-               dialog_->packagesModule->psdriverCO->insertItem(enc);
+               dialog_->latexModule->psdriverCO->insertItem(enc);
        }
 
        // paper
-       QComboBox * cb = dialog_->paperModule->papersizeCO;
+       QComboBox * cb = dialog_->pageLayoutModule->papersizeCO;
        cb->insertItem(qt_("Default"));
                cb->insertItem(qt_("Custom"));
                cb->insertItem(qt_("US letter"));
@@ -121,47 +122,63 @@ void QDocument::build_dialog()
        // layout
        for (LyXTextClassList::const_iterator cit = textclasslist.begin();
             cit != textclasslist.end(); ++cit) {
-               dialog_->layoutModule->classCO->insertItem(toqstr(cit->description()));
+               if (cit->isTeXClassAvailable()) {
+                       dialog_->latexModule->classCO->insertItem(toqstr(cit->description()));
+                } else {
+                       string item =
+#if USE_BOOST_FORMAT
+                               boost::io::str(boost::format(_("Unavailable: %1$s")) % cit->description());
+#else
+                               _("Unavailable: ") + cit->description();
+#endif
+                       dialog_->latexModule->classCO->insertItem(toqstr(item));
+               }
        }
 
        for (int n = 0; tex_fonts[n][0]; ++n) {
                QString font = tex_fonts[n];
-               dialog_->layoutModule->fontsCO->insertItem(font);
+               dialog_->textLayoutModule->fontsCO->insertItem(font);
        }
 
-       dialog_->layoutModule->fontsizeCO->insertItem(qt_("default"));
-       dialog_->layoutModule->fontsizeCO->insertItem(qt_("10"));
-       dialog_->layoutModule->fontsizeCO->insertItem(qt_("11"));
-       dialog_->layoutModule->fontsizeCO->insertItem(qt_("12"));
+       dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("default"));
+       dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("10"));
+       dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("11"));
+       dialog_->textLayoutModule->fontsizeCO->insertItem(qt_("12"));
 
-       dialog_->layoutModule->skipCO->insertItem(qt_("SmallSkip"));
-       dialog_->layoutModule->skipCO->insertItem(qt_("MedSkip"));
-       dialog_->layoutModule->skipCO->insertItem(qt_("BigSkip"));
-       dialog_->layoutModule->skipCO->insertItem(qt_("Length"));
+       dialog_->textLayoutModule->skipCO->insertItem(qt_("SmallSkip"));
+       dialog_->textLayoutModule->skipCO->insertItem(qt_("MedSkip"));
+       dialog_->textLayoutModule->skipCO->insertItem(qt_("BigSkip"));
+       dialog_->textLayoutModule->skipCO->insertItem(qt_("Length"));
 
-       dialog_->layoutModule->pagestyleCO->insertItem(qt_("default"));
-       dialog_->layoutModule->pagestyleCO->insertItem(qt_("empty"));
-       dialog_->layoutModule->pagestyleCO->insertItem(qt_("plain"));
-       dialog_->layoutModule->pagestyleCO->insertItem(qt_("headings"));
-       dialog_->layoutModule->pagestyleCO->insertItem(qt_("fancy"));
+       dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("default"));
+       dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("empty"));
+       dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("plain"));
+       dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("headings"));
+       dialog_->pageLayoutModule->pagestyleCO->insertItem(qt_("fancy"));
 
-       dialog_->layoutModule->lspacingCO->insertItem(
+       dialog_->textLayoutModule->lspacingCO->insertItem(
                qt_("Single"), Spacing::Single);
-       dialog_->layoutModule->lspacingCO->insertItem(
+       dialog_->textLayoutModule->lspacingCO->insertItem(
                qt_("OneHalf"), Spacing::Onehalf);
-       dialog_->layoutModule->lspacingCO->insertItem(
+       dialog_->textLayoutModule->lspacingCO->insertItem(
                qt_("Double"), Spacing::Double);
-       dialog_->layoutModule->lspacingCO->insertItem(
+       dialog_->textLayoutModule->lspacingCO->insertItem(
                qt_("Custom"), Spacing::Other);
 
        // margins
        dialog_->setMargins(0);
 
        // Manage the restore, ok, apply, restore and cancel/close buttons
-       bc().setOK(dialog_->okPB);
-       bc().setApply(dialog_->applyPB);
-       bc().setCancel(dialog_->closePB);
-       bc().setRestore(dialog_->restorePB);
+       bcview().setOK(dialog_->okPB);
+       bcview().setApply(dialog_->applyPB);
+       bcview().setCancel(dialog_->closePB);
+       bcview().setRestore(dialog_->restorePB);
+}
+
+
+void QDocument::showPreamble()
+{
+       dialog_->showPreamble();
 }
 
 
@@ -223,10 +240,8 @@ void QDocument::apply()
        params.language = languages.getLanguage(lang_[pos]);
 
        // numbering
-       params.secnumdepth =
-               dialog_->numberingModule->tocDepthSB->value();
-       params.tocdepth =
-               dialog_->numberingModule->sectionnrDepthSB->value();
+       params.tocdepth = dialog_->numberingModule->tocSL->value();
+       params.secnumdepth = dialog_->numberingModule->depthSL->value();
 
        // bullets
        params.user_defined_bullets[0] = dialog_->bulletsModule->getBullet(0);
@@ -236,25 +251,31 @@ void QDocument::apply()
 
        // packages
        params.graphicsDriver =
-               fromqstr(dialog_->packagesModule->psdriverCO->currentText());
+               fromqstr(dialog_->latexModule->psdriverCO->currentText());
 
-       params.use_amsmath =
-               dialog_->packagesModule->amsCB->isChecked();
+       if (dialog_->mathsModule->amsautoCB->isChecked()) {
+               params.use_amsmath = BufferParams::AMS_AUTO;
+       } else {
+               if (dialog_->mathsModule->amsCB->isChecked())
+                       params.use_amsmath = BufferParams::AMS_ON;
+               else
+                       params.use_amsmath = BufferParams::AMS_OFF;
+       }
 
        // layout
        params.textclass =
-               dialog_->layoutModule->classCO->currentItem();
+               dialog_->latexModule->classCO->currentItem();
 
        params.fonts =
-               fromqstr(dialog_->layoutModule->fontsCO->currentText());
+               fromqstr(dialog_->textLayoutModule->fontsCO->currentText());
 
        params.fontsize =
-               fromqstr(dialog_->layoutModule->fontsizeCO->currentText());
+               fromqstr(dialog_->textLayoutModule->fontsizeCO->currentText());
 
        params.pagestyle =
-               fromqstr(dialog_->layoutModule->pagestyleCO->currentText());
+               fromqstr(dialog_->pageLayoutModule->pagestyleCO->currentText());
 
-       switch (dialog_->layoutModule->lspacingCO->currentItem()) {
+       switch (dialog_->textLayoutModule->lspacingCO->currentItem()) {
        case 0:
                params.spacing.set(Spacing::Single);
                break;
@@ -266,18 +287,23 @@ void QDocument::apply()
                break;
        case 3:
                params.spacing.set(Spacing::Other,
-                                  dialog_->layoutModule->
+                                  dialog_->textLayoutModule->
                                   lspacingLE->text().toFloat()
                                   );
                break;
        }
 
-       if (dialog_->layoutModule->indentRB->isChecked())
+       if (dialog_->textLayoutModule->twoColumnCB->isChecked())
+               params.columns = 2;
+       else
+               params.columns = 1;
+
+       if (dialog_->textLayoutModule->indentRB->isChecked())
                params.paragraph_separation = BufferParams::PARSEP_INDENT;
        else
                params.paragraph_separation = BufferParams::PARSEP_SKIP;
 
-       switch (dialog_->layoutModule->skipCO->currentItem()) {
+       switch (dialog_->textLayoutModule->skipCO->currentItem()) {
        case 0:
                params.setDefSkip(VSpace(VSpace::SMALLSKIP));
                break;
@@ -290,10 +316,10 @@ void QDocument::apply()
        case 3:
        {
                LyXLength::UNIT unit =
-                       dialog_->layoutModule->skipLengthCO->
+                       dialog_->textLayoutModule->skipLengthCO->
                        currentLengthItem();
                double length =
-                       dialog_->layoutModule->skipLE->text().toDouble();
+                       dialog_->textLayoutModule->skipLE->text().toDouble();
                VSpace vs = VSpace(LyXGlueLength(LyXLength(length,unit)));
                params.setDefSkip(vs);
                break;
@@ -306,32 +332,26 @@ void QDocument::apply()
        }
 
        params.options =
-               fromqstr(dialog_->layoutModule->optionsLE->text());
+               fromqstr(dialog_->latexModule->optionsLE->text());
 
-       params.float_placement =
-               fromqstr(dialog_->layoutModule->floatPlacementLE->text());
+       params.float_placement = dialog_->floatModule->get();
 
        // paper
-       params.papersize2 =
-               dialog_->paperModule->papersizeCO->currentItem();
+       params.papersize2 = BufferParams::VMARGIN_PAPER_TYPE(
+               dialog_->pageLayoutModule->papersizeCO->currentItem());
 
-       params.paperwidth = widgetsToLength(dialog_->paperModule->paperwidthLE,
-               dialog_->paperModule->paperwidthUnitCO);
+       params.paperwidth = widgetsToLength(dialog_->pageLayoutModule->paperwidthLE,
+               dialog_->pageLayoutModule->paperwidthUnitCO);
 
-       params.paperheight = widgetsToLength(dialog_->paperModule->paperheightLE,
-               dialog_->paperModule->paperheightUnitCO);
+       params.paperheight = widgetsToLength(dialog_->pageLayoutModule->paperheightLE,
+               dialog_->pageLayoutModule->paperheightUnitCO);
 
-       if (dialog_->paperModule->twoColumnCB->isChecked())
-               params.columns = 2;
-       else
-               params.columns = 1;
-
-       if (dialog_->paperModule->facingPagesCB->isChecked())
+       if (dialog_->pageLayoutModule->facingPagesCB->isChecked())
                params.sides = LyXTextClass::TwoSides;
        else
                params.sides = LyXTextClass::OneSide;
 
-       if (dialog_->paperModule->landscapeRB->isChecked())
+       if (dialog_->pageLayoutModule->landscapeRB->isChecked())
                params.orientation = BufferParams::ORIENTATION_LANDSCAPE;
        else
                params.orientation = BufferParams::ORIENTATION_PORTRAIT;
@@ -344,7 +364,7 @@ void QDocument::apply()
        if (margin > 0) {
                margin = margin - 1;
        }
-       params.paperpackage = char(margin);
+       params.paperpackage = BufferParams::PAPER_PACKAGES(margin);
 
        // set params.papersize from params.papersize2
        // and params.paperpackage
@@ -454,10 +474,9 @@ void QDocument::update_contents()
        }
 
        // numbering
-       dialog_->numberingModule->tocDepthSB->setValue(
-               params.secnumdepth);
-       dialog_->numberingModule->sectionnrDepthSB->setValue(
-               params.tocdepth);
+       dialog_->numberingModule->tocSL->setValue(params.tocdepth);
+       dialog_->numberingModule->depthSL->setValue(params.secnumdepth);
+       dialog_->updateNumbering();
 
        // bullets
        dialog_->bulletsModule->setBullet(0,params.user_defined_bullets[0]);
@@ -467,17 +486,19 @@ void QDocument::update_contents()
 
        // packages
        QString text = toqstr(params.graphicsDriver);
-       int nitem = dialog_->packagesModule->psdriverCO->count();
+       int nitem = dialog_->latexModule->psdriverCO->count();
        for (int n = 0; n < nitem ; ++n) {
                QString enc = tex_graphics[n];
                if (enc == text) {
-                       dialog_->packagesModule->psdriverCO->setCurrentItem(n);
+                       dialog_->latexModule->psdriverCO->setCurrentItem(n);
                }
        }
 
 
-       dialog_->packagesModule->amsCB->setChecked(
-               params.use_amsmath);
+       dialog_->mathsModule->amsCB->setChecked(
+               params.use_amsmath == BufferParams::AMS_ON);
+       dialog_->mathsModule->amsautoCB->setChecked(
+               params.use_amsmath == BufferParams::AMS_AUTO);
 
        switch (params.spacing.getSpace()) {
                case Spacing::Other: nitem = 3; break;
@@ -488,13 +509,7 @@ void QDocument::update_contents()
 
 
        // layout
-       for (int n = 0; n<dialog_->layoutModule->classCO->count(); ++n) {
-               if (dialog_->layoutModule->classCO->text(n) ==
-                   toqstr(controller().textClass().description())) {
-                       dialog_->layoutModule->classCO->setCurrentItem(n);
-                       break;
-               }
-       }
+       dialog_->latexModule->classCO->setCurrentItem(params.textclass);
 
        dialog_->updateFontsize(controller().textClass().opt_fontsize(),
                                params.fontsize);
@@ -504,23 +519,23 @@ void QDocument::update_contents()
 
        for (int n = 0; tex_fonts[n][0]; ++n) {
                if (tex_fonts[n] == params.fonts) {
-                       dialog_->layoutModule->fontsCO->setCurrentItem(n);
+                       dialog_->textLayoutModule->fontsCO->setCurrentItem(n);
                        break;
                }
        }
 
-       dialog_->layoutModule->lspacingCO->setCurrentItem(nitem);
+       dialog_->textLayoutModule->lspacingCO->setCurrentItem(nitem);
        if (params.spacing.getSpace() == Spacing::Other) {
-               dialog_->layoutModule->lspacingLE->setText(
+               dialog_->textLayoutModule->lspacingLE->setText(
                        toqstr(tostr(params.spacing.getValue())));
                dialog_->setLSpacing(3);
        }
 
        if (params.paragraph_separation
            == BufferParams::PARSEP_INDENT) {
-               dialog_->layoutModule->indentRB->setChecked(true);
+               dialog_->textLayoutModule->indentRB->setChecked(true);
        } else {
-               dialog_->layoutModule->skipRB->setChecked(true);
+               dialog_->textLayoutModule->skipRB->setChecked(true);
        }
 
        int skip = 0;
@@ -538,47 +553,50 @@ void QDocument::update_contents()
        {
                skip = 3;
                string const length = params.getDefSkip().asLyXCommand();
-               dialog_->layoutModule->skipLengthCO->setCurrentItem(LyXLength(length).unit());
-               dialog_->layoutModule->skipLE->setText(toqstr(tostr(LyXLength(length).value())));
+               dialog_->textLayoutModule->skipLengthCO->setCurrentItem(LyXLength(length).unit());
+               dialog_->textLayoutModule->skipLE->setText(toqstr(tostr(LyXLength(length).value())));
                break;
        }
        default:
                skip = 0;
                break;
        }
-       dialog_->layoutModule->skipCO->setCurrentItem(skip);
+       dialog_->textLayoutModule->skipCO->setCurrentItem(skip);
        dialog_->setSkip(skip);
 
+       dialog_->textLayoutModule->twoColumnCB->setChecked(
+               params.columns == 2);
+
        if (!params.options.empty()) {
-               dialog_->layoutModule->optionsLE->setText(
+               dialog_->latexModule->optionsLE->setText(
                        toqstr(params.options));
        } else {
-               dialog_->layoutModule->optionsLE->setText("");
+               dialog_->latexModule->optionsLE->setText("");
        }
 
+       dialog_->floatModule->set(params.float_placement);
+
        // paper
        int const psize = params.papersize2;
-       dialog_->paperModule->papersizeCO->setCurrentItem(psize);
+       dialog_->pageLayoutModule->papersizeCO->setCurrentItem(psize);
        dialog_->setMargins(psize);
        dialog_->setCustomPapersize(psize);
 
        bool const landscape =
                params.orientation == BufferParams::ORIENTATION_LANDSCAPE;
-       dialog_->paperModule->landscapeRB->setChecked(landscape);
-       dialog_->paperModule->portraitRB->setChecked(!landscape);
+       dialog_->pageLayoutModule->landscapeRB->setChecked(landscape);
+       dialog_->pageLayoutModule->portraitRB->setChecked(!landscape);
 
-       dialog_->paperModule->facingPagesCB->setChecked(
+       dialog_->pageLayoutModule->facingPagesCB->setChecked(
                params.sides == LyXTextClass::TwoSides);
 
-       dialog_->paperModule->twoColumnCB->setChecked(
-               params.columns == 2);
 
 
-       lengthToWidgets(dialog_->paperModule->paperwidthLE,
-               dialog_->paperModule->paperwidthUnitCO, params.paperwidth, defaultUnit);
+       lengthToWidgets(dialog_->pageLayoutModule->paperwidthLE,
+               dialog_->pageLayoutModule->paperwidthUnitCO, params.paperwidth, defaultUnit);
 
-       lengthToWidgets(dialog_->paperModule->paperheightLE,
-               dialog_->paperModule->paperheightUnitCO, params.paperheight, defaultUnit);
+       lengthToWidgets(dialog_->pageLayoutModule->paperheightLE,
+               dialog_->pageLayoutModule->paperheightUnitCO, params.paperheight, defaultUnit);
 
        // margins
 
@@ -628,7 +646,7 @@ void QDocument::useClassDefaults()
 {
        BufferParams & params = controller().params();
 
-       params.textclass = dialog_->layoutModule->classCO->currentItem();
+       params.textclass = dialog_->latexModule->classCO->currentItem();
        params.useClassDefaults();
        update_contents();
 }