]> git.lyx.org Git - lyx.git/blobdiff - src/output_docbook.cpp
Account for old versions of Pygments
[lyx.git] / src / output_docbook.cpp
index dda121059deab033add6b22885d1f94a3b5362c9..6ab9c9d9f076bd08641567efa20c0530af32d16c 100644 (file)
@@ -3,8 +3,8 @@
  * This file is part of LyX, the document processor.
  * Licence details can be found in the file COPYING.
  *
- * \author Lars Gullik Bjønnes
- * \author José Matos
+ * \author Lars Gullik Bjønnes
+ * \author José Matos
  *
  * Full author contact details are available in file CREDITS.
  */
 #include "buffer_funcs.h"
 #include "BufferParams.h"
 #include "Counters.h"
+#include "Font.h"
 #include "Layout.h"
 #include "OutputParams.h"
 #include "Paragraph.h"
-#include "paragraph_funcs.h"
 #include "ParagraphList.h"
 #include "ParagraphParameters.h"
 #include "sgml.h"
+#include "Text.h"
 #include "TextClass.h"
 
-#include "support/convert.h"
+#include "support/lassert.h"
 #include "support/debug.h"
 #include "support/lstrings.h"
-#include "support/types.h"
+#include "support/lyxalgo.h"
 
-#include <boost/next_prior.hpp>
+#include <iostream>
 
 using namespace std;
 using namespace lyx::support;
