mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-12-14 01:22:33 +00:00
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:
parent
1bde292bee
commit
4ef3356020
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user