From 61874b4bae6bf740c363e2cf748f29c8fa4e014e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Enrico=20Tr=C3=B6ger?= Date: Mon, 5 Dec 2005 20:54:25 +0000 Subject: [PATCH] extending HOME and END key default behaviour, to jump back to previous cursor position if pressed again (improved) git-svn-id: https://geany.svn.sourceforge.net/svnroot/geany/trunk@35 ea778897-0a13-0410-b9d1-a72fbfd435f5 --- src/callbacks.c | 57 +++++++++++++++++++++++++++++-------------------- 1 file changed, 34 insertions(+), 23 deletions(-) diff --git a/src/callbacks.c b/src/callbacks.c index 2f8ea0bf..eb8ef0a3 100644 --- a/src/callbacks.c +++ b/src/callbacks.c @@ -78,7 +78,6 @@ static gboolean search_backwards; static gint search_flags_re; static gboolean search_backwards_re; - // extending HOME and END default behaviour, to jump back to previous cursor position if pressed again static gint cursor_pos_end = -1; static gint cursor_pos_home = 0; @@ -88,7 +87,6 @@ static gint cursor_pos_home_state = 0; - // exit function, for very early exit(quit by non-existing configuration dir) gint destroyapp_early(void) { @@ -731,6 +729,10 @@ on_notebook1_switch_page (GtkNotebook *notebook, gtk_tree_model_foreach(GTK_TREE_MODEL(tv.store_openfiles), treeviews_find_node, GINT_TO_POINTER(idx)); + // resets the cursor position(it could be wrong, assuming line has changed) + cursor_pos_end = -1; + cursor_pos_home_state = 0; + document_set_text_changed(idx); utils_build_show_hide(idx); utils_update_statusbar(idx); @@ -1006,6 +1008,8 @@ on_editor_key_press_event (GtkWidget *widget, { //gint idx = geany_document_get_cur_idx(); gboolean ret = FALSE; + gint idx = GPOINTER_TO_INT(user_data); + switch(event->keyval) { @@ -1014,7 +1018,7 @@ on_editor_key_press_event (GtkWidget *widget, { if (event->state & GDK_CONTROL_MASK) { - sci_line_duplicate(doc_list[GPOINTER_TO_INT(user_data)].sci); + sci_line_duplicate(doc_list[idx].sci); ret = TRUE; } break; @@ -1026,17 +1030,17 @@ on_editor_key_press_event (GtkWidget *widget, { sci_cb_start_auto_complete( doc_list[GPOINTER_TO_INT(user_data)].sci, - sci_get_current_position(doc_list[GPOINTER_TO_INT(user_data)].sci)); + sci_get_current_position(doc_list[idx].sci)); ret = TRUE; } else if (event->state & GDK_MOD1_MASK) { // ALT+Space - sci_cb_show_calltip(doc_list[GPOINTER_TO_INT(user_data)].sci, -1); + sci_cb_show_calltip(doc_list[idx].sci, -1); ret = TRUE; } else if (event->state & GDK_SHIFT_MASK) { // Shift+Space, catch this explicitly to suppress sci_cb_auto_forif() ;-) - sci_add_text(doc_list[GPOINTER_TO_INT(user_data)].sci, " "); + sci_add_text(doc_list[idx].sci, " "); ret = TRUE; } break; @@ -1046,7 +1050,7 @@ on_editor_key_press_event (GtkWidget *widget, { if (event->state & GDK_CONTROL_MASK) { - document_update_tag_list(GPOINTER_TO_INT(user_data)); + document_update_tag_list(idx); ret = TRUE; } break; @@ -1056,7 +1060,7 @@ on_editor_key_press_event (GtkWidget *widget, { if (event->state & GDK_CONTROL_MASK) { - sci_cb_do_comment(GPOINTER_TO_INT(user_data)); + sci_cb_do_comment(idx); ret = TRUE; } break; @@ -1067,8 +1071,8 @@ on_editor_key_press_event (GtkWidget *widget, if (event->state & GDK_CONTROL_MASK) { sci_cb_handle_uri( - doc_list[GPOINTER_TO_INT(user_data)].sci, - sci_get_current_position(doc_list[GPOINTER_TO_INT(user_data)].sci)); + doc_list[idx].sci, + sci_get_current_position(doc_list[idx].sci)); ret = TRUE; } break; @@ -1078,7 +1082,7 @@ on_editor_key_press_event (GtkWidget *widget, { if (event->state & GDK_CONTROL_MASK) { - sci_zoom_in(doc_list[GPOINTER_TO_INT(user_data)].sci); + sci_zoom_in(doc_list[idx].sci); ret = TRUE; } break; @@ -1088,7 +1092,7 @@ on_editor_key_press_event (GtkWidget *widget, { if (event->state & GDK_CONTROL_MASK) { - sci_zoom_out(doc_list[GPOINTER_TO_INT(user_data)].sci); + sci_zoom_out(doc_list[idx].sci); ret = TRUE; } break; @@ -1137,7 +1141,7 @@ on_editor_key_press_event (GtkWidget *widget, case GDK_Insert: { if (! (event->state & GDK_SHIFT_MASK)) - doc_list[GPOINTER_TO_INT(user_data)].do_overwrite = (doc_list[GPOINTER_TO_INT(user_data)].do_overwrite) ? FALSE : TRUE; + doc_list[GPOINTER_TO_INT(user_data)].do_overwrite = (doc_list[idx].do_overwrite) ? FALSE : TRUE; break; } case GDK_F12: @@ -1147,15 +1151,16 @@ on_editor_key_press_event (GtkWidget *widget, break; } case GDK_End: - { // extending HOME and END default behaviour, for details look at the start of this file + { // extending HOME and END default behaviour, for details look at the start of this function + geany_debug("pos_end: %d", cursor_pos_end); if (cursor_pos_end == -1) { - cursor_pos_end = sci_get_current_position(doc_list[GPOINTER_TO_INT(user_data)].sci); - sci_cmd(doc_list[GPOINTER_TO_INT(user_data)].sci, SCI_LINEEND); + cursor_pos_end = sci_get_current_position(doc_list[idx].sci); + sci_cmd(doc_list[idx].sci, SCI_LINEEND); } else { - sci_set_current_position(doc_list[GPOINTER_TO_INT(user_data)].sci, cursor_pos_end); + sci_set_current_position(doc_list[idx].sci, cursor_pos_end); cursor_pos_end = -1; } break; @@ -1164,18 +1169,18 @@ on_editor_key_press_event (GtkWidget *widget, { if (cursor_pos_home_state == 0) { - cursor_pos_home = sci_get_current_position(doc_list[GPOINTER_TO_INT(user_data)].sci); - sci_cmd(doc_list[GPOINTER_TO_INT(user_data)].sci, SCI_VCHOME); + cursor_pos_home = sci_get_current_position(doc_list[idx].sci); + sci_cmd(doc_list[idx].sci, SCI_VCHOME); cursor_pos_home_state = 1; } else if (cursor_pos_home_state == 1) { - sci_cmd(doc_list[GPOINTER_TO_INT(user_data)].sci, SCI_HOME); + sci_cmd(doc_list[idx].sci, SCI_HOME); cursor_pos_home_state = 2; } else { - sci_set_current_position(doc_list[GPOINTER_TO_INT(user_data)].sci, cursor_pos_home); + sci_set_current_position(doc_list[idx].sci, cursor_pos_home); cursor_pos_home_state = 0; } break; @@ -1196,6 +1201,9 @@ on_editor_button_press_event (GtkWidget *widget, if (event->button == 1) { utils_check_disk_status(GPOINTER_TO_INT(user_data), FALSE); + // resets the cursor position(it could be wrong, assuming line has changed) + cursor_pos_end = -1; + cursor_pos_home_state = 0; } #endif @@ -2164,8 +2172,11 @@ on_pref_tools_button_clicked (GtkButton *button, if (field[0]) { filename = g_find_program_in_path(field[0]); - gtk_file_chooser_select_filename(GTK_FILE_CHOOSER(dialog), filename); - g_free(filename); + if (filename) + { + gtk_file_chooser_select_filename(GTK_FILE_CHOOSER(dialog), filename); + g_free(filename); + } } // run it