X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fbufferparams.C;h=6aa67adfc1150326856d224c08db0ac3eab20ecf;hb=1cfd4fceaccc2de186faf1118c2081346d37c65d;hp=ff656f202489483ef6f24ea741a182722c444d44;hpb=dfe1bc44b44903faf77ef454c98c4c3e56c1d5e3;p=lyx.git diff --git a/src/bufferparams.C b/src/bufferparams.C index ff656f2024..6aa67adfc1 100644 --- a/src/bufferparams.C +++ b/src/bufferparams.C @@ -1,18 +1,17 @@ /* This file is part of - * ====================================================== + * ====================================================== * * LyX, The Document Processor * * Copyright 1995 Matthias Ettrich - * Copyright 1995-1999 The LyX Team. + * Copyright 1995-2001 The LyX Team. * - * ======================================================*/ + * ====================================================== */ #include -#include #ifdef __GNUG__ -#pragma implementation "bufferparams.h" +#pragma implementation #endif #include "bufferparams.h" @@ -20,208 +19,196 @@ #include "layout.h" #include "vspace.h" #include "debug.h" +#include "lyxrc.h" +#include "language.h" +#include "lyxtextclasslist.h" + #include "support/lyxlib.h" #include "support/lstrings.h" +#include + +using std::ostream; +using std::endl; + 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) { - paragraph_separation = LYX_PARSEP_INDENT; + paragraph_separation = PARSEP_INDENT; defskip = VSpace(VSpace::MEDSKIP); quotes_language = InsetQuotes::EnglishQ; quotes_times = InsetQuotes::DoubleQ; fontsize = "default"; - textclass = 0; - /* PaperLayout */ + + /* PaperLayout */ papersize = PAPER_DEFAULT; - papersize2 = VM_PAPER_DEFAULT; /* DEFAULT */ - paperpackage = PACKAGE_NONE; + papersize2 = VM_PAPER_DEFAULT; /* DEFAULT */ + paperpackage = PACKAGE_NONE; orientation = ORIENTATION_PORTRAIT; - use_geometry = false; - use_amsmath = false; + use_geometry = false; + use_amsmath = false; + use_natbib = false; + use_numerical_citations = false; secnumdepth = 3; tocdepth = 3; - language = "default"; + language = default_language; fonts = "default"; - inputenc = "latin1"; + inputenc = "auto"; graphicsDriver = "default"; sides = LyXTextClass::OneSide; columns = 1; pagestyle = "default"; - for(int iter = 0; iter < 4; iter++) { - user_defined_bullets[iter] = temp_bullets[iter] - = ITEMIZE_DEFAULTS[iter]; + for (int iter = 0; iter < 4; ++iter) { + user_defined_bullets[iter] = ITEMIZE_DEFAULTS[iter]; + temp_bullets[iter] = ITEMIZE_DEFAULTS[iter]; } - allowAccents=false; } -void BufferParams::Copy(BufferParams const &p) -{ - paragraph_separation = p.paragraph_separation; - defskip = p.defskip; - quotes_language = p.quotes_language; - quotes_times = p.quotes_times; - fontsize = p.fontsize; - textclass = p.textclass; - papersize = p.papersize; - papersize2 = p.papersize2; - paperpackage = p.paperpackage; - orientation = p.orientation; - use_geometry = p.use_geometry; - paperwidth = p.paperwidth; - paperheight = p.paperheight; - leftmargin = p.leftmargin; - topmargin = p.topmargin; - rightmargin = p.rightmargin; - bottommargin = p.bottommargin; - headheight = p.headheight; - headsep = p.headsep; - footskip = p.footskip; - graphicsDriver = p.graphicsDriver; - fonts = p.fonts; - spacing = p.spacing; - secnumdepth = p.secnumdepth; - tocdepth = p.tocdepth; - language = p.language; - inputenc = p.inputenc; - preamble = p.preamble; - options = p.options; - float_placement = p.float_placement; - columns = p.columns; - sides = p.sides; - pagestyle = p.pagestyle; - - // WARNING destructor will deallocate paragraph!! - // this is not good and will cause an error somewhere else. - //paragraph = p.paragraph; - - for (int i = 0; i < 4; ++i) { - temp_bullets[i] = p.temp_bullets[i]; - user_defined_bullets[i] = p.user_defined_bullets[i]; - } - - allowAccents=p.allowAccents; - use_amsmath = p.use_amsmath; -} - - -void BufferParams::writeFile(FILE *file) +void BufferParams::writeFile(ostream & os) const { // The top of the file is written by the buffer. // Prints out the buffer info into the .lyx file given by file // the textclass - fprintf(file, "\\textclass %s\n", - textclasslist.NameOfClass(textclass).c_str()); + os << "\\textclass " << textclasslist.NameOfClass(textclass) << '\n'; // then the the preamble if (!preamble.empty()) { - fprintf(file, "\\begin_preamble\n"); - { - // remove '\n' from the end of preamble - preamble = strip(preamble, '\n'); - - // write out the whole preamble in one go - fwrite(preamble.c_str(), - sizeof(char), - preamble.length(), - file); - fprintf(file, "\n\\end_preamble\n"); - } + // remove '\n' from the end of preamble + string const tmppreamble = strip(preamble, '\n'); + os << "\\begin_preamble\n" + << tmppreamble + << "\n\\end_preamble\n"; } /* the options */ if (!options.empty()) { - fprintf(file, - "\\options %s\n", - options.c_str()); + os << "\\options " << options << '\n'; } - /* then the text parameters */ - fprintf(file, "\\language %s\n", language.c_str()); - fprintf(file, "\\inputencoding %s\n", inputenc.c_str()); - fprintf(file, "\\fontscheme %s\n", fonts.c_str()); - fprintf(file, "\\graphics %s\n", graphicsDriver.c_str()); + /* then the text parameters */ + if (language != ignore_language) + os << "\\language " << language->lang() << '\n'; + os << "\\inputencoding " << inputenc + << "\n\\fontscheme " << fonts + << "\n\\graphics " << graphicsDriver << '\n'; if (!float_placement.empty()) { - fprintf(file, - "\\float_placement %s\n", - float_placement.c_str()); + os << "\\float_placement " << float_placement << '\n'; } - fprintf(file, "\\paperfontsize %s\n", fontsize.c_str()); + os << "\\paperfontsize " << fontsize << '\n'; - spacing.writeFile(file); + spacing.writeFile(os); - fprintf(file, "\\papersize %s\n", string_papersize[papersize2]); - fprintf(file, "\\paperpackage %s\n", - string_paperpackages[paperpackage]); - fprintf(file, "\\use_geometry %d\n",use_geometry); - fprintf(file, "\\use_amsmath %d\n",use_amsmath); - fprintf(file, "\\paperorientation %s\n", - string_orientation[orientation]); + os << "\\papersize " << string_papersize[papersize2] + << "\n\\paperpackage " << string_paperpackages[paperpackage] + << "\n\\use_geometry " << use_geometry + << "\n\\use_amsmath " << use_amsmath + << "\n\\use_natbib " << use_natbib + << "\n\\use_numerical_citations " << use_numerical_citations + << "\n\\paperorientation " << string_orientation[orientation] + << '\n'; if (!paperwidth.empty()) - fprintf(file, "\\paperwidth %s\n", - VSpace(paperwidth).asLyXCommand().c_str()); + os << "\\paperwidth " + << VSpace(paperwidth).asLyXCommand() << '\n'; if (!paperheight.empty()) - fprintf(file, "\\paperheight %s\n", - VSpace(paperheight).asLyXCommand().c_str()); + os << "\\paperheight " + << VSpace(paperheight).asLyXCommand() << '\n'; if (!leftmargin.empty()) - fprintf(file, "\\leftmargin %s\n", - VSpace(leftmargin).asLyXCommand().c_str()); + os << "\\leftmargin " + << VSpace(leftmargin).asLyXCommand() << '\n'; if (!topmargin.empty()) - fprintf(file, "\\topmargin %s\n", - VSpace(topmargin).asLyXCommand().c_str()); + os << "\\topmargin " + << VSpace(topmargin).asLyXCommand() << '\n'; if (!rightmargin.empty()) - fprintf(file, "\\rightmargin %s\n", - VSpace(rightmargin).asLyXCommand().c_str()); + os << "\\rightmargin " + << VSpace(rightmargin).asLyXCommand() << '\n'; if (!bottommargin.empty()) - fprintf(file, "\\bottommargin %s\n", - VSpace(bottommargin).asLyXCommand().c_str()); + os << "\\bottommargin " + << VSpace(bottommargin).asLyXCommand() << '\n'; if (!headheight.empty()) - fprintf(file, "\\headheight %s\n", - VSpace(headheight).asLyXCommand().c_str()); + os << "\\headheight " + << VSpace(headheight).asLyXCommand() << '\n'; if (!headsep.empty()) - fprintf(file, "\\headsep %s\n", - VSpace(headsep).asLyXCommand().c_str()); + os << "\\headsep " + << VSpace(headsep).asLyXCommand() << '\n'; if (!footskip.empty()) - fprintf(file, "\\footskip %s\n", - VSpace(footskip).asLyXCommand().c_str()); - fprintf(file, "\\secnumdepth %d\n", secnumdepth); - fprintf(file, "\\tocdepth %d\n", tocdepth); - fprintf(file, "\\paragraph_separation %s\n", - string_paragraph_separation[paragraph_separation]); - fprintf(file, "\\defskip %s\n", defskip.asLyXCommand().c_str()); - fprintf(file, "\\quotes_language %s\n", - string_quotes_language[quotes_language]); - switch(quotes_times) { - case InsetQuotes::SingleQ: - fprintf(file, "\\quotes_times 1\n"); break; + os << "\\footskip " + << VSpace(footskip).asLyXCommand() << '\n'; + os << "\\secnumdepth " << secnumdepth + << "\n\\tocdepth " << tocdepth + << "\n\\paragraph_separation " + << string_paragraph_separation[paragraph_separation] + << "\n\\defskip " << defskip.asLyXCommand() + << "\n\\quotes_language " + << string_quotes_language[quotes_language] << '\n'; + switch (quotes_times) { + // An output operator for insetquotes would be nice + case InsetQuotes::SingleQ: + os << "\\quotes_times 1\n"; break; case InsetQuotes::DoubleQ: - fprintf(file, "\\quotes_times 2\n"); break; - } - fprintf(file, "\\papercolumns %d\n", columns); - fprintf(file, "\\papersides %d\n", sides); - fprintf(file, "\\paperpagestyle %s\n", pagestyle.c_str()); + os << "\\quotes_times 2\n"; break; + } + os << "\\papercolumns " << columns + << "\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) { - fprintf(file, "\\bullet %d\n\t%d\n\t%d\n\t%d\n\\end_bullet\n", - i, - user_defined_bullets[i].getFont(), - user_defined_bullets[i].getCharacter(), - user_defined_bullets[i].getSize()); + os << "\\bullet " << i + << "\n\t" + << user_defined_bullets[i].getFont() + << "\n\t" + << user_defined_bullets[i].getCharacter() + << "\n\t" + << user_defined_bullets[i].getSize() + << "\n\\end_bullet\n"; } else { - fprintf(file, "\\bulletLaTeX %d\n\t%s\n\\end_bullet\n", - i, - user_defined_bullets[i].c_str()); + os << "\\bulletLaTeX " << i + << "\n\t\"" + << user_defined_bullets[i].getText() + << "\"\n\\end_bullet\n"; } } } } -void BufferParams::useClassDefaults() { +void BufferParams::setPaperStuff() +{ + papersize = PAPER_DEFAULT; + char const c1 = paperpackage; + if (c1 == PACKAGE_NONE) { + char const c2 = papersize2; + if (c2 == VM_PAPER_USLETTER) + papersize = PAPER_USLETTER; + else if (c2 == VM_PAPER_USLEGAL) + papersize = PAPER_LEGALPAPER; + else if (c2 == VM_PAPER_USEXECUTIVE) + papersize = PAPER_EXECUTIVEPAPER; + else if (c2 == VM_PAPER_A3) + papersize = PAPER_A3PAPER; + else if (c2 == VM_PAPER_A4) + papersize = PAPER_A4PAPER; + else if (c2 == VM_PAPER_A5) + papersize = PAPER_A5PAPER; + else if ((c2 == VM_PAPER_B3) || (c2 == VM_PAPER_B4) || + (c2 == VM_PAPER_B5)) + papersize = PAPER_B5PAPER; + } else if ((c1 == PACKAGE_A4) || (c1 == PACKAGE_A4WIDE) || + (c1 == PACKAGE_WIDEMARGINSA4)) + papersize = PAPER_A4PAPER; +} + + +void BufferParams::useClassDefaults() +{ LyXTextClass const & tclass = textclasslist.TextClass(textclass); sides = tclass.sides(); @@ -233,9 +220,22 @@ void BufferParams::useClassDefaults() { } -void BufferParams::readPreamble(LyXLex &lex) +bool BufferParams::hasClassDefaults() const +{ + LyXTextClass const & tclass = textclasslist.TextClass(textclass); + + return (sides == tclass.sides() + && columns == tclass.columns() + && pagestyle == tclass.pagestyle() + && options == tclass.options() + && secnumdepth == tclass.secnumdepth() + && tocdepth == tclass.tocdepth()); +} + + +void BufferParams::readPreamble(LyXLex & lex) { - if (lex.GetString() != "\\begin_preamble") + if (lex.getString() != "\\begin_preamble") lyxerr << "Error (BufferParams::readPreamble):" "consistency check failed." << endl; @@ -243,54 +243,38 @@ void BufferParams::readPreamble(LyXLex &lex) } -void BufferParams::readLanguage(LyXLex &lex) +void BufferParams::readLanguage(LyXLex & lex) { - string tmptok; - string test; - int n = 0; - if (!lex.next()) return; - tmptok = lex.GetString(); + string const tmptok = lex.getString(); + // check if tmptok is part of tex_babel in tex-defs.h - while (true) { - test = tex_babel[n++]; - - if (test == tmptok) { - language = tmptok; - break; - } - else if (test.empty()) { - lyxerr << "Warning: language `" - << tmptok << "' not recognized!\n" - << " Setting language to `default'." - << endl; - language = "default"; - break; - } + language = languages.getLanguage(tmptok); + if (!language) { + // Language tmptok was not found + language = default_language; + lyxerr << "Warning: Setting language `" + << tmptok << "' to `" << language->lang() + << "'." << endl; } } -void BufferParams::readGraphicsDriver(LyXLex &lex) +void BufferParams::readGraphicsDriver(LyXLex & lex) { - string tmptok; - string test; - int n=0; - - if (!lex.next()) return; - tmptok = lex.GetString(); + string const tmptok = lex.getString(); // check if tmptok is part of tex_graphics in tex_defs.h + int n = 0; while (true) { - test = tex_graphics[n++]; + string const test = tex_graphics[n++]; if (test == tmptok) { graphicsDriver = tmptok; break; - } - else if (test == "last_item") { + } else if (test == "last_item") { lex.printError( "Warning: graphics driver `$$Token' not recognized!\n" " Setting graphics driver to `default'.\n");