]> git.lyx.org Git - features.git/blobdiff - src/Paragraph.cpp
Find: Renamend for_searchAdv to for_serach in src/OutputParams.h
[features.git] / src / Paragraph.cpp
index e37a123823e3e828df7084eeacf6c400cf0d9b3f..434e515ccb8101296b9d5492fbe65915ddf42b45 100644 (file)
@@ -1209,10 +1209,10 @@ void Paragraph::Private::latexSpecialChar(otexstream & os,
 {
        char_type const c = owner_->getUChar(bparams, runparams, i);
 
-       if (style.pass_thru || runparams.pass_thru || (runparams.for_searchAdv != OutputParams::NoSearch)
+       if (style.pass_thru || runparams.pass_thru || (runparams.for_search != OutputParams::NoSearch)
            || contains(style.pass_thru_chars, c)
            || contains(runparams.pass_thru_chars, c)) {
-               if (runparams.for_searchAdv != OutputParams::NoSearch) {
+               if (runparams.for_search != OutputParams::NoSearch) {
                        if (c == '\\')
                                os << "\\\\";
                        else if (c == '{')
@@ -2640,10 +2640,10 @@ void Paragraph::latex(BufferParams const & bparams,
 
                // Check whether a display math inset follows
                bool output_changes;
-               if (runparams.for_searchAdv == OutputParams::NoSearch)
+               if (runparams.for_search == OutputParams::NoSearch)
                        output_changes = bparams.output_changes;
                else
-                       output_changes = ((runparams.for_searchAdv & OutputParams::SearchWithDeleted) != 0);
+                       output_changes = ((runparams.for_search & OutputParams::SearchWithDeleted) != 0);
                if (c == META_INSET
                    && i >= start_pos && (end_pos == -1 || i < end_pos)) {
                        if (isDeleted(i))
@@ -4560,32 +4560,6 @@ void Paragraph::changeCase(BufferParams const & bparams, pos_type pos,
        }
 }
 
-static char_type matchquote(char_type in)
-{
-       switch (in) {
-               case 0x2018:    // Left Single Quotation Mark
-               case 0x2019:    // Right Single Quotation Mark
-               case 0x201a:    // Single Low-9 Quotation Mark
-               case 0x201b:    // Single High-Reversed-9 Quotation Mark 
-               case 0x2039:    // Single Left-Pointing Angle Quotation Mark
-               case 0x203a:    // Single Right-Pointing Angle Quotation Mark
-                       return '\'';
-               case 0x00bb:    // Right-Pointing Double Angle Quotation Mark
-               case 0x00ab:    // Left-Pointing Double Angle Quotation Mark
-               case 0x201e:    // Double Low-9 Quotation Mark 
-               case 0x201c:    // Left Double Quotation Mark 
-               case 0x201d:    // Right Double Quotation Mark 
-               case 0x201f:    // Double High-Reversed-9 Quotation Mark 
-               case 0x2e42:    // Double Low-Reversed-9 Quotation Mark
-               case 0x301e:    // Double Prime Quotation Mark
-               case 0x301d:    // Reversed Double Prime Quotation Mark
-               case 0x301f:    // Low Double Prime Quotation Mark
-                       return '"';
-               default:
-                       return in;
-       }
-}
-
 int Paragraph::find(docstring const & str, bool cs, bool mw,
                pos_type start_pos, bool del) const
 {
@@ -4610,14 +4584,20 @@ int Paragraph::find(docstring const & str, bool cs, bool mw,
                        if (!inset->isLetter() && !inset->isChar())
                                break;
                        odocstringstream os;
-                       inset->toString(os);
+                       if (inset->lyxCode() == lyx::QUOTE_CODE) {
+                               OutputParams op(0);
+                               op.for_search = OutputParams::SearchQuick;
+                               inset->plaintext(os, op);
+                       }
+                       else {
+                               inset->toString(os);
+                       }
                        docstring const insetstring = os.str();
                        if (!insetstring.empty()) {
                                int const insetstringsize = insetstring.length();
                                for (int j = 0; j < insetstringsize && pos < parsize; ++i, ++j) {
-                                       char_type ij = matchquote(insetstring[j]);
-                                       if ((cs && str[i] != ij)
-                                           || (!cs && uppercase(str[i]) != uppercase(ij))) {
+                                       if ((cs && str[i] != insetstring[j])
+                                           || (!cs && uppercase(str[i]) != uppercase(insetstring[j]))) {
                                                nonmatch = true;
                                                break;
                                        }
@@ -4627,7 +4607,7 @@ int Paragraph::find(docstring const & str, bool cs, bool mw,
                }
                if (nonmatch || i == strsize)
                        break;
-               char_type dp = matchquote(d->text_[pos]);
+               char_type dp = d->text_[pos];
                if (cs && str[i] != dp)
                        break;
                if (!cs && uppercase(str[i]) != uppercase(dp))