mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-03 00:20:43 +00:00
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:
parent
7086f52fc8
commit
3d5734b98f
@ -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>
|
||||||
|
@ -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"))
|
||||||
|
@ -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>
|
||||||
|
@ -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());
|
||||||
|
|
||||||
|
@ -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");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
@ -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_;
|
||||||
|
@ -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@";
|
||||||
|
Loading…
Reference in New Issue
Block a user