commit 633013453eea56467b50869a355849c46a39a3a3
Author: Juergen Spitzmueller <[email protected]>
Date:   Sun Oct 31 09:26:57 2021 +0100

    Factor out Paragraph::isPartOfTextSequence
    
    Amends 045c25cf76
---
 src/Paragraph.cpp |   27 ++++++++++++++-------------
 src/Paragraph.h   |    2 ++
 2 files changed, 16 insertions(+), 13 deletions(-)

diff --git a/src/Paragraph.cpp b/src/Paragraph.cpp
index dc4be43..709507b 100644
--- a/src/Paragraph.cpp
+++ b/src/Paragraph.cpp
@@ -2268,6 +2268,16 @@ bool Paragraph::isPassThru() const
        return inInset().isPassThru() || d->layout_->pass_thru;
 }
 
+
+bool Paragraph::isPartOfTextSequence() const
+{
+       for (pos_type i = 0; i < size(); ++i) {
+               if (!isInset(i) || getInset(i)->isPartOfTextSequence())
+                       return true;
+       }
+       return false;
+}
+
 namespace {
 
 // paragraphs inside floats need different alignment tags to avoid
@@ -2339,21 +2349,12 @@ int Paragraph::Private::startTeXParParams(BufferParams 
const & bparams,
                        (layout_->toggle_indent != ITOGGLE_NEVER) :
                        (layout_->toggle_indent == ITOGGLE_ALWAYS);
 
-       // Paragraphs that only contain insets which are not part of the text 
sequence
-       // (e.g., floats) should not get \\noindent (this would cause extra 
white space)
-       bool emptypar = true;
-       if (canindent) {
-               for (pos_type i = 0; i < owner_->size(); ++i) {
-                       if (!owner_->isInset(i) || 
owner_->getInset(i)->isPartOfTextSequence()) {
-                               emptypar = false;
-                               break;
-                       }
-               }
-       }
-
        LyXAlignment const curAlign = params_.align();
 
-       if (canindent && !emptypar && params_.noindent()
+       // Do not output \\noindent for paragraphs that are not part of the
+       // immediate text sequence (e.g., contain only floats), that cannot
+       // have indentation, that are PassThru or centered.
+       if (canindent && params_.noindent() && owner_->isPartOfTextSequence()
            && !layout_->pass_thru && curAlign != LYX_ALIGN_CENTER) {
                os << "\\noindent ";
                column += 10;
diff --git a/src/Paragraph.h b/src/Paragraph.h
index 67f41dd..d6e4a76 100644
--- a/src/Paragraph.h
+++ b/src/Paragraph.h
@@ -239,6 +239,8 @@ public:
        ///
        bool isPassThru() const;
        ///
+       bool isPartOfTextSequence() const;
+       ///
        pos_type size() const;
        ///
        bool empty() const;
-- 
lyx-cvs mailing list
[email protected]
http://lists.lyx.org/mailman/listinfo/lyx-cvs

Reply via email to