made length of MRU list changeable

git-svn-id: https://geany.svn.sourceforge.net/svnroot/geany/trunk@49 ea778897-0a13-0410-b9d1-a72fbfd435f5
This commit is contained in:
Enrico Tröger 2005-12-12 02:23:51 +00:00
parent 01141ccb6c
commit 9fe6b716f7
7 changed files with 67 additions and 26 deletions

View File

@ -867,7 +867,7 @@ on_file_save_save_button_clicked (GtkButton *button,
if (g_queue_find_custom(app->recent_queue, doc_list[idx].file_name, (GCompareFunc) strcmp) == NULL) if (g_queue_find_custom(app->recent_queue, doc_list[idx].file_name, (GCompareFunc) strcmp) == NULL)
{ {
g_queue_push_head(app->recent_queue, g_strdup(doc_list[idx].file_name)); g_queue_push_head(app->recent_queue, g_strdup(doc_list[idx].file_name));
if (g_queue_get_length(app->recent_queue) > GEANY_RECENT_MRU_LENGTH) if (g_queue_get_length(app->recent_queue) > app->mru_length)
{ {
g_free(g_queue_pop_tail(app->recent_queue)); g_free(g_queue_pop_tail(app->recent_queue));
} }
@ -1168,7 +1168,7 @@ on_editor_key_press_event (GtkWidget *widget,
} }
/* following code is unusable unless I get a signal for a line changed, don't want to do this with /* following code is unusable unless I get a signal for a line changed, don't want to do this with
* updateUI() * updateUI()
case GDK_End: */ case GDK_End:
{ // extending HOME and END default behaviour, for details look at the start of this function { // extending HOME and END default behaviour, for details look at the start of this function
if (cursor_pos_end == -1 || current_line != sci_get_current_line(doc_list[idx].sci, -1)) if (cursor_pos_end == -1 || current_line != sci_get_current_line(doc_list[idx].sci, -1))
{ {
@ -1183,7 +1183,7 @@ on_editor_key_press_event (GtkWidget *widget,
} }
break; break;
} }
case GDK_Home: /* case GDK_Home:
{ {
if (cursor_pos_home_state == 0 || current_line != sci_get_current_line(doc_list[idx].sci, -1)) if (cursor_pos_home_state == 0 || current_line != sci_get_current_line(doc_list[idx].sci, -1))
{ {

View File

@ -551,7 +551,7 @@ void dialogs_create_recent_menu(void)
gint i; gint i;
gchar *filename; gchar *filename;
for (i = (MIN(GEANY_RECENT_MRU_LENGTH, g_queue_get_length(app->recent_queue)) - 1); i >= 0; i--) for (i = (MIN(app->mru_length, g_queue_get_length(app->recent_queue)) - 1); i >= 0; i--)
{ {
filename = g_queue_peek_nth(app->recent_queue, i); filename = g_queue_peek_nth(app->recent_queue, i);
tmp = gtk_menu_item_new_with_label(filename); tmp = gtk_menu_item_new_with_label(filename);

View File

@ -176,7 +176,7 @@ gint document_create_new_sci(const gchar *filename)
sci_use_popup(sci, FALSE); sci_use_popup(sci, FALSE);
sci_set_codepage(sci, 1); sci_set_codepage(sci, 1);
sci_clear_cmdkey(sci, SCK_END); // disable to act on our own in callbacks.c sci_clear_cmdkey(sci, SCK_END); // disable to act on our own in callbacks.c
sci_clear_cmdkey(sci, SCK_HOME); //sci_clear_cmdkey(sci, SCK_HOME);
sci_set_mark_long_lines(sci, app->long_line_column, app->long_line_color); sci_set_mark_long_lines(sci, app->long_line_column, app->long_line_color);
sci_set_symbol_margin(sci, app->show_markers_margin); sci_set_symbol_margin(sci, app->show_markers_margin);
//sci_set_lines_wrapped(sci, app->line_breaking); //sci_set_lines_wrapped(sci, app->line_breaking);
@ -456,7 +456,7 @@ void document_open_file(gint idx, const gchar *filename, gint pos, gboolean read
if (g_queue_find_custom(app->recent_queue, filename, (GCompareFunc) strcmp) == NULL) if (g_queue_find_custom(app->recent_queue, filename, (GCompareFunc) strcmp) == NULL)
{ {
g_queue_push_head(app->recent_queue, g_strdup(filename)); g_queue_push_head(app->recent_queue, g_strdup(filename));
if (g_queue_get_length(app->recent_queue) > GEANY_RECENT_MRU_LENGTH) if (g_queue_get_length(app->recent_queue) > app->mru_length)
{ {
g_free(g_queue_pop_tail(app->recent_queue)); g_free(g_queue_pop_tail(app->recent_queue));
} }

View File

@ -57,8 +57,8 @@
#define GEANY_CODENAME "Tarkin" #define GEANY_CODENAME "Tarkin"
#define GEANY_HOMEPAGE "http://geany.uvena.de/" #define GEANY_HOMEPAGE "http://geany.uvena.de/"
#define GEANY_MAX_OPEN_FILES 25 #define GEANY_MAX_OPEN_FILES 25
#define GEANY_MRU_LENGTH 15 #define GEANY_SESSION_FILES 15
#define GEANY_RECENT_MRU_LENGTH 10 //#define GEANY_RECENT_MRU_LENGTH 10
#define GEANY_MAX_TAGS_COUNT 1000 #define GEANY_MAX_TAGS_COUNT 1000
#define GEANY_WORDCHARS "_#&abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789" #define GEANY_WORDCHARS "_#&abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
#define GEANY_MAX_AUTOCOMPLETE_WORDS 30 #define GEANY_MAX_AUTOCOMPLETE_WORDS 30
@ -127,6 +127,7 @@ typedef struct MyApp
gboolean pref_main_save_winpos; gboolean pref_main_save_winpos;
gboolean pref_main_confirm_exit; gboolean pref_main_confirm_exit;
gboolean pref_main_show_search; gboolean pref_main_show_search;
gint mru_length;
gint long_line_column; gint long_line_column;
gchar *long_line_color; gchar *long_line_color;
gchar *pref_template_developer; gchar *pref_template_developer;

View File

@ -1896,6 +1896,10 @@ create_prefs_dialog (void)
GtkWidget *frame1; GtkWidget *frame1;
GtkWidget *alignment2; GtkWidget *alignment2;
GtkWidget *vbox4; GtkWidget *vbox4;
GtkWidget *hbox2;
GtkWidget *label147;
GtkObject *spin_mru_adj;
GtkWidget *spin_mru;
GtkWidget *check_load_session; GtkWidget *check_load_session;
GtkWidget *check_save_win_pos; GtkWidget *check_save_win_pos;
GtkWidget *check_switch_pages; GtkWidget *check_switch_pages;
@ -2060,6 +2064,22 @@ create_prefs_dialog (void)
gtk_widget_show (vbox4); gtk_widget_show (vbox4);
gtk_container_add (GTK_CONTAINER (alignment2), vbox4); gtk_container_add (GTK_CONTAINER (alignment2), vbox4);
hbox2 = gtk_hbox_new (FALSE, 19);
gtk_widget_show (hbox2);
gtk_box_pack_start (GTK_BOX (vbox4), hbox2, FALSE, FALSE, 0);
label147 = gtk_label_new (_("MRU list length"));
gtk_widget_show (label147);
gtk_box_pack_start (GTK_BOX (hbox2), label147, FALSE, FALSE, 0);
spin_mru_adj = gtk_adjustment_new (4, 1, 50, 1, 10, 10);
spin_mru = gtk_spin_button_new (GTK_ADJUSTMENT (spin_mru_adj), 1, 0);
gtk_widget_show (spin_mru);
gtk_box_pack_start (GTK_BOX (hbox2), spin_mru, FALSE, TRUE, 0);
gtk_tooltips_set_tip (tooltips, spin_mru, _("Specifies the number of files which are stored in the Recent files list."), NULL);
gtk_spin_button_set_numeric (GTK_SPIN_BUTTON (spin_mru), TRUE);
gtk_spin_button_set_wrap (GTK_SPIN_BUTTON (spin_mru), TRUE);
check_load_session = gtk_check_button_new_with_mnemonic (_("Load files from the last session")); check_load_session = gtk_check_button_new_with_mnemonic (_("Load files from the last session"));
gtk_widget_show (check_load_session); gtk_widget_show (check_load_session);
gtk_box_pack_start (GTK_BOX (vbox4), check_load_session, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox4), check_load_session, FALSE, FALSE, 0);
@ -2821,6 +2841,9 @@ create_prefs_dialog (void)
GLADE_HOOKUP_OBJECT (prefs_dialog, frame1, "frame1"); GLADE_HOOKUP_OBJECT (prefs_dialog, frame1, "frame1");
GLADE_HOOKUP_OBJECT (prefs_dialog, alignment2, "alignment2"); GLADE_HOOKUP_OBJECT (prefs_dialog, alignment2, "alignment2");
GLADE_HOOKUP_OBJECT (prefs_dialog, vbox4, "vbox4"); GLADE_HOOKUP_OBJECT (prefs_dialog, vbox4, "vbox4");
GLADE_HOOKUP_OBJECT (prefs_dialog, hbox2, "hbox2");
GLADE_HOOKUP_OBJECT (prefs_dialog, label147, "label147");
GLADE_HOOKUP_OBJECT (prefs_dialog, spin_mru, "spin_mru");
GLADE_HOOKUP_OBJECT (prefs_dialog, check_load_session, "check_load_session"); GLADE_HOOKUP_OBJECT (prefs_dialog, check_load_session, "check_load_session");
GLADE_HOOKUP_OBJECT (prefs_dialog, check_save_win_pos, "check_save_win_pos"); GLADE_HOOKUP_OBJECT (prefs_dialog, check_save_win_pos, "check_save_win_pos");
GLADE_HOOKUP_OBJECT (prefs_dialog, check_switch_pages, "check_switch_pages"); GLADE_HOOKUP_OBJECT (prefs_dialog, check_switch_pages, "check_switch_pages");

View File

@ -31,7 +31,7 @@
static gchar *scribble_text = NULL; static gchar *scribble_text = NULL;
static gchar *session_files[GEANY_MRU_LENGTH]; static gchar *session_files[GEANY_SESSION_FILES];
static gint hpan_position; static gint hpan_position;
static gint vpan_position; static gint vpan_position;
@ -44,7 +44,7 @@ void configuration_save(void)
gchar *configfile = g_strconcat(app->configdir, G_DIR_SEPARATOR_S, "geany.conf", NULL); gchar *configfile = g_strconcat(app->configdir, G_DIR_SEPARATOR_S, "geany.conf", NULL);
gchar *entry = g_malloc(14); gchar *entry = g_malloc(14);
gchar *fname = g_malloc0(256); gchar *fname = g_malloc0(256);
gchar *recent_files[GEANY_RECENT_MRU_LENGTH] = { NULL }; gchar **recent_files = g_new(gchar*, app->mru_length);
GtkTextBuffer *buffer; GtkTextBuffer *buffer;
GtkTextIter start, end; GtkTextIter start, end;
@ -74,6 +74,7 @@ void configuration_save(void)
gtk_paned_get_position(GTK_PANED(lookup_widget(app->window, "vpaned1")))); gtk_paned_get_position(GTK_PANED(lookup_widget(app->window, "vpaned1"))));
} }
g_key_file_set_integer(config, PACKAGE, "mru_length", app->mru_length);
g_key_file_set_integer(config, PACKAGE, "long_line_column", app->long_line_column); g_key_file_set_integer(config, PACKAGE, "long_line_column", app->long_line_column);
g_key_file_set_string(config, PACKAGE, "long_line_color", app->long_line_color); g_key_file_set_string(config, PACKAGE, "long_line_color", app->long_line_color);
g_key_file_set_boolean(config, PACKAGE, "treeview_symbol_visible", app->treeview_symbol_visible); g_key_file_set_boolean(config, PACKAGE, "treeview_symbol_visible", app->treeview_symbol_visible);
@ -89,6 +90,8 @@ void configuration_save(void)
g_key_file_set_boolean(config, PACKAGE, "switch_msgwin_pages", app->switch_msgwin_pages); g_key_file_set_boolean(config, PACKAGE, "switch_msgwin_pages", app->switch_msgwin_pages);
g_key_file_set_boolean(config, PACKAGE, "auto_close_xml_tags", app->auto_close_xml_tags); g_key_file_set_boolean(config, PACKAGE, "auto_close_xml_tags", app->auto_close_xml_tags);
g_key_file_set_boolean(config, PACKAGE, "auto_complete_constructs", app->auto_complete_constructs); g_key_file_set_boolean(config, PACKAGE, "auto_complete_constructs", app->auto_complete_constructs);
g_key_file_set_comment(config, PACKAGE, "terminal_settings",
_(" VTE settings: FONT;FOREGROUND;BACKGROUND;scrollback;type;scroll on keystroke;scroll on output"), NULL);
g_key_file_set_string(config, PACKAGE, "terminal_settings", app->terminal_settings); g_key_file_set_string(config, PACKAGE, "terminal_settings", app->terminal_settings);
g_key_file_set_string(config, PACKAGE, "editor_font", app->editor_font); g_key_file_set_string(config, PACKAGE, "editor_font", app->editor_font);
g_key_file_set_string(config, PACKAGE, "tagbar_font", app->tagbar_font); g_key_file_set_string(config, PACKAGE, "tagbar_font", app->tagbar_font);
@ -118,19 +121,24 @@ void configuration_save(void)
g_key_file_set_string(config, "build", "build_term_cmd", app->build_term_cmd ? app->build_term_cmd : ""); g_key_file_set_string(config, "build", "build_term_cmd", app->build_term_cmd ? app->build_term_cmd : "");
g_key_file_set_string(config, "build", "build_browser_cmd", app->build_browser_cmd ? app->build_browser_cmd : ""); g_key_file_set_string(config, "build", "build_browser_cmd", app->build_browser_cmd ? app->build_browser_cmd : "");
for (i = 0; i < GEANY_RECENT_MRU_LENGTH; i++) for (i = 0; i < app->mru_length; i++)
{ {
if (! g_queue_is_empty(app->recent_queue)) if (! g_queue_is_empty(app->recent_queue))
{ {
recent_files[i] = g_queue_pop_head(app->recent_queue); recent_files[i] = g_queue_pop_head(app->recent_queue);
} }
else
{
recent_files[i] = NULL;
}
} }
g_key_file_set_string_list(config, "files", "recent_files", g_key_file_set_string_list(config, "files", "recent_files",
(const gchar**)recent_files, GEANY_RECENT_MRU_LENGTH); (const gchar**)recent_files, app->mru_length);
// store the last 10(or what ever MRU_LENGTH is set to) filenames, to reopen the next time // store the last 15(or what ever GEANY_SESSION_FILES is set to) filenames, to reopen the next time
max = gtk_notebook_get_n_pages(GTK_NOTEBOOK(app->notebook)); max = gtk_notebook_get_n_pages(GTK_NOTEBOOK(app->notebook));
for(i = 0; (i < max) && (j < GEANY_MRU_LENGTH); i++) for(i = 0; (i < max) && (j < GEANY_SESSION_FILES); i++)
{ {
idx = document_get_n_idx(i); idx = document_get_n_idx(i);
if (idx >= 0 && doc_list[idx].file_name) if (idx >= 0 && doc_list[idx].file_name)
@ -141,10 +149,10 @@ void configuration_save(void)
j++; j++;
} }
} }
// if open tabs less than MRU_LENGTH, delete existing saved entries in the list // if open tabs less than GEANY_SESSION_FILES, delete existing saved entries in the list
if (max < GEANY_MRU_LENGTH) if (max < GEANY_SESSION_FILES)
{ {
for(i = max; i < GEANY_MRU_LENGTH; i++) for(i = max; i < GEANY_SESSION_FILES; i++)
{ {
g_snprintf(entry, 13, "FILE_NAME_%d", i); g_snprintf(entry, 13, "FILE_NAME_%d", i);
g_key_file_set_string(config, "files", entry, ""); g_key_file_set_string(config, "files", entry, "");
@ -154,7 +162,8 @@ void configuration_save(void)
// write the file // write the file
utils_write_file(configfile, g_key_file_to_data(config, NULL, NULL)); utils_write_file(configfile, g_key_file_to_data(config, NULL, NULL));
utils_free_ptr_array(recent_files, GEANY_RECENT_MRU_LENGTH); utils_free_ptr_array(recent_files, app->mru_length);
g_free(recent_files);
g_key_file_free(config); g_key_file_free(config);
g_free(configfile); g_free(configfile);
g_free(entry); g_free(entry);
@ -168,7 +177,7 @@ gboolean configuration_load(void)
gboolean config_exists; gboolean config_exists;
guint i, geo_len; guint i, geo_len;
gint *geo = g_malloc(sizeof(gint) * 4); gint *geo = g_malloc(sizeof(gint) * 4);
gsize len; gsize len = 0;
gchar *configfile = g_strconcat(app->configdir, G_DIR_SEPARATOR_S, "geany.conf", NULL); gchar *configfile = g_strconcat(app->configdir, G_DIR_SEPARATOR_S, "geany.conf", NULL);
gchar *entry = g_malloc(14); gchar *entry = g_malloc(14);
gchar *tmp_string, *tmp_string2; gchar *tmp_string, *tmp_string2;
@ -178,6 +187,7 @@ gboolean configuration_load(void)
config_exists = g_key_file_load_from_file(config, configfile, G_KEY_FILE_KEEP_COMMENTS, NULL); config_exists = g_key_file_load_from_file(config, configfile, G_KEY_FILE_KEEP_COMMENTS, NULL);
app->toolbar_visible = utils_get_setting_boolean(config, PACKAGE, "toolbar_visible", TRUE); app->toolbar_visible = utils_get_setting_boolean(config, PACKAGE, "toolbar_visible", TRUE);
app->mru_length = utils_get_setting_integer(config, PACKAGE, "mru_length", 10);
app->toolbar_icon_style = utils_get_setting_integer(config, PACKAGE, "toolbar_icon_style", GTK_TOOLBAR_ICONS); app->toolbar_icon_style = utils_get_setting_integer(config, PACKAGE, "toolbar_icon_style", GTK_TOOLBAR_ICONS);
app->toolbar_icon_size = utils_get_setting_integer(config, PACKAGE, "toolbar_icon_size", 2); app->toolbar_icon_size = utils_get_setting_integer(config, PACKAGE, "toolbar_icon_size", 2);
app->long_line_color = utils_get_setting_string(config, PACKAGE, "long_line_color", "#C2EBC2"); app->long_line_color = utils_get_setting_string(config, PACKAGE, "long_line_color", "#C2EBC2");
@ -227,7 +237,7 @@ gboolean configuration_load(void)
app->pref_main_show_search = utils_get_setting_boolean(config, PACKAGE, "pref_main_show_search", TRUE); app->pref_main_show_search = utils_get_setting_boolean(config, PACKAGE, "pref_main_show_search", TRUE);
app->pref_template_developer = utils_get_setting_string(config, PACKAGE, "pref_template_developer", g_get_real_name()); app->pref_template_developer = utils_get_setting_string(config, PACKAGE, "pref_template_developer", g_get_real_name());
app->pref_template_company = utils_get_setting_string(config, PACKAGE, "pref_template_company", ""); app->pref_template_company = utils_get_setting_string(config, PACKAGE, "pref_template_company", "");
app->terminal_settings = utils_get_setting_string(config, PACKAGE, "terminal_settings", "Monospace 10;;;500;xterm;true;true"); app->terminal_settings = utils_get_setting_string(config, PACKAGE, "terminal_settings", "");
tmp_string = utils_get_initials(app->pref_template_developer); tmp_string = utils_get_initials(app->pref_template_developer);
app->pref_template_initial = utils_get_setting_string(config, PACKAGE, "pref_template_initial", tmp_string); app->pref_template_initial = utils_get_setting_string(config, PACKAGE, "pref_template_initial", tmp_string);
@ -285,13 +295,15 @@ gboolean configuration_load(void)
app->recent_files = g_key_file_get_string_list(config, "files", "recent_files", &len, NULL); app->recent_files = g_key_file_get_string_list(config, "files", "recent_files", &len, NULL);
if (app->recent_files != NULL) if (app->recent_files != NULL)
{ {
for (i = 0; (i < len) && (i < GEANY_RECENT_MRU_LENGTH); i++) for (i = 0; (i < len) && (i < app->mru_length); i++)
{ {
g_queue_push_head(app->recent_queue, app->recent_files[i]); g_queue_push_head(app->recent_queue, app->recent_files[i]);
app->recent_files[i] = NULL;
} }
} }
//geany_debug("%d", g_strv_length(app->recent_files));
for(i = 0; i < GEANY_MRU_LENGTH; i++) for(i = 0; i < GEANY_SESSION_FILES; i++)
{ {
g_snprintf(entry, 13, "FILE_NAME_%d", i); g_snprintf(entry, 13, "FILE_NAME_%d", i);
session_files[i] = g_key_file_get_string(config, "files", entry, &error); session_files[i] = g_key_file_get_string(config, "files", entry, &error);
@ -303,6 +315,7 @@ gboolean configuration_load(void)
} }
} }
utils_free_ptr_array(app->recent_files, len);
g_key_file_free(config); g_key_file_free(config);
g_free(configfile); g_free(configfile);
g_free(entry); g_free(entry);
@ -318,7 +331,7 @@ gboolean configuration_open_files(void)
gchar *file, spos[7]; gchar *file, spos[7];
gboolean ret = FALSE; gboolean ret = FALSE;
for(i = GEANY_MRU_LENGTH - 1; i >= 0 ; i--) for(i = GEANY_SESSION_FILES - 1; i >= 0 ; i--)
{ {
if (session_files[i] && strlen(session_files[i])) if (session_files[i] && strlen(session_files[i]))
{ {

View File

@ -44,6 +44,9 @@ void prefs_init_dialog(void)
GdkColor *color; GdkColor *color;
// General settings // General settings
widget = lookup_widget(app->prefs_dialog, "spin_mru");
gtk_spin_button_set_value(GTK_SPIN_BUTTON(widget), app->mru_length);
widget = lookup_widget(app->prefs_dialog, "check_load_session"); widget = lookup_widget(app->prefs_dialog, "check_load_session");
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget), app->pref_main_load_session); gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget), app->pref_main_load_session);
@ -188,6 +191,9 @@ void on_prefs_button_clicked(GtkDialog *dialog, gint response, gpointer user_dat
GtkWidget *widget; GtkWidget *widget;
// General settings // General settings
widget = lookup_widget(app->prefs_dialog, "spin_mru");
app->mru_length = gtk_spin_button_get_value_as_int(GTK_SPIN_BUTTON(widget));
widget = lookup_widget(app->prefs_dialog, "check_load_session"); widget = lookup_widget(app->prefs_dialog, "check_load_session");
app->pref_main_load_session = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget)); app->pref_main_load_session = gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget));
@ -301,9 +307,7 @@ void on_prefs_button_clicked(GtkDialog *dialog, gint response, gpointer user_dat
hex_color_fore = utils_get_hex_from_color(vc->color_fore); hex_color_fore = utils_get_hex_from_color(vc->color_fore);
hex_color_back = utils_get_hex_from_color(vc->color_back); hex_color_back = utils_get_hex_from_color(vc->color_back);
app->terminal_settings = g_strdup_printf("%s;%s;%s;%d;%s;%s;%s", vc->font, app->terminal_settings = g_strdup_printf("%s;%s;%s;%d;%s;%s;%s", vc->font,
//(vc->color_fore->red | (vc->color_fore->green << 8) | (vc->color_fore->blue << 16)), hex_color_fore, hex_color_back,
//(vc->color_back->red | (vc->color_back->green << 8) | (vc->color_back->blue << 16)),
hex_color_back, hex_color_fore,
vc->scrollback_lines, vc->emulation, vc->scrollback_lines, vc->emulation,
utils_btoa(vc->scroll_on_key), utils_btoa(vc->scroll_on_out)); utils_btoa(vc->scroll_on_key), utils_btoa(vc->scroll_on_out));