-
- if (in == 0 || !in->forceDefaultParagraphs(in)) {
- further_blank_line = false;
- if (pit->params().lineBottom()) {
- os << "\\lyxline{\\" << font.latexSize() << '}';
- further_blank_line = true;
- }
-
- if (pit->params().spaceBottom().kind() != VSpace::NONE) {
- os << pit->params().spaceBottom().asLatexCommand(bparams);
- further_blank_line = true;
- }
-
- if (pit->params().pagebreakBottom()) {
- os << "\\newpage";
- further_blank_line = true;
- }
-
- if (further_blank_line) {
- os << '\n';
- texrow.newline();
- }
-
- if (!pit->params().spacing().isDefault()
- && (boost::next(pit) == const_cast<ParagraphList&>(paragraphs).end()|| !boost::next(pit)->hasSameLayout(*pit))) {
- os << pit->params().spacing().writeEnvirEnd() << '\n';
- texrow.newline();
- }
- }
-
- // we don't need it for the last paragraph!!!
- if (boost::next(pit) != const_cast<ParagraphList&>(paragraphs).end()) {
- os << '\n';
- texrow.newline();
- } else {
- // Since \selectlanguage write the language to the aux file,
- // we need to reset the language at the end of footnote or
- // float.
-
- if (language->babel() != doc_language->babel()) {
- if (lyxrc.language_command_end.empty())
- os << subst(lyxrc.language_command_begin,
- "$$lang",
- doc_language->babel())
- << endl;
- else
- os << subst(lyxrc.language_command_end,
- "$$lang",
- language->babel())
- << endl;
- texrow.newline();
- }
- }
-
- lyxerr[Debug::LATEX] << "TeXOnePar...done " << &*boost::next(pit) << endl;
- return ++pit;
-}
-
-} // anon namespace
-
-
-//
-// LaTeX all paragraphs from par to endpar, if endpar == 0 then to the end
-//
-void latexParagraphs(Buffer const * buf,
- ParagraphList const & paragraphs,
- ostream & os,
- TexRow & texrow,
- LatexRunParams const & runparams,
- string const & everypar)
-{
- bool was_title = false;
- bool already_title = false;
- LyXTextClass const & tclass = buf->params.getLyXTextClass();
- ParagraphList::iterator par = const_cast<ParagraphList&>(paragraphs).begin();
- ParagraphList::iterator endpar = const_cast<ParagraphList&>(paragraphs).end();
-
- // if only_body
- while (par != endpar) {
- InsetOld * in = par->inInset();
- // well we have to check if we are in an inset with unlimited
- // length (all in one row) if that is true then we don't allow
- // any special options in the paragraph and also we don't allow
- // any environment other then "Standard" to be valid!
- if ((in == 0) || !in->forceDefaultParagraphs(in)) {
- LyXLayout_ptr const & layout = par->layout();
-
- if (layout->intitle) {
- if (already_title) {
- lyxerr <<"Error in latexParagraphs: You"
- " should not mix title layouts"
- " with normal ones." << endl;
- } else if (!was_title) {
- was_title = true;
- if (tclass.titletype() == TITLE_ENVIRONMENT) {
- os << "\\begin{"
- << tclass.titlename()
- << "}\n";
- texrow.newline();
- }
- }
- } else if (was_title && !already_title) {
- if (tclass.titletype() == TITLE_ENVIRONMENT) {
- os << "\\end{" << tclass.titlename()
- << "}\n";
- }
- else {
- os << "\\" << tclass.titlename()
- << "\n";
- }
- texrow.newline();
- already_title = true;
- was_title = false;
- }
-
- if (layout->is_environment) {
- par = TeXOnePar(buf, paragraphs, par, os, texrow,
- runparams, everypar);
- } else if (layout->isEnvironment() ||
- !par->params().leftIndent().zero())
- {
- par = TeXEnvironment(buf, paragraphs, par, os,
- texrow, runparams);
- } else {
- par = TeXOnePar(buf, paragraphs, par, os, texrow,
- runparams, everypar);
- }
- } else {
- par = TeXOnePar(buf, paragraphs, par, os, texrow,
- runparams, everypar);
- }
- }
- // It might be that we only have a title in this document
- if (was_title && !already_title) {
- if (tclass.titletype() == TITLE_ENVIRONMENT) {
- os << "\\end{" << tclass.titlename()
- << "}\n";
- }
- else {
- os << "\\" << tclass.titlename()
- << "\n";
- }
- texrow.newline();
- }
-}
-
-
-namespace {
-
-int readParToken(Buffer & buf, Paragraph & par, LyXLex & lex, string const & token)
-{
- static LyXFont font;
- static Change change;
-
- BufferParams const & bp = buf.params;
-
- if (token[0] != '\\') {
- string::const_iterator cit = token.begin();
- for (; cit != token.end(); ++cit) {
- par.insertChar(par.size(), (*cit), font, change);
- }
- } else if (token == "\\begin_layout") {
- lex.eatLine();
- string layoutname = lex.getString();
-
- font = LyXFont(LyXFont::ALL_INHERIT, bp.language);
- change = Change();
-
- LyXTextClass const & tclass = bp.getLyXTextClass();
-
- if (layoutname.empty()) {
- layoutname = tclass.defaultLayoutName();
- }
-
- bool hasLayout = tclass.hasLayout(layoutname);
-
- if (!hasLayout) {
- lyxerr << "Layout '" << layoutname << "' does not"
- << " exist in textclass '" << tclass.name()
- << "'." << endl;
- lyxerr << "Trying to use default layout instead."
- << endl;
- layoutname = tclass.defaultLayoutName();
- }
-
- par.layout(bp.getLyXTextClass()[layoutname]);
-
- // Test whether the layout is obsolete.
- LyXLayout_ptr const & layout = par.layout();
- if (!layout->obsoleted_by().empty())
- par.layout(bp.getLyXTextClass()[layout->obsoleted_by()]);
-
- par.params().read(lex);
-
- } else if (token == "\\end_layout") {
- lyxerr << "Solitary \\end_layout in line " << lex.getLineNo() << "\n"
- << "Missing \\begin_layout?.\n";
- } else if (token == "\\end_inset") {
- lyxerr << "Solitary \\end_inset in line " << lex.getLineNo() << "\n"
- << "Missing \\begin_inset?.\n";
- } else if (token == "\\begin_inset") {
- InsetOld * inset = readInset(lex, buf);
- par.insertInset(par.size(), inset, font, change);
- } else if (token == "\\family") {
- lex.next();
- font.setLyXFamily(lex.getString());
- } else if (token == "\\series") {
- lex.next();
- font.setLyXSeries(lex.getString());
- } else if (token == "\\shape") {
- lex.next();
- font.setLyXShape(lex.getString());
- } else if (token == "\\size") {
- lex.next();
- font.setLyXSize(lex.getString());
- } else if (token == "\\lang") {
- lex.next();
- string const tok = lex.getString();
- Language const * lang = languages.getLanguage(tok);
- if (lang) {
- font.setLanguage(lang);
- } else {
- font.setLanguage(bp.language);
- lex.printError("Unknown language `$$Token'");
- }
- } else if (token == "\\numeric") {
- lex.next();
- font.setNumber(font.setLyXMisc(lex.getString()));
- } else if (token == "\\emph") {
- lex.next();
- font.setEmph(font.setLyXMisc(lex.getString()));
- } else if (token == "\\bar") {
- lex.next();
- string const tok = lex.getString();
-
- if (tok == "under")
- font.setUnderbar(LyXFont::ON);
- else if (tok == "no")
- font.setUnderbar(LyXFont::OFF);
- else if (tok == "default")
- font.setUnderbar(LyXFont::INHERIT);
- else
- lex.printError("Unknown bar font flag "
- "`$$Token'");
- } else if (token == "\\noun") {
- lex.next();
- font.setNoun(font.setLyXMisc(lex.getString()));
- } else if (token == "\\color") {
- lex.next();
- font.setLyXColor(lex.getString());
- } else if (token == "\\InsetSpace" || token == "\\SpecialChar") {
-
- // Insets don't make sense in a free-spacing context! ---Kayvan
- if (par.isFreeSpacing()) {
- if (token == "\\InsetSpace")
- par.insertChar(par.size(), ' ', font, change);
- else if (lex.isOK()) {
- lex.next();
- string const next_token = lex.getString();
- if (next_token == "\\-")
- par.insertChar(par.size(), '-', font, change);
- else {
- lex.printError("Token `$$Token' "
- "is in free space "
- "paragraph layout!");
- }
- }
- } else {
- InsetOld * inset = 0;
- if (token == "\\SpecialChar" )
- inset = new InsetSpecialChar;
- else
- inset = new InsetSpace;
- inset->read(&buf, lex);
- par.insertInset(par.size(), inset, font, change);
- }
- } else if (token == "\\i") {
- InsetOld * inset = new InsetLatexAccent;
- inset->read(&buf, lex);
- par.insertInset(par.size(), inset, font, change);
- } else if (token == "\\backslash") {
- par.insertChar(par.size(), '\\', font, change);
- } else if (token == "\\newline") {
- InsetOld * inset = new InsetNewline;
- inset->read(&buf, lex);
- par.insertInset(par.size(), inset, font, change);
- } else if (token == "\\LyXTable") {
- InsetOld * inset = new InsetTabular(buf);
- inset->read(&buf, lex);
- par.insertInset(par.size(), inset, font, change);
- } else if (token == "\\bibitem") {
- InsetCommandParams p("bibitem", "dummy");
- InsetBibitem * inset = new InsetBibitem(p);
- inset->read(&buf, lex);
- par.insertInset(par.size(), inset, font, change);
- } else if (token == "\\hfill") {
- par.insertInset(par.size(), new InsetHFill, font, change);
- } else if (token == "\\change_unchanged") {
- // Hack ! Needed for empty paragraphs :/
- // FIXME: is it still ??
- if (!par.size())
- par.cleanChanges();
- change = Change(Change::UNCHANGED);
- } else if (token == "\\change_inserted") {
- lex.nextToken();
- istringstream is(STRCONV(lex.getString()));
- int aid;
- lyx::time_type ct;
- is >> aid >> ct;
- change = Change(Change::INSERTED, bp.author_map[aid], ct);
- } else if (token == "\\change_deleted") {
- lex.nextToken();
- istringstream is(STRCONV(lex.getString()));
- int aid;
- lyx::time_type ct;
- is >> aid >> ct;
- change = Change(Change::DELETED, bp.author_map[aid], ct);
- } else {
- lex.eatLine();
- string const s = bformat(_("Unknown token: %1$s %2$s\n"),
- token, lex.getString());
-
- buf.error(ErrorItem(_("Unknown token"), s,
- par.id(), 0, par.size()));
- return 1;
- }
- return 0;
-}
-
-}
-
-
-int readParagraph(Buffer & buf, Paragraph & par, LyXLex & lex)
-{
- int unknown = 0;
-
- lex.nextToken();
- string token = lex.getString();
-
- while (lex.isOK()) {
-
- unknown += readParToken(buf, par, lex, token);
-
- lex.nextToken();
- token = lex.getString();
-
- if (token.empty())
- continue;
-
- if (token == "\\end_layout") {
- //Ok, paragraph finished
- break;
- }
-
- lyxerr[Debug::PARSER] << "Handling paragraph token: `"
- << token << '\'' << endl;
- if (token == "\\begin_layout" || token == "\\end_document"
- || token == "\\end_inset" || token == "\\begin_deeper"
- || token == "\\end_deeper") {
- lex.pushToken(token);
- lyxerr << "Paragraph ended in line "
- << lex.getLineNo() << "\n"
- << "Missing \\end_layout.\n";
- break;
- }
- }
-
- return unknown;
-}
-
-
-LyXFont const outerFont(ParagraphList::iterator pit,
- ParagraphList const & plist)
-{
- Paragraph::depth_type par_depth = pit->getDepth();
- LyXFont tmpfont(LyXFont::ALL_INHERIT);
-
- // Resolve against environment font information
- while (pit != const_cast<ParagraphList&>(plist).end() &&
- par_depth && !tmpfont.resolved()) {
- pit = outerHook(pit, plist);
- if (pit != const_cast<ParagraphList&>(plist).end()) {
- tmpfont.realize(pit->layout()->font);
- par_depth = pit->getDepth();
- }
- }
-
- return tmpfont;