do not define macro \LyX if we do not need it; small things

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@4724 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Jean-Marc Lasgouttes 2002-07-20 16:42:15 +00:00
parent 7086f52fc8
commit 3d5734b98f
8 changed files with 132 additions and 93 deletions

View File

@ -1,5 +1,13 @@
2002-07-20 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr> 2002-07-20 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>
* version.C.in: update lyx_docversion
* LaTeXFeatures.C (getMacros): only define \LyX when needed
* paragraph.C (validate): remove from here...
* paragraph_pimpl.C (validate): ... and move here
(isTextAt): make it const
* buffer.C (getLists): ws cleanup * buffer.C (getLists): ws cleanup
2002-07-20 Dekel Tsur <dekelts@tau.ac.il> 2002-07-20 Dekel Tsur <dekelts@tau.ac.il>

View File

@ -265,8 +265,7 @@ string const LaTeXFeatures::getMacros() const
{ {
ostringstream macros; ostringstream macros;
// always include this if (isRequired("LyX"))
if (true || isRequired("lyx"))
macros << lyx_def << '\n'; macros << lyx_def << '\n';
if (isRequired("lyxline")) if (isRequired("lyxline"))

View File

@ -1,5 +1,8 @@
2002-07-20 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr> 2002-07-20 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>
* PreviewLoader.C (startLoading): pass an interger as resolution
to the lyxpreview converter
* GraphicsParams.C: include <cstdlib> * GraphicsParams.C: include <cstdlib>
2002-07-19 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr> 2002-07-19 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>

View File

@ -465,7 +465,7 @@ void PreviewLoader::Impl::startLoading()
// The conversion command. // The conversion command.
ostringstream cs; ostringstream cs;
cs << pconverter_->command << " " << latexfile << " " cs << pconverter_->command << " " << latexfile << " "
<< font_scaling_factor_; << int(font_scaling_factor_);
string const command = LibScriptSearch(cs.str().c_str()); string const command = LibScriptSearch(cs.str().c_str());

View File

@ -23,7 +23,6 @@
#include "buffer.h" #include "buffer.h"
#include "bufferparams.h" #include "bufferparams.h"
#include "debug.h" #include "debug.h"
#include "LaTeXFeatures.h"
#include "texrow.h" #include "texrow.h"
#include "BufferView.h" #include "BufferView.h"
#include "encoding.h" #include "encoding.h"
@ -332,78 +331,7 @@ void Paragraph::writeFile(Buffer const * buf, ostream & os,
void Paragraph::validate(LaTeXFeatures & features) const void Paragraph::validate(LaTeXFeatures & features) const
{ {
BufferParams const & bparams = features.bufferParams(); pimpl_->validate(features, *layout());
// check the params.
if (params().lineTop() || params().lineBottom())
features.require("lyxline");
if (!params().spacing().isDefault())
features.require("setspace");
// then the layouts
features.useLayout(layout()->name());
// then the fonts
Language const * doc_language = bparams.language;
Pimpl::FontList::const_iterator fcit = pimpl_->fontlist.begin();
Pimpl::FontList::const_iterator fend = pimpl_->fontlist.end();
for (; fcit != fend; ++fcit) {
if (fcit->font().noun() == LyXFont::ON) {
lyxerr[Debug::LATEX] << "font.noun: "
<< fcit->font().noun()
<< endl;
features.require("noun");
lyxerr[Debug::LATEX] << "Noun enabled. Font: "
<< fcit->font().stateText(0)
<< endl;
}
switch (fcit->font().color()) {
case LColor::none:
case LColor::inherit:
case LColor::ignore:
// probably we should put here all interface colors used for
// font displaying! For now I just add this ones I know of (Jug)
case LColor::latex:
case LColor::note:
break;
default:
features.require("color");
lyxerr[Debug::LATEX] << "Color enabled. Font: "
<< fcit->font().stateText(0)
<< endl;
}
Language const * language = fcit->font().language();
if (language->babel() != doc_language->babel() &&
language != ignore_language &&
#ifdef INHERIT_LANGUAGE
language != inherit_language &&
#endif
language != latex_language)
{
features.useLanguage(language);
lyxerr[Debug::LATEX] << "Found language "
<< language->babel() << endl;
}
}
if (!params().leftIndent().zero())
features.require("ParagraphLeftIndent");
// then the insets
LyXLayout_ptr const & lout = layout();
InsetList::const_iterator icit = insetlist.begin();
InsetList::const_iterator iend = insetlist.end();
for (; icit != iend; ++icit) {
if (icit->inset) {
icit->inset->validate(features);
if (lout->needprotect &&
icit->inset->lyxCode() == Inset::FOOT_CODE)
features.require("NeedLyXFootnoteCode");
}
}
} }

View File

@ -15,6 +15,7 @@
#endif #endif
#include "paragraph_pimpl.h" #include "paragraph_pimpl.h"
#include "LaTeXFeatures.h"
#include "texrow.h" #include "texrow.h"
#include "language.h" #include "language.h"
#include "bufferparams.h" #include "bufferparams.h"
@ -41,14 +42,20 @@ unsigned int Paragraph::Pimpl::paragraph_id = 0;
namespace { namespace {
string special_phrases[][2] = { struct special_phrase {
{ "LyX", "\\LyX{}" }, string phrase;
{ "TeX", "\\TeX{}" }, string macro;
{ "LaTeX2e", "\\LaTeXe{}" }, bool builtin;
{ "LaTeX", "\\LaTeX{}" }, };
};
special_phrase special_phrases[] = {
{ "LyX", "\\LyX{}", false },
{ "TeX", "\\TeX{}", true },
{ "LaTeX2e", "\\LaTeXe{}", true },
{ "LaTeX", "\\LaTeX{}", true },
};
size_t phrases_nr = sizeof(special_phrases)/sizeof(special_phrases[0]); size_t phrases_nr = sizeof(special_phrases)/sizeof(special_phrase);
} // namespace anon } // namespace anon
@ -275,7 +282,7 @@ void Paragraph::Pimpl::simpleTeXBlanks(ostream & os, TexRow & texrow,
} }
bool Paragraph::Pimpl::isTextAt(string const & str, pos_type pos) bool Paragraph::Pimpl::isTextAt(string const & str, pos_type pos) const
{ {
pos_type const len = str.length(); pos_type const len = str.length();
@ -511,17 +518,19 @@ void Paragraph::Pimpl::simpleTeXSpecialChars(Buffer const * buf,
// LyX, LaTeX etc. // LyX, LaTeX etc.
// FIXME: if we have "LaTeX" with a font change in the middle (before // FIXME: if we have "LaTeX" with a font
// the 'T', then the "TeX" part is still special cased. Really we // change in the middle (before the 'T', then
// should only operate this on "words" for some definition of word // the "TeX" part is still special cased.
// Really we should only operate this on
// "words" for some definition of word
size_t pnr = 0; size_t pnr = 0;
for (; pnr < phrases_nr; ++pnr) { for (; pnr < phrases_nr; ++pnr) {
if (isTextAt(special_phrases[pnr][0], i)) { if (isTextAt(special_phrases[pnr].phrase, i)) {
os << special_phrases[pnr][1]; os << special_phrases[pnr].macro;
i += special_phrases[pnr][0].length() - 1; i += special_phrases[pnr].phrase.length() - 1;
column += special_phrases[pnr][1].length() - 1; column += special_phrases[pnr].macro.length() - 1;
break; break;
} }
} }
@ -558,6 +567,93 @@ Paragraph * Paragraph::Pimpl::TeXDeeper(Buffer const * buf,
} }
void Paragraph::Pimpl::validate(LaTeXFeatures & features,
LyXLayout const & layout) const
{
BufferParams const & bparams = features.bufferParams();
// check the params.
if (params.lineTop() || params.lineBottom())
features.require("lyxline");
if (!params.spacing().isDefault())
features.require("setspace");
// then the layouts
features.useLayout(layout.name());
// then the fonts
Language const * doc_language = bparams.language;
FontList::const_iterator fcit = fontlist.begin();
FontList::const_iterator fend = fontlist.end();
for (; fcit != fend; ++fcit) {
if (fcit->font().noun() == LyXFont::ON) {
lyxerr[Debug::LATEX] << "font.noun: "
<< fcit->font().noun()
<< endl;
features.require("noun");
lyxerr[Debug::LATEX] << "Noun enabled. Font: "
<< fcit->font().stateText(0)
<< endl;
}
switch (fcit->font().color()) {
case LColor::none:
case LColor::inherit:
case LColor::ignore:
// probably we should put here all interface colors used for
// font displaying! For now I just add this ones I know of (Jug)
case LColor::latex:
case LColor::note:
break;
default:
features.require("color");
lyxerr[Debug::LATEX] << "Color enabled. Font: "
<< fcit->font().stateText(0)
<< endl;
}
Language const * language = fcit->font().language();
if (language->babel() != doc_language->babel() &&
language != ignore_language &&
#ifdef INHERIT_LANGUAGE
language != inherit_language &&
#endif
language != latex_language)
{
features.useLanguage(language);
lyxerr[Debug::LATEX] << "Found language "
<< language->babel() << endl;
}
}
if (!params.leftIndent().zero())
features.require("ParagraphLeftIndent");
// then the insets
InsetList::const_iterator icit = owner_->insetlist.begin();
InsetList::const_iterator iend = owner_->insetlist.end();
for (; icit != iend; ++icit) {
if (icit->inset) {
icit->inset->validate(features);
if (layout.needprotect &&
icit->inset->lyxCode() == Inset::FOOT_CODE)
features.require("NeedLyXFootnoteCode");
}
}
// then the contents
for (pos_type i = 0; i < size() ; ++i) {
for (size_t pnr = 0; pnr < phrases_nr; ++pnr) {
if (!special_phrases[pnr].builtin
&& isTextAt(special_phrases[pnr].phrase, i)) {
features.require(special_phrases[pnr].phrase);
break;
}
}
}
}
Paragraph * Paragraph::Pimpl::getParFromID(int id) const Paragraph * Paragraph::Pimpl::getParFromID(int id) const
{ {
InsetList::const_iterator cit = owner_->insetlist.begin(); InsetList::const_iterator cit = owner_->insetlist.begin();

View File

@ -141,6 +141,11 @@ struct Paragraph::Pimpl {
LyXLayout const & style, LyXLayout const & style,
lyx::pos_type & i, lyx::pos_type & i,
int & column, value_type const c); int & column, value_type const c);
///
void validate(LaTeXFeatures & features,
LyXLayout const & layout) const;
/// ///
Paragraph * getParFromID(int id) const; Paragraph * getParFromID(int id) const;
/// ///
@ -151,7 +156,7 @@ struct Paragraph::Pimpl {
ParagraphParameters params; ParagraphParameters params;
private: private:
/// match a string against a particular point in the paragraph /// match a string against a particular point in the paragraph
bool isTextAt(string const & str, lyx::pos_type pos); bool isTextAt(string const & str, lyx::pos_type pos) const;
/// Who owns us? /// Who owns us?
Paragraph * owner_; Paragraph * owner_;

View File

@ -16,7 +16,7 @@ char const * lyx_version = "@VERSION@";
char const * lyx_release_date = "Fri, May 3, 2002"; char const * lyx_release_date = "Fri, May 3, 2002";
/// This version string is intended to be used in files created by LyX /// This version string is intended to be used in files created by LyX
char const * lyx_docversion = "LyX 1.2"; char const * lyx_docversion = "LyX 1.3";
/// This is the version information shown by 'lyx -version' /// This is the version information shown by 'lyx -version'
char const * lyx_version_info = "@VERSION_INFO@"; char const * lyx_version_info = "@VERSION_INFO@";