The string we parse as name may contain backslashes if \csname ... \endcsname
is used. Therefore we have to output it using asInput() instead of cs().
This commit is contained in:
Georg Baum 2012-05-13 18:41:51 +02:00
parent bba0c9aa22
commit 72023030d9

View File

@ -1269,8 +1269,12 @@ void Preamble::parse(Parser & p, string const & forceclass,
else if (t.cs() == "def") { else if (t.cs() == "def") {
string name = p.get_token().cs(); string name = p.get_token().cs();
// In fact, name may be more than the name:
// In the test case of bug 8116
// name == "csname SF@gobble@opt \endcsname".
// Therefore, we need to use asInput() instead of cs().
while (p.next_token().cat() != catBegin) while (p.next_token().cat() != catBegin)
name += p.get_token().cs(); name += p.get_token().asInput();
if (!in_lyx_preamble) if (!in_lyx_preamble)
h_preamble << "\\def\\" << name << '{' h_preamble << "\\def\\" << name << '{'
<< p.verbatim_item() << "}"; << p.verbatim_item() << "}";