]> git.lyx.org Git - features.git/commitdiff
Case-insensitive reference sorting.
authorPavel Sanda <sanda@lyx.org>
Tue, 24 Feb 2009 22:56:57 +0000 (22:56 +0000)
committerPavel Sanda <sanda@lyx.org>
Tue, 24 Feb 2009 22:56:57 +0000 (22:56 +0000)
Patch from Manoj Rajagopalan.
http://www.mail-archive.com/lyx-devel@lists.lyx.org/msg147931.html

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@28593 a592a061-630c-0410-9148-cb99ea01b6c8

src/frontends/qt4/GuiRef.cpp
src/frontends/qt4/GuiRef.h
src/frontends/qt4/ui/RefUi.ui

index d344ab64faaa77255f82ef56983b4a238cb9e2c5..c63cc80dbf34db47319b09ef7396f3630281e7c3 100644 (file)
@@ -57,6 +57,8 @@ GuiRef::GuiRef(GuiView & lv)
        // Enabling is set in updateRefs. Disable for now in case no
        // call to updateContents follows (e.g. read-only documents).
        sortCB->setEnabled(false);
+       caseSensitiveCB->setEnabled(false);
+       caseSensitiveCB->setChecked(false);
        refsLW->setEnabled(false);
        gotoPB->setEnabled(false);
 
@@ -80,6 +82,8 @@ GuiRef::GuiRef(GuiView & lv)
                this, SLOT(refSelected(QListWidgetItem *)));
        connect(sortCB, SIGNAL(clicked()),
                this, SLOT(sortToggled()));
+       connect(caseSensitiveCB, SIGNAL(clicked()),
+               this, SLOT(caseSensitiveToggled()));
        connect(gotoPB, SIGNAL(clicked()),
                this, SLOT(gotoClicked()));
        connect(updatePB, SIGNAL(clicked()),
@@ -93,6 +97,7 @@ GuiRef::GuiRef(GuiView & lv)
        bc().setCancel(closePB);
        bc().addReadOnly(refsLW);
        bc().addReadOnly(sortCB);
+       bc().addReadOnly(caseSensitiveCB);
        bc().addReadOnly(nameED);
        bc().addReadOnly(referenceED);
        bc().addReadOnly(typeCO);
@@ -170,6 +175,13 @@ void GuiRef::refSelected(QListWidgetItem * sel)
 
 
 void GuiRef::sortToggled()
+{
+       caseSensitiveCB->setEnabled(sortCB->isChecked());
+       redoRefs();
+}
+
+
+void GuiRef::caseSensitiveToggled()
 {
        redoRefs();
 }
@@ -306,6 +318,11 @@ void GuiRef::gotoRef()
        at_ref_ = !at_ref_;
 }
 