@@ -42,9 +43,9 @@ namespace {
 
 ParagraphList::const_iterator searchParagraph(
        ParagraphList::const_iterator p,
-  ParagraphList::const_iterator const & pend)
+       ParagraphList::const_iterator const & pend)
 {
-       for (++p; p != pend && p->layout()->latextype == LATEX_PARAGRAPH; ++p)
+       for (++p; p != pend && p->layout().latextype == LATEX_PARAGRAPH; ++p)
                ;
 
        return p;
@@ -52,15 +53,15 @@ ParagraphList::const_iterator searchParagraph(
 
 
 ParagraphList::const_iterator searchCommand(
-               ParagraphList::const_iterator p,
-               ParagraphList::const_iterator const & pend)
+       ParagraphList::const_iterator p,
+       ParagraphList::const_iterator const & pend)
 {
-       LayoutPtr const & bstyle = p->layout();
+       Layout const & bstyle = p->layout();
 
        for (++p; p != pend; ++p) {
-               LayoutPtr const & style = p->layout();
-               if (style->latextype == LATEX_COMMAND
-                               && style->commanddepth <= bstyle->commanddepth)
+               Layout const & style = p->layout();
+               if (style.latextype == LATEX_COMMAND
+                               && style.commanddepth <= bstyle.commanddepth)
                        return p;
        }
        return pend;
@@ -68,17 +69,17 @@ ParagraphList::const_iterator searchCommand(
 
 
 ParagraphList::const_iterator searchEnvironment(
-               ParagraphList::const_iterator p,
-               ParagraphList::const_iterator const & pend)
+       ParagraphList::const_iterator p,
+       ParagraphList::const_iterator const & pend)
 {
-       LayoutPtr const & bstyle = p->layout();
+       Layout const & bstyle = p->layout();
        size_t const depth = p->params().depth();
        for (++p; p != pend; ++p) {
-               LayoutPtr const & style = p->layout();
-               if (style->latextype == LATEX_COMMAND)
+               Layout const & style = p->layout();
+               if (style.latextype == LATEX_COMMAND)
                        return p;
 
-               if (style->latextype == LATEX_PARAGRAPH) {
+               if (style.latextype == LATEX_PARAGRAPH) {
                        if (p->params().depth() > depth)
                                continue;
                        return p;
@@ -87,7 +88,7 @@ ParagraphList::const_iterator searchEnvironment(
                if (p->params().depth() < depth)
                        return p;
 
-               if (style->latexname() != bstyle->latexname()
+               if (style.latexname() != bstyle.latexname()
                                && p->params().depth() == depth)
                        return p;
        }
@@ -95,23 +96,28 @@ ParagraphList::const_iterator searchEnvironment(
 }
 
 
-ParagraphList::const_iterator makeParagraph(Buffer const & buf,
-                                           odocstream & os,
-                                           OutputParams const & runparams,
-                                           ParagraphList const & paragraphs,
-                                           ParagraphList::const_iterator const & pbegin,
-                                           ParagraphList::const_iterator const & pend)
+ParagraphList::const_iterator makeParagraph(
+       Buffer const & buf,
+       odocstream & os,
+       OutputParams const & runparams,
+       Text const & text,
+       ParagraphList::const_iterator const & pbegin,
+       ParagraphList::const_iterator const & pend)
 {
-       LayoutPtr const & defaultstyle =
-               buf.params().getTextClass().defaultLayout();
+       ParagraphList const & paragraphs = text.paragraphs();
        for (ParagraphList::const_iterator par = pbegin; par != pend; ++par) {
                if (par != pbegin)
                        os << '\n';
-               if (par->layout() == defaultstyle && par->emptyTag()) {
-                       par->simpleDocBookOnePar(buf, os, runparams, outerFont(distance(paragraphs.begin(), par), paragraphs));
+               bool const default_or_plain = 
+                       (buf.params().documentClass().isDefaultLayout(par->layout()) 
+                               || buf.params().documentClass().isPlainLayout(par->layout()));
+               if (default_or_plain && par->emptyTag()) {
+                       par->simpleDocBookOnePar(buf, os, runparams, 
+                                       text.outerFont(distance(paragraphs.begin(), par)));
                } else {
                        sgml::openTag(buf, os, runparams, *par);
-                       par->simpleDocBookOnePar(buf, os, runparams, outerFont(distance(paragraphs.begin(), par), paragraphs));
+                       par->simpleDocBookOnePar(buf, os, runparams, 
+                                       text.outerFont(distance(paragraphs.begin(), par)));
                        sgml::closeTag(os, *par);
                }
        }
@@ -119,86 +125,94 @@ ParagraphList::const_iterator makeParagraph(Buffer const & buf,
 }
 
 
-ParagraphList::const_iterator makeEnvironment(Buffer const & buf,
-                                             odocstream & os,
-                                             OutputParams const & runparams,
-                                             ParagraphList const & paragraphs,
-                                             ParagraphList::const_iterator const & pbegin,
-                                             ParagraphList::const_iterator const & pend) {
+ParagraphList::const_iterator makeEnvironment(
+       Buffer const & buf,
+       odocstream & os,
+       OutputParams const & runparams,
+       Text const & text,
+       ParagraphList::const_iterator const & pbegin,
+       ParagraphList::const_iterator const & pend)
+{
+       ParagraphList const & paragraphs = text.paragraphs();
        ParagraphList::const_iterator par = pbegin;
 
-       LayoutPtr const & defaultstyle = buf.params().getTextClass().defaultLayout();
-       LayoutPtr const & bstyle = par->layout();
-       string item_tag;
+       Layout const & defaultstyle = buf.params().documentClass().defaultLayout();
+       Layout const & bstyle = par->layout();
 
        // Opening outter tag
        sgml::openTag(buf, os, runparams, *pbegin);
        os << '\n';
-       if (bstyle->latextype == LATEX_ENVIRONMENT && bstyle->pass_thru)
+       if (bstyle.latextype == LATEX_ENVIRONMENT && bstyle.pass_thru)
                os << "<![CDATA[";
 
        while (par != pend) {
-               LayoutPtr const & style = par->layout();
+               Layout const & style = par->layout();
                ParagraphList::const_iterator send;
                string id = par->getID(buf, runparams);
                string wrapper = "";
                pos_type sep = 0;
 
                // Opening inner tag
-               switch (bstyle->latextype) {
+               switch (bstyle.latextype) {
                case LATEX_ENVIRONMENT:
-                       if (!bstyle->innertag().empty()) {
-                               sgml::openTag(os, bstyle->innertag(), id);
+                       if (!bstyle.innertag().empty()) {
+                               sgml::openTag(os, bstyle.innertag(), id);
                        }
                        break;
 
                case LATEX_ITEM_ENVIRONMENT:
-                       if (!bstyle->labeltag().empty()) {
-                               sgml::openTag(os, bstyle->innertag(), id);
-                               sgml::openTag(os, bstyle->labeltag());
-                               sep = par->getFirstWord(buf, os, runparams) + 1;
-                               sgml::closeTag(os, bstyle->labeltag());
+                       if (!bstyle.labeltag().empty()) {
+                               sgml::openTag(os, bstyle.innertag(), id);
+                               sgml::openTag(os, bstyle.labeltag());
+                               sep = par->firstWordDocBook(os, runparams) + 1;
+                               sgml::closeTag(os, bstyle.labeltag());
                        }
-                       wrapper = defaultstyle->latexname();
+                       wrapper = defaultstyle.latexname();
                        // If a sub list (embedded list) appears next with a
                        // different depth, then there is no need to open
                        // another tag at the current depth.
                        if(par->params().depth() == pbegin->params().depth()) {
-                               sgml::openTag(os, bstyle->itemtag());
+                               sgml::openTag(os, bstyle.itemtag());
                        }
                        break;
                default:
                        break;
                }
 
-               switch (style->latextype) {
+               switch (style.latextype) {
                case LATEX_ENVIRONMENT:
                case LATEX_ITEM_ENVIRONMENT: {
                        if (par->params().depth() == pbegin->params().depth()) {
                                sgml::openTag(os, wrapper);
-                               par->simpleDocBookOnePar(buf, os, runparams, outerFont(distance(paragraphs.begin(), par), paragraphs), sep);
+                               par->simpleDocBookOnePar(buf, os, runparams,
+                                       text.outerFont(distance(paragraphs.begin(), par)), sep);
                                sgml::closeTag(os, wrapper);
                                ++par;
                        }
                        else {
                                send = searchEnvironment(par, pend);
-                               par = makeEnvironment(buf, os, runparams, paragraphs, par,send);
+                               par = makeEnvironment(buf, os, runparams, text, par,send);
                        }
                        break;
                }
                case LATEX_PARAGRAPH:
                        send = searchParagraph(par, pend);
-                       par = makeParagraph(buf, os, runparams, paragraphs, par,send);
+                       par = makeParagraph(buf, os, runparams, text, par,send);
                        break;
-               default:
+               case LATEX_LIST_ENVIRONMENT:
+               case LATEX_BIB_ENVIRONMENT:
+               case LATEX_COMMAND:
+                       // FIXME This means that we are just skipping any paragraph that
+                       // isn't implemented above, and this includes lists.
+                       ++par;
                        break;
                }
 
                // Closing inner tag
-               switch (bstyle->latextype) {
+               switch (bstyle.latextype) {
                case LATEX_ENVIRONMENT:
-                       if (!bstyle->innertag().empty()) {
-                               sgml::closeTag(os, bstyle->innertag());
+                       if (!bstyle.innertag().empty()) {
+                               sgml::closeTag(os, bstyle.innertag());
                                os << '\n';
                        }
                        break;
@@ -212,76 +226,83 @@ ParagraphList::const_iterator makeEnvironment(Buffer const & buf,
                        // when par == pend but at the same time that the
                        // current tag is closed.
                        if((par != pend && par->params().depth() == pbegin->params().depth()) || par == pend) {
-                               sgml::closeTag(os, bstyle->itemtag());
+                               sgml::closeTag(os, bstyle.itemtag());
                        }
-                       if (!bstyle->labeltag().empty())
-                               sgml::closeTag(os, bstyle->innertag());
+                       if (!bstyle.labeltag().empty())
+                               sgml::closeTag(os, bstyle.innertag());
                        break;
                default:
                        break;
                }
        }
 
-       if (bstyle->latextype == LATEX_ENVIRONMENT && bstyle->pass_thru)
+       if (bstyle.latextype == LATEX_ENVIRONMENT && bstyle.pass_thru)
                os << "]]>";
 
-       // Closing outter tag
+       // Closing outer tag
        sgml::closeTag(os, *pbegin);
 
        return pend;
 }
 
 
-ParagraphList::const_iterator makeCommand(Buffer const & buf,
-                                         odocstream & os,
-                                         OutputParams const & runparams,
-                                         ParagraphList const & paragraphs,
-                                         ParagraphList::const_iterator const & pbegin,
-                                         ParagraphList::const_iterator const & pend)
+ParagraphList::const_iterator makeCommand(
+       Buffer const & buf,
+       odocstream & os,
+       OutputParams const & runparams,
+       Text const & text,
+       ParagraphList::const_iterator const & pbegin,
+       ParagraphList::const_iterator const & pend)
 {
+       ParagraphList const & paragraphs = text.paragraphs();
        ParagraphList::const_iterator par = pbegin;
-       LayoutPtr const & bstyle = par->layout();
+       Layout const & bstyle = par->layout();
 
        //Open outter tag
        sgml::openTag(buf, os, runparams, *pbegin);
        os << '\n';
 
        // Label around sectioning number:
-       if (!bstyle->labeltag().empty()) {
-               sgml::openTag(os, bstyle->labeltag());
+       if (!bstyle.labeltag().empty()) {
+               sgml::openTag(os, bstyle.labeltag());
                // We don't care about appendix in DOCBOOK.
-               os << par->expandLabel(bstyle, buf.params(), false);
-               sgml::closeTag(os, bstyle->labeltag());
+               os << par->expandDocBookLabel(bstyle, buf.params());
+               sgml::closeTag(os, bstyle.labeltag());
        }
 
        // Opend inner tag and  close inner tags
-       sgml::openTag(os, bstyle->innertag());
-       par->simpleDocBookOnePar(buf, os, runparams,  outerFont(distance(paragraphs.begin(), par), paragraphs));
-       sgml::closeTag(os, bstyle->innertag());
+       sgml::openTag(os, bstyle.innertag());
+       par->simpleDocBookOnePar(buf, os, runparams,
+               text.outerFont(distance(paragraphs.begin(), par)));
+       sgml::closeTag(os, bstyle.innertag());
        os << '\n';
 
        ++par;
        while (par != pend) {
-               LayoutPtr const & style = par->layout();
+               Layout const & style = par->layout();
                ParagraphList::const_iterator send;
 
-               switch (style->latextype) {
+               switch (style.latextype) {
                case LATEX_COMMAND: {
                        send = searchCommand(par, pend);
-                       par = makeCommand(buf, os, runparams, paragraphs, par,send);
+                       par = makeCommand(buf, os, runparams, text, par,send);
                        break;
                }
                case LATEX_ENVIRONMENT:
                case LATEX_ITEM_ENVIRONMENT: {
                        send = searchEnvironment(par, pend);
-                       par = makeEnvironment(buf, os, runparams, paragraphs, par,send);
+                       par = makeEnvironment(buf, os, runparams, text, par,send);
                        break;
                }
                case LATEX_PARAGRAPH:
                        send = searchParagraph(par, pend);
-                       par = makeParagraph(buf, os, runparams, paragraphs, par,send);
+                       par = makeParagraph(buf, os, runparams, text, par,send);
                        break;
-               default:
+               case LATEX_BIB_ENVIRONMENT:
+               case LATEX_LIST_ENVIRONMENT:
+                       // FIXME This means that we are just skipping any paragraph that
+                       // isn't implemented above.
+                       ++par;
                        break;
                }
        }
@@ -294,19 +315,22 @@ ParagraphList::const_iterator makeCommand(Buffer const & buf,
 } // end anonym namespace
 
 
-void docbookParagraphs(ParagraphList const & paragraphs,
+void docbookParagraphs(Text const & text,
                       Buffer const & buf,
                       odocstream & os,
                       OutputParams const & runparams)
 {
+       LASSERT(runparams.par_begin <= runparams.par_end,
+               { os << "<!-- Docbook Output Error -->\n"; return; });
+
+       ParagraphList const & paragraphs = text.paragraphs();
        ParagraphList::const_iterator par = paragraphs.begin();
        ParagraphList::const_iterator pend = paragraphs.end();
 
-       BOOST_ASSERT(runparams.par_begin <= runparams.par_end);
        // if only part of the paragraphs will be outputed
        if (runparams.par_begin !=  runparams.par_end) {
-               par = boost::next(paragraphs.begin(), runparams.par_begin);
-               pend = boost::next(paragraphs.begin(), runparams.par_end);
+               par = lyx::next(paragraphs.begin(), runparams.par_begin);
+               pend = lyx::next(paragraphs.begin(), runparams.par_end);
                // runparams will be passed to nested paragraphs, so
                // we have to reset the range parameters.
                const_cast<OutputParams&>(runparams).par_begin = 0;
@@ -314,27 +338,31 @@ void docbookParagraphs(ParagraphList const & paragraphs,
        }
 
        while (par != pend) {
-               LayoutPtr const & style = par->layout();
+               Layout const & style = par->layout();
                ParagraphList::const_iterator lastpar = par;
                ParagraphList::const_iterator send;
 
-               switch (style->latextype) {
+               switch (style.latextype) {
                case LATEX_COMMAND: {
                        send = searchCommand(par, pend);
-                       par = makeCommand(buf, os, runparams, paragraphs, par,send);
+                       par = makeCommand(buf, os, runparams, text, par, send);
                        break;
                }
                case LATEX_ENVIRONMENT:
                case LATEX_ITEM_ENVIRONMENT: {
                        send = searchEnvironment(par, pend);
-                       par = makeEnvironment(buf, os, runparams, paragraphs, par,send);
+                       par = makeEnvironment(buf, os, runparams, text, par, send);
                        break;
                }
                case LATEX_PARAGRAPH:
                        send = searchParagraph(par, pend);
-                       par = makeParagraph(buf, os, runparams, paragraphs, par,send);
+                       par = makeParagraph(buf, os, runparams, text, par, send);
                        break;
-               default:
+               case LATEX_BIB_ENVIRONMENT:
+               case LATEX_LIST_ENVIRONMENT:
+                       // FIXME This means that we are just skipping any paragraph that
+                       // isn't implemented above.
+                       ++par;
                        break;
                }
                // makeEnvironment may process more than one paragraphs and bypass pend