Add and use ui_combo_box_prepend_text_once() to add project's base_path to the Find in Files dialog even if another project was opened.

git-svn-id: https://geany.svn.sourceforge.net/svnroot/geany/trunk@3237 ea778897-0a13-0410-b9d1-a72fbfd435f5
This commit is contained in:
Enrico Tröger 2008-11-16 17:53:55 +00:00
parent 0bfd8eb893
commit 9975737eff
4 changed files with 35 additions and 4 deletions

View File

@ -7,6 +7,10 @@
when a Find in Files search fails. when a Find in Files search fails.
Add the project's base_path to the directory list in the Find in Add the project's base_path to the directory list in the Find in
Files dialog if a project is open. Files dialog if a project is open.
* src/search.c, src/ui_utils.c, src/ui_utils.h:
Add and use ui_combo_box_prepend_text_once() to add project's
base_path to the Find in Files dialog even if another project was
opened.
2008-11-15 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de> 2008-11-15 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>

View File

@ -744,7 +744,6 @@ void search_show_find_in_files_dialog(const gchar *dir)
gchar *sel = NULL; gchar *sel = NULL;
gchar *cur_dir = NULL; gchar *cur_dir = NULL;
GeanyEncodingIndex enc_idx = GEANY_ENCODING_UTF_8; GeanyEncodingIndex enc_idx = GEANY_ENCODING_UTF_8;
static gboolean project_basepath_added = FALSE;
if (widgets.find_in_files_dialog == NULL) if (widgets.find_in_files_dialog == NULL)
{ {
@ -762,11 +761,10 @@ void search_show_find_in_files_dialog(const gchar *dir)
/* add project's base path directory to the dir list, we do this here once /* add project's base path directory to the dir list, we do this here once
* (in create_fif_dialog() it would fail if a project is opened after dialog creation) */ * (in create_fif_dialog() it would fail if a project is opened after dialog creation) */
if (app->project != NULL && NZV(app->project->base_path) && ! project_basepath_added) if (app->project != NULL && NZV(app->project->base_path))
{ {
gtk_combo_box_prepend_text(GTK_COMBO_BOX(find_in_files.dir_combo), ui_combo_box_prepend_text_once(GTK_COMBO_BOX(find_in_files.dir_combo),
app->project->base_path); app->project->base_path);
project_basepath_added = TRUE;
} }
entry = GTK_BIN(find_in_files.dir_combo)->child; entry = GTK_BIN(find_in_files.dir_combo)->child;

View File

@ -1259,6 +1259,33 @@ void ui_combo_box_add_to_history(GtkComboBox *combo, const gchar *text)
} }
/* Same as gtk_combo_box_prepend_text(), except that text is only prepended if it not already
* exists in the combo's model. */
void ui_combo_box_prepend_text_once(GtkComboBox *combo, const gchar *text)
{
GtkTreeModel *model;
GtkTreeIter iter;
gchar *combo_text;
gboolean found = FALSE;
model = gtk_combo_box_get_model(combo);
if (gtk_tree_model_get_iter_first(model, &iter))
{
do
{
gtk_tree_model_get(model, &iter, 0, &combo_text, -1);
found = utils_str_equal(combo_text, text);
g_free(combo_text);
}
while (!found && gtk_tree_model_iter_next(model, &iter));
}
if (found)
return; /* don't prepend duplicate */
gtk_combo_box_prepend_text(combo, text);
}
/* Changes the color of the notebook tab text and open files items according to /* Changes the color of the notebook tab text and open files items according to
* document status. */ * document status. */
void ui_update_tab_status(GeanyDocument *doc) void ui_update_tab_status(GeanyDocument *doc)

View File

@ -154,6 +154,8 @@ void ui_hbutton_box_copy_layout(GtkButtonBox *master, GtkButtonBox *copy);
void ui_combo_box_add_to_history(GtkComboBox *combo, const gchar *text); void ui_combo_box_add_to_history(GtkComboBox *combo, const gchar *text);
void ui_combo_box_prepend_text_once(GtkComboBox *combo, const gchar *text);
GtkWidget *ui_path_box_new(const gchar *title, GtkFileChooserAction action, GtkEntry *entry); GtkWidget *ui_path_box_new(const gchar *title, GtkFileChooserAction action, GtkEntry *entry);
void ui_setup_open_button_callback(GtkWidget *open_btn, const gchar *title, void ui_setup_open_button_callback(GtkWidget *open_btn, const gchar *title,