commit 68d48b0015065f3c3cdd1377678bca56551cc203
Author: Juergen Spitzmueller <[email protected]>
Date:   Wed Aug 22 08:39:13 2018 +0200

    tex2lyx: Fixes to the btUnit import
    
    1. Do not attempt to mix diverging btUnits (e.g., chapters and sections).
    2. use parse_text to properly parse the contents.
---
 src/tex2lyx/Preamble.h |    2 ++
 src/tex2lyx/text.cpp   |    9 ++++++---
 2 files changed, 8 insertions(+), 3 deletions(-)

diff --git a/src/tex2lyx/Preamble.h b/src/tex2lyx/Preamble.h
index 725bf67..804e5ca 100644
--- a/src/tex2lyx/Preamble.h
+++ b/src/tex2lyx/Preamble.h
@@ -82,6 +82,8 @@ public:
        ///
        void citeEngine(std::string const & e) { h_cite_engine = e; }
        ///
+       std::string multibib() const { return h_multibib; }
+       ///
        void multibib(std::string const & s) { h_multibib = s; }
        ///
        bool titleLayoutFound() const { return title_layout_found; }
diff --git a/src/tex2lyx/text.cpp b/src/tex2lyx/text.cpp
index c39f928..5bc0e99 100644
--- a/src/tex2lyx/text.cpp
+++ b/src/tex2lyx/text.cpp
@@ -1925,9 +1925,12 @@ void parse_environment(Parser & p, ostream & os, bool 
outer,
 
        else if (name == "btUnit") {
                string const nt = p.next_next_token().cs();
-               if (nt == "part" || nt == "chapter"
-                  || nt == "section" || nt == "subsection") {
-                       active_environments.push_back("btUnit");
+               // Do not attempt to overwrite a former diverging multibib.
+               // Those are output as ERT instead.
+               if ((nt == "part" || nt == "chapter"
+                    || nt == "section" || nt == "subsection")
+                  && (preamble.multibib().empty() || preamble.multibib() == 
nt)) {
+                       parse_text(p, os, FLAG_END, outer, parent_context);
                        preamble.multibib(nt);
                } else
                        parse_unknown_environment(p, name, os, FLAG_END, outer,

Reply via email to