commit - 166423e4e667c305423488bec9792232678f833f
commit + 613f9cdc75d627ee113c4eb0f09c4d1cb61df9fb
blob - 89daa8cac4f8f34e27ed2c8ff49dc791cab6db91
blob + 89dabdc700deeb790a922906c53f49e2406e4b5e
--- ChangeLog-gtk2.claws
+++ ChangeLog-gtk2.claws
+2004-08-11 [colin] 0.9.12cvs57.3
+
+ * src/message_search.c
+ * src/summary_search.c
+ Make searches case insensitive by default
+ * src/textview.c
+ Fix case-insensitive search in message
+
2004-08-11 [colin] 0.9.12cvs57.2
* src/summary_search.c
blob - 5d46098e039f7270a630f89d49517d24d3d4ce95
blob + 6b586c28f87eaf7ab92894864fb3b4fc8b8bbefb
--- PATCHSETS
+++ PATCHSETS
( cvs diff -u -r 1.654.2.141 -r 1.654.2.142 configure.ac; cvs diff -u -r 1.155.2.8 -r 1.155.2.9 src/Makefile.am; cvs diff -u -r 1.24.2.3 -r 1.24.2.4 src/common/Makefile.am; ) > 0.9.12cvs55.3.patchset
( cvs diff -u -r 1.13.2.7 -r 1.13.2.8 src/common/socket.c; ) > 0.9.12cvs55.4.patchset
( cvs diff -u -r 1.15.2.6 -r 1.15.2.7 src/summary_search.c; ) > 0.9.12cvs57.2.patchset
+( cvs diff -u -r 1.3.12.4 -r 1.3.12.5 src/message_search.c; cvs diff -u -r 1.15.2.7 -r 1.15.2.8 src/summary_search.c; cvs diff -u -r 1.96.2.15 -r 1.96.2.16 src/textview.c; ) > 0.9.12cvs57.3.patchset
blob - b21d60a0c7609bb8716ac1c4143eebe9b5d2beb5
blob + 9d53c4a95105845f34efe46caf6372cc4ad102cd
--- configure.ac
+++ configure.ac
BINARY_AGE=0
EXTRA_VERSION=57
EXTRA_RELEASE=
-EXTRA_GTK2_VERSION=.2
+EXTRA_GTK2_VERSION=.3
if test \( $EXTRA_VERSION -eq 0 \) -o \( "x$EXTRA_RELEASE" != "x" \); then
VERSION=${MAJOR_VERSION}.${MINOR_VERSION}.${MICRO_VERSION}${EXTRA_RELEASE}${EXTRA_GTK2_VERSION}
blob - 4e95defb418f00b53b9ba910ff95f0336144c86f
blob + d5f0808c1e12166a9700a6e69bf362043b79c7e0
--- src/message_search.c
+++ src/message_search.c
gtk_widget_show (case_checkbtn);
gtk_box_pack_start (GTK_BOX (checkbtn_hbox), case_checkbtn,
FALSE, FALSE, 0);
- gtk_widget_set_sensitive(case_checkbtn, FALSE);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(case_checkbtn), TRUE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(case_checkbtn), FALSE);
backward_checkbtn =
gtk_check_button_new_with_label (_("Backward search"));
blob - 499027a273b7bf7721db653fb004b86f78f1e882
blob + 23739c7785809c79c8bd73929801290a18dfce2f
--- src/summary_search.c
+++ src/summary_search.c
gtk_container_set_border_width (GTK_CONTAINER (checkbtn_hbox), 8);
case_checkbtn = gtk_check_button_new_with_label (_("Case sensitive"));
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(case_checkbtn), TRUE);
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(case_checkbtn), FALSE);
gtk_widget_show (case_checkbtn);
gtk_box_pack_start (GTK_BOX (checkbtn_hbox), case_checkbtn,
FALSE, FALSE, 0);
blob - 2c0b266d2dcdc432fd97f8dce278abf015865168
blob + d9b839724577ec52b55d31210341b4317825307e
--- src/textview.c
+++ src/textview.c
gboolean textview_search_string(TextView *textview, const gchar *str,
gboolean case_sens)
{
-#warning FIXME_GTK2 /* currently, these search functions ignores case_sens */
GtkTextView *text = GTK_TEXT_VIEW(textview->text);
GtkTextBuffer *buffer = gtk_text_view_get_buffer(text);
GtkTextMark *mark;
- GtkTextIter iter, start, end, *pos;
- gboolean found;
+ GtkTextIter iter, start, end, real_end, *pos;
+ gboolean found = FALSE;
gint insert_offset, selbound_offset;
/* reset selection */
/* search */
mark = gtk_text_buffer_get_insert(buffer);
gtk_text_buffer_get_iter_at_mark(buffer, &iter, mark);
- found = gtk_text_iter_forward_search(&iter, str,
+ if (case_sens) {
+ found = gtk_text_iter_forward_search(&iter, str,
GTK_TEXT_SEARCH_VISIBLE_ONLY,
&start, &end, NULL);
+ } else {
+ gchar *text = NULL;
+ int i = 0;
+ gtk_text_buffer_get_end_iter(buffer, &real_end);
+ text = strdup(gtk_text_buffer_get_text(buffer, &iter,
+ &real_end, FALSE));
+
+ while (!found && i++ < strlen(text)) {
+ found = (strncasecmp(text+i, str, strlen(str)) == 0);
+ }
+
+ i += gtk_text_iter_get_offset(&end);
+
+ if (found) {
+ gtk_text_buffer_get_iter_at_offset(buffer, &start, i);
+ gtk_text_buffer_get_iter_at_offset(buffer, &end,
+ i + strlen(str));
+ }
+
+ g_free(text);
+ }
+
if (found) {
gtk_text_buffer_place_cursor(buffer, &start);
- gtk_text_buffer_move_mark_by_name(buffer, "selection_bound", &end);
+ gtk_text_buffer_move_mark_by_name(buffer, "selection_bound",
+ &end);
mark = gtk_text_buffer_get_mark(buffer, "insert");
gtk_text_view_scroll_mark_onscreen(text, mark);
}
gboolean textview_search_string_backward(TextView *textview, const gchar *str,
gboolean case_sens)
{
-#warning FIXME_GTK2
GtkTextView *text = GTK_TEXT_VIEW(textview->text);
GtkTextBuffer *buffer = gtk_text_view_get_buffer(text);
GtkTextMark *mark;
- GtkTextIter iter, start, end, *pos;
- gboolean found;
+ GtkTextIter iter, start, real_start, end, *pos;
+ gboolean found = FALSE;
gint insert_offset, selbound_offset;
/* reset selection */
/* search */
mark = gtk_text_buffer_get_insert(buffer);
gtk_text_buffer_get_iter_at_mark(buffer, &iter, mark);
- found = gtk_text_iter_backward_search(&iter, str,
+ if (case_sens) {
+ found = gtk_text_iter_backward_search(&iter, str,
GTK_TEXT_SEARCH_VISIBLE_ONLY,
&start, &end, NULL);
+ } else {
+ gchar *text = NULL;
+ int i = 0;
+ if (gtk_text_iter_get_offset(&iter) == 0)
+ gtk_text_buffer_get_end_iter(buffer, &iter);
+
+ i = gtk_text_iter_get_offset(&iter) - strlen(str) - 1;
+ gtk_text_buffer_get_start_iter(buffer, &real_start);
+
+ text = strdup(gtk_text_buffer_get_text(buffer, &real_start,
+ &iter, FALSE));
+
+ while (!found && i-- >= 0) {
+ found = (strncasecmp(text+i, str, strlen(str)) == 0);
+ }
+
+ if (found) {
+ gtk_text_buffer_get_iter_at_offset(buffer, &start, i);
+ gtk_text_buffer_get_iter_at_offset(buffer, &end,
+ i + strlen(str));
+ }
+
+ g_free(text);
+ }
+
if (found) {
gtk_text_buffer_place_cursor(buffer, &end);
- gtk_text_buffer_move_mark_by_name(buffer, "selection_bound", &start);
+ gtk_text_buffer_move_mark_by_name(buffer, "selection_bound",
+ &start);
mark = gtk_text_buffer_get_mark(buffer, "insert");
gtk_text_view_scroll_mark_onscreen(text, mark);
}