branch: tex2lyx/preamble.cpp:

- don't assume any longer LyX specific commands from their position in TeX files and a comment (fixes bugs in the preamble handling and makes the tex2lyx testfiles compilable after importing)


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/BRANCH_1_6_X@30167 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Uwe Stöhr 2009-06-18 23:55:49 +00:00
parent 1bde292bee
commit 4ef3356020

View File

@ -101,6 +101,27 @@ const char * const known_coded_paper_margins[] = { "leftmargin", "topmargin",
"rightmargin", "bottommargin", "headheight", "headsep", "footskip", "rightmargin", "bottommargin", "headheight", "headsep", "footskip",
"columnsep", 0}; "columnsep", 0};
const char * const known_lyx_commands[] = { "binom", "cedilla", "cyrtext",
"dacute", "dgrave", "docedilla", "doogonek", "dosubhat", "dosubring",
"dosubtilde", "greektext", "guillemotleft", "guillemotright", "guilsinglleft",
"guilsinglright", "LyX", "lyxadded", "lyxarrow", "lyxdeleted", "lyxdot",
"lyxgreyedout", "lyxline", "lyxmathsym", "LyXParagraphLeftIndent",
"lyxrightaddress", "makenomenclature", "mathcircumflex", "noun", "ogonek",
"printnomenclature", "quotedblbase", "quotesinglbase", "rcap", "subhat",
"subring", "subtilde", "tabularnewline", "textcyr", "textgreek", 0};
const char * const known_lyx_comments[] = {
"%% Binom macro for standard LaTeX users\n",
"%% For printing a cirumflex inside a formula\n",
"%% Because html converters don't know tabularnewline\n",
"%% The greyedout annotation environment\n",
"%% A simple dot to overcome graphicx limitations\n",
"%% Change tracking with ulem\n",
"% the following is useful when we have the old nomencl.sty package\n",
"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% LyX specific LaTeX commands.\n",
"%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% User specified LaTeX commands.\n",
0};
// default settings // default settings
ostringstream h_preamble; ostringstream h_preamble;
string h_textclass = "article"; string h_textclass = "article";
@ -249,8 +270,7 @@ string const scale_as_percentage(string const & scale)
} }
void handle_package(Parser &p, string const & name, string const & opts, void handle_package(Parser &p, string const & name, string const & opts)
bool in_lyx_preamble)
{ {
vector<string> options = split_options(opts); vector<string> options = split_options(opts);
add_package(name, options); add_package(name, options);
@ -424,7 +444,10 @@ void handle_package(Parser &p, string const & name, string const & opts,
else if (name == "jurabib") else if (name == "jurabib")
h_cite_engine = "jurabib"; h_cite_engine = "jurabib";
else if (!in_lyx_preamble) { else if (name == "babel")
; // ignore this
else {
if (options.empty()) if (options.empty())
h_preamble << "\\usepackage{" << name << "}"; h_preamble << "\\usepackage{" << name << "}";
else { else {
@ -501,8 +524,7 @@ void parse_preamble(Parser & p, ostream & os,
// initialize fixed types // initialize fixed types
special_columns['D'] = 3; special_columns['D'] = 3;
bool is_full_document = false; bool is_full_document = false;
bool is_lyx_file = false; bool lyx_specific_preamble = false;
bool in_lyx_preamble = false;
// determine whether this is a full document or a fragment for inclusion // determine whether this is a full document or a fragment for inclusion
while (p.good()) { while (p.good()) {
@ -525,8 +547,7 @@ void parse_preamble(Parser & p, ostream & os,
// //
// cat codes // cat codes
// //
if (!in_lyx_preamble && if ((t.cat() == catLetter ||
(t.cat() == catLetter ||
t.cat() == catSuper || t.cat() == catSuper ||
t.cat() == catSub || t.cat() == catSub ||
t.cat() == catOther || t.cat() == catOther ||
@ -538,17 +559,12 @@ void parse_preamble(Parser & p, ostream & os,
t.cat() == catParameter)) t.cat() == catParameter))
h_preamble << t.character(); h_preamble << t.character();
else if (!in_lyx_preamble && else if (t.cat() == catSpace || t.cat() == catNewline)
(t.cat() == catSpace || t.cat() == catNewline))
h_preamble << t.asInput(); h_preamble << t.asInput();
else if (t.cat() == catComment) { else if (t.cat() == catComment) {
// regex to parse comments // regex to parse comments
static regex const islyxfile("%% LyX .* created this file");
static regex const usercommands("User specified LaTeX commands");
string const comment = t.asInput(); string const comment = t.asInput();
// magically switch encoding default if it looks like XeLaTeX // magically switch encoding default if it looks like XeLaTeX
static string const magicXeLaTeX = static string const magicXeLaTeX =
"% This document must be compiled with XeLaTeX "; "% This document must be compiled with XeLaTeX ";
@ -558,15 +574,9 @@ void parse_preamble(Parser & p, ostream & os,
cerr << "XeLaTeX comment found, switching to UTF8\n"; cerr << "XeLaTeX comment found, switching to UTF8\n";
h_inputencoding = "utf8"; h_inputencoding = "utf8";
} }
smatch sub; smatch sub;
if (regex_search(comment, sub, islyxfile)) { // don't output LyX specific comments
is_lyx_file = true; if (!is_known(comment, known_lyx_comments))
in_lyx_preamble = true;
} else if (is_lyx_file
&& regex_search(comment, sub, usercommands))
in_lyx_preamble = false;
else if (!in_lyx_preamble)
h_preamble << t.asInput(); h_preamble << t.asInput();
} }
@ -574,21 +584,20 @@ void parse_preamble(Parser & p, ostream & os,
h_paperpagestyle = p.verbatim_item(); h_paperpagestyle = p.verbatim_item();
else if (t.cs() == "makeatletter") { else if (t.cs() == "makeatletter") {
if (!is_lyx_file || !in_lyx_preamble // LyX takes care of this
|| p.getCatCode('@') != catLetter)
h_preamble << "\\makeatletter";
p.setCatCode('@', catLetter); p.setCatCode('@', catLetter);
} }
else if (t.cs() == "makeatother") { else if (t.cs() == "makeatother") {
if (!is_lyx_file || !in_lyx_preamble // LyX takes care of this
|| p.getCatCode('@') != catOther)
h_preamble << "\\makeatother";
p.setCatCode('@', catOther); p.setCatCode('@', catOther);
} }
else if (t.cs() == "newcommand" || t.cs() == "renewcommand" else if (t.cs() == "newcommand" || t.cs() == "renewcommand"
|| t.cs() == "providecommand") { || t.cs() == "providecommand"
|| t.cs() == "DeclareRobustCommand"
|| t.cs() == "ProvideTextCommandDefault"
|| t.cs() == "DeclareMathAccent") {
bool star = false; bool star = false;
if (p.next_token().character() == '*') { if (p.next_token().character() == '*') {
p.get_token(); p.get_token();
@ -613,8 +622,17 @@ void parse_preamble(Parser & p, ostream & os,
// remove leading "\" // remove leading "\"
h_font_default_family = family.erase(0,1); h_font_default_family = family.erase(0,1);
} }
// LyX specific commands that will automatically be set by LyX
string lyx_command = name;
// remove the leading "\"
lyx_command.erase(0,1);
lyx_specific_preamble = false;
// allow redefinitions of LyX specific commands
if (is_known(lyx_command, known_lyx_commands)
&& (t.cs() != "renewcommand"))
lyx_specific_preamble = true;
// only non-lyxspecific stuff // only non-lyxspecific stuff
if (!in_lyx_preamble) { if (!lyx_specific_preamble) {
ostringstream ss; ostringstream ss;
ss << '\\' << t.cs(); ss << '\\' << t.cs();
if (star) if (star)
@ -702,8 +720,7 @@ void parse_preamble(Parser & p, ostream & os,
vector<string>::const_iterator it = vecnames.begin(); vector<string>::const_iterator it = vecnames.begin();
vector<string>::const_iterator end = vecnames.end(); vector<string>::const_iterator end = vecnames.end();
for (; it != end; ++it) for (; it != end; ++it)
handle_package(p, trim(*it), options, handle_package(p, trim(*it), options);
in_lyx_preamble);
} }
else if (t.cs() == "inputencoding") { else if (t.cs() == "inputencoding") {
@ -721,7 +738,7 @@ void parse_preamble(Parser & p, ostream & os,
ss << p.getOpt(); ss << p.getOpt();
ss << '{' << p.verbatim_item() << '}'; ss << '{' << p.verbatim_item() << '}';
ss << '{' << p.verbatim_item() << '}'; ss << '{' << p.verbatim_item() << '}';
if (!in_lyx_preamble) if (!is_known(name, known_lyx_commands))
h_preamble << ss.str(); h_preamble << ss.str();
} }
@ -729,7 +746,7 @@ void parse_preamble(Parser & p, ostream & os,
string name = p.get_token().cs(); string name = p.get_token().cs();
while (p.next_token().cat() != catBegin) while (p.next_token().cat() != catBegin)
name += p.get_token().asString(); name += p.get_token().asString();
if (!in_lyx_preamble) if (!is_known(name, known_lyx_commands))
h_preamble << "\\def\\" << name << '{' h_preamble << "\\def\\" << name << '{'
<< p.verbatim_item() << "}"; << p.verbatim_item() << "}";
} }
@ -837,7 +854,7 @@ void parse_preamble(Parser & p, ostream & os,
} }
} }
else if (!t.cs().empty() && !in_lyx_preamble) else if (!t.cs().empty())
h_preamble << '\\' << t.cs(); h_preamble << '\\' << t.cs();
// remove the whitespace // remove the whitespace