+inline bool caseInsensitiveLessThan(QString const & s1, QString const & s2)
+{
+       return s1.toLower() < s2.toLower();
+}
+
 
 void GuiRef::redoRefs()
 {
@@ -321,13 +338,20 @@ void GuiRef::redoRefs()
        // the first item inserted
        QString const oldSelection(referenceED->text());
 
-       for (vector<docstring>::const_iterator iter = refs_.begin();
-               iter != refs_.end(); ++iter) {
-               refsLW->addItem(toqstr(*iter));
+       QStringList refsStrings;
+       vector<docstring>::const_iterator iter;
+       for (iter = refs_.begin(); iter != refs_.end(); ++iter)
+               refsStrings.append(toqstr(*iter));
+
+       if (sortCB->isEnabled() && sortCB->isChecked()) {
+               if(caseSensitiveCB->isEnabled() && caseSensitiveCB->isChecked())
+                       qSort(refsStrings.begin(), refsStrings.end());
+               else
+                       qSort(refsStrings.begin(), refsStrings.end(),
+                             caseInsensitiveLessThan /*defined above*/);
        }
 
-       if (sortCB->isEnabled() && sortCB->isChecked())
-               refsLW->sortItems();
+       refsLW->addItems(refsStrings);
 
        referenceED->setText(oldSelection);
 
@@ -368,6 +392,7 @@ void GuiRef::updateRefs()
                buf->getLabelList(refs_);
        }       
        sortCB->setEnabled(!refs_.empty());
+       caseSensitiveCB->setEnabled(sortCB->isEnabled() && sortCB->isChecked());
        refsLW->setEnabled(!refs_.empty());
        // refsLW should only be the focus proxy when it is enabled
        setFocusProxy(refs_.empty() ? 0 : refsLW);
index d34908751045b5bd4c9c7092e13d0454796fa37d..cf2a3d491c68284b1e8d359ef2c4d7e589a0dd31 100644 (file)
@@ -38,6 +38,7 @@ private Q_SLOTS:
        void selectionChanged();
        void refSelected(QListWidgetItem *);
        void sortToggled();
+       void caseSensitiveToggled();
        void updateClicked();
        void reset_dialog();
        void dialog_rejected();
index ca8c474f275bd7ee3858f66d75fc2f5e90d474f2..a5e2adbbc98a5c3008e00049bf273be1fa3c6644 100644 (file)
@@ -5,7 +5,7 @@
    <rect>
     <x>0</x>
     <y>0</y>
-    <width>347</width>
+    <width>386</width>
     <height>423</height>
    </rect>
   </property>
    <bool>true</bool>
   </property>
   <layout class="QGridLayout" >
-   <property name="margin" >
-    <number>9</number>
-   </property>
-   <property name="spacing" >
-    <number>6</number>
-   </property>
-   <item row="1" column="0" colspan="3" >
-    <widget class="QListWidget" name="refsLW" />
+   <item row="0" column="0" colspan="2" >
+    <widget class="QLabel" name="refsL" >
+     <property name="text" >
+      <string>La&amp;bels in:</string>
+     </property>
+     <property name="buddy" >
+      <cstring>bufferCO</cstring>
+     </property>
+    </widget>
    </item>
    <item row="0" column="2" >
     <widget class="QComboBox" name="bufferCO" >
      <property name="sizePolicy" >
-      <sizepolicy>
-       <hsizetype>7</hsizetype>
-       <vsizetype>0</vsizetype>
+      <sizepolicy vsizetype="Fixed" hsizetype="Expanding" >
        <horstretch>0</horstretch>
        <verstretch>0</verstretch>
       </sizepolicy>
      </property>
     </widget>
    </item>
-   <item row="0" column="0" colspan="2" >
-    <widget class="QLabel" name="refsL" >
-     <property name="text" >
-      <string>La&amp;bels in:</string>
-     </property>
-     <property name="buddy" >
-      <cstring>bufferCO</cstring>
-     </property>
-    </widget>
+   <item row="1" column="0" colspan="3" >
+    <widget class="QListWidget" name="refsLW" />
    </item>
-   <item row="6" column="0" colspan="3" >
+   <item row="2" column="0" colspan="3" >
     <layout class="QHBoxLayout" >
-     <property name="margin" >
-      <number>0</number>
-     </property>
-     <property name="spacing" >
-      <number>6</number>
-     </property>
-     <item>
-      <spacer>
-       <property name="orientation" >
-        <enum>Qt::Horizontal</enum>
-       </property>
-       <property name="sizeType" >
-        <enum>QSizePolicy::Expanding</enum>
-       </property>
-       <property name="sizeHint" >
-        <size>
-         <width>20</width>
-         <height>20</height>
-        </size>
-       </property>
-      </spacer>
-     </item>
      <item>
-      <widget class="QPushButton" name="okPB" >
-       <property name="text" >
-        <string>&amp;OK</string>
-       </property>
-       <property name="default" >
-        <bool>true</bool>
-       </property>
-      </widget>
+      <layout class="QHBoxLayout" >
+       <item>
+        <widget class="QCheckBox" name="sortCB" >
+         <property name="toolTip" >
+          <string>Sort labels in alphabetical order (case-insensitively unless the Case-sensitive option is checked)</string>
+         </property>
+         <property name="text" >
+          <string>&amp;Sort</string>
+         </property>
+        </widget>
+       </item>
+       <item>
+        <widget class="QCheckBox" name="caseSensitiveCB" >
+         <property name="enabled" >
+          <bool>false</bool>
+         </property>
+         <property name="toolTip" >
+          <string>Sort labels case-sensitively in alphabetical order</string>
+         </property>
+         <property name="text" >
+          <string>Cas&amp;e-sensitive</string>
+         </property>
+        </widget>
+       </item>
+      </layout>
      </item>
      <item>
-      <widget class="QPushButton" name="applyPB" >
-       <property name="text" >
-        <string>&amp;Apply</string>
-       </property>
-       <property name="default" >
-        <bool>true</bool>
-       </property>
-      </widget>
-     </item>
-     <item>
-      <widget class="QPushButton" name="closePB" >
-       <property name="text" >
-        <string>&amp;Close</string>
-       </property>
-      </widget>
+      <layout class="QHBoxLayout" >
+       <item>
+        <widget class="QPushButton" name="updatePB" >
+         <property name="sizePolicy" >
+          <sizepolicy vsizetype="Fixed" hsizetype="MinimumExpanding" >
+           <horstretch>0</horstretch>
+           <verstretch>0</verstretch>
+          </sizepolicy>
+         </property>
+         <property name="toolTip" >
+          <string>Update the label list</string>
+         </property>
+         <property name="text" >
+          <string>&amp;Update</string>
+         </property>
+        </widget>
+       </item>
+       <item>
+        <widget class="QPushButton" name="gotoPB" >
+         <property name="sizePolicy" >
+          <sizepolicy vsizetype="Fixed" hsizetype="MinimumExpanding" >
+           <horstretch>0</horstretch>
+           <verstretch>0</verstretch>
+          </sizepolicy>
+         </property>
+         <property name="toolTip" >
+          <string>Jump to the label</string>
+         </property>
+         <property name="text" >
+          <string>&amp;Go to Label</string>
+         </property>
+        </widget>
+       </item>
+      </layout>
      </item>
     </layout>
    </item>
-   <item row="5" column="1" colspan="2" >
-    <widget class="QLineEdit" name="nameED" >
-     <property name="enabled" >
-      <bool>false</bool>
-     </property>
-    </widget>
-   </item>
-   <item row="5" column="0" >
-    <widget class="QLabel" name="nameL" >
-     <property name="enabled" >
-      <bool>false</bool>
-     </property>
+   <item row="3" column="0" >
+    <widget class="QLabel" name="referenceL" >
      <property name="text" >
-      <string>&amp;Name:</string>
+      <string>&amp;Label:</string>
      </property>
      <property name="alignment" >
       <set>Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter</set>
      </property>
      <property name="buddy" >
-      <cstring>nameED</cstring>
+      <cstring>referenceED</cstring>
      </property>
     </widget>
    </item>
+   <item row="3" column="1" colspan="2" >
+    <widget class="QLineEdit" name="referenceED" />
+   </item>
    <item row="4" column="0" >
     <widget class="QLabel" name="typeLA" >
      <property name="text" >
      </property>
     </widget>
    </item>
-   <item row="3" column="0" >
-    <widget class="QLabel" name="referenceL" >
-     <property name="text" >
-      <string>&amp;Label:</string>
-     </property>
-     <property name="alignment" >
-      <set>Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter</set>
-     </property>
-     <property name="buddy" >
-      <cstring>referenceED</cstring>
-     </property>
-    </widget>
-   </item>
    <item row="4" column="1" colspan="2" >
     <widget class="QComboBox" name="typeCO" >
      <property name="sizePolicy" >
-      <sizepolicy>
-       <hsizetype>1</hsizetype>
-       <vsizetype>0</vsizetype>
+      <sizepolicy vsizetype="Fixed" hsizetype="Minimum" >
        <horstretch>0</horstretch>
        <verstretch>0</verstretch>
       </sizepolicy>
      </item>
     </widget>
    </item>
-   <item row="3" column="1" colspan="2" >
-    <widget class="QLineEdit" name="referenceED" />
-   </item>
-   <item row="2" column="0" >
-    <widget class="QCheckBox" name="sortCB" >
-     <property name="toolTip" >
-      <string>Sort labels in alphabetical order</string>
+   <item row="5" column="0" >
+    <widget class="QLabel" name="nameL" >
+     <property name="enabled" >
+      <bool>false</bool>
      </property>
      <property name="text" >
-      <string>&amp;Sort</string>
+      <string>&amp;Name:</string>
+     </property>
+     <property name="alignment" >
+      <set>Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter</set>
+     </property>
+     <property name="buddy" >
+      <cstring>nameED</cstring>
      </property>
     </widget>
    </item>
-   <item row="2" column="1" colspan="2" >
-    <layout class="QHBoxLayout" >
-     <property name="margin" >
-      <number>0</number>
+   <item row="5" column="1" colspan="2" >
+    <widget class="QLineEdit" name="nameED" >
+     <property name="enabled" >
+      <bool>false</bool>
      </property>
+    </widget>
+   </item>
+   <item row="6" column="0" colspan="3" >
+    <layout class="QHBoxLayout" >
      <property name="spacing" >
       <number>6</number>
      </property>
+     <property name="margin" >
+      <number>0</number>
+     </property>
      <item>
-      <widget class="QPushButton" name="updatePB" >
-       <property name="sizePolicy" >
-        <sizepolicy>
-         <hsizetype>3</hsizetype>
-         <vsizetype>0</vsizetype>
-         <horstretch>0</horstretch>
-         <verstretch>0</verstretch>
-        </sizepolicy>
+      <spacer>
+       <property name="orientation" >
+        <enum>Qt::Horizontal</enum>
        </property>
-       <property name="toolTip" >
-        <string>Update the label list</string>
+       <property name="sizeType" >
+        <enum>QSizePolicy::Expanding</enum>
+       </property>
+       <property name="sizeHint" stdset="0" >
+        <size>
+         <width>20</width>
+         <height>20</height>
+        </size>
        </property>
+      </spacer>
+     </item>
+     <item>
+      <widget class="QPushButton" name="okPB" >
        <property name="text" >
-        <string>&amp;Update</string>
+        <string>&amp;OK</string>
+       </property>
+       <property name="default" >
+        <bool>true</bool>
        </property>
       </widget>
      </item>
      <item>
-      <widget class="QPushButton" name="gotoPB" >
-       <property name="sizePolicy" >
-        <sizepolicy>
-         <hsizetype>3</hsizetype>
-         <vsizetype>0</vsizetype>
-         <horstretch>0</horstretch>
-         <verstretch>0</verstretch>
-        </sizepolicy>
+      <widget class="QPushButton" name="applyPB" >
+       <property name="text" >
+        <string>&amp;Apply</string>
        </property>
-       <property name="toolTip" >
-        <string>Jump to the label</string>
+       <property name="default" >
+        <bool>true</bool>
        </property>
+      </widget>
+     </item>
+     <item>
+      <widget class="QPushButton" name="closePB" >
        <property name="text" >
-        <string>&amp;Go to Label</string>
+        <string>&amp;Close</string>
        </property>
       </widget>
      </item>
    </item>
   </layout>
  </widget>
- <pixmapfunction></pixmapfunction>
- <includes>
-  <include location="local" >qt_i18n.h</include>
- </includes>
  <tabstops>
   <tabstop>bufferCO</tabstop>
   <tabstop>refsLW</tabstop>
   <tabstop>applyPB</tabstop>
   <tabstop>closePB</tabstop>
  </tabstops>
+ <includes>
+  <include location="local" >qt_i18n.h</include>
+ </includes>
  <resources/>
  <connections/>
 </ui>