Author: tommaso
Date: Thu May 26 18:54:51 2011
New Revision: 38845
URL: http://www.lyx.org/trac/changeset/38845

Log:
(Replaying r38819 from trunk)

Addressing #7581: now I'm copying the document class as well
from the main document WA to the find/replace WAs (in addition
to the language, as required for addressing #6560).
I'm not cloning the whole BufferParams? because we learned
from

    http://www.mail-archive.com/[email protected]/msg168175.html

that, for example, if we inherit the default master by mistake,
then we may run into problems.

Modified:
   lyx-devel/branches/BRANCH_2_0_X/src/frontends/qt4/FindAndReplace.cpp

Modified: lyx-devel/branches/BRANCH_2_0_X/src/frontends/qt4/FindAndReplace.cpp
==============================================================================
--- lyx-devel/branches/BRANCH_2_0_X/src/frontends/qt4/FindAndReplace.cpp        
Thu May 26 18:01:16 2011        (r38844)
+++ lyx-devel/branches/BRANCH_2_0_X/src/frontends/qt4/FindAndReplace.cpp        
Thu May 26 18:54:51 2011        (r38845)
@@ -21,6 +21,7 @@
 
 #include "BufferParams.h"
 #include "BufferList.h"
+#include "TextClass.h"
 #include "Cursor.h"
 #include "FuncRequest.h"
 #include "lyxfind.h"
@@ -468,24 +469,28 @@
 }
 
 
+/** Copy selected elements from bv's BufferParams to the dest_bv's one
+ ** We don't want to copy'em all, e.g., not the default master **/
+static void copy_params(BufferView const & bv, BufferView & dest_bv) {
+       Buffer const & doc_buf = bv.buffer();
+       BufferParams const & doc_bp = doc_buf.params();
+       string const & lang = doc_bp.language->lang();
+       string const & doc_class = doc_bp.documentClass().name();
+       Buffer & dest_buf = dest_bv.buffer();
+       dest_buf.params().setLanguage(lang);
+       dest_buf.params().setBaseClass(doc_class);
+       dest_buf.params().makeDocumentClass();
+       dest_bv.cursor().current_font.setLanguage(doc_bp.language);
+}
+
+
 void FindAndReplaceWidget::showEvent(QShowEvent * /* ev */)
 {
        LYXERR(Debug::DEBUG, "showEvent()" << endl);
        BufferView * bv = view_.documentBufferView();
        if (bv) {
-               Buffer & doc_buf = bv->buffer();
-               BufferParams & doc_bp = doc_buf.params();
-               string const & lang = doc_bp.language->lang();
-               Buffer & find_buf = find_work_area_->bufferView().buffer();
-               LYXERR(Debug::FIND, "Applying document params to find buffer");
-               find_buf.params().setLanguage(lang);
-               Buffer & replace_buf = 
replace_work_area_->bufferView().buffer();
-               LYXERR(Debug::FIND, "Applying document params to replace 
buffer");
-               replace_buf.params().setLanguage(lang);
-
-               LYXERR(Debug::FIND, "Setting current editing language to " << 
lang << endl);
-               
find_work_area_->bufferView().cursor().current_font.setLanguage(doc_bp.language);
-               
replace_work_area_->bufferView().cursor().current_font.setLanguage(doc_bp.language);
+               copy_params(*bv, find_work_area_->bufferView());
+               copy_params(*bv, replace_work_area_->bufferView());
        }
 
        find_work_area_->installEventFilter(this);

Reply via email to