[libgda] Added gdaui_[gs]et_default_path()
- From: Vivien Malerba <vivien src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libgda] Added gdaui_[gs]et_default_path()
- Date: Sat, 4 Jun 2011 09:22:12 +0000 (UTC)
commit 41073e9cae210569eff0b025718b67b4d4deea4a
Author: Vivien Malerba <malerba gnome-db org>
Date: Fri Jun 3 21:08:20 2011 +0200
Added gdaui_[gs]et_default_path()
which allows all GtkFileChooser widgets to have a
common behaviour across the library
doc/C/libgda-5.0-docs.sgml | 3 ++
doc/C/libgda-ui-sections.txt | 2 +
libgda-ui/data-entries/plugins/common-pict.c | 11 +++++-
.../data-entries/plugins/gdaui-entry-filesel.c | 9 +++--
libgda-ui/gdaui-decl.h | 9 +----
libgda-ui/gdaui-init.c | 37 ++++++++++++++++++++
libgda-ui/gdaui-raw-grid.c | 13 +++----
libgda-ui/gdaui-rt-editor.c | 8 +++--
libgda-ui/libgda-ui.h | 16 +++++++--
libgda-ui/libgda-ui.symbols | 2 +
libgda/libgda.symbols | 1 -
tools/browser/canvas/browser-canvas.c | 8 +++--
tools/browser/common/gdaui-data-import.c | 9 ++---
tools/browser/ldap-browser/entry-properties.c | 4 ++
14 files changed, 97 insertions(+), 35 deletions(-)
---
diff --git a/doc/C/libgda-5.0-docs.sgml b/doc/C/libgda-5.0-docs.sgml
index c81d4cb..16548f6 100644
--- a/doc/C/libgda-5.0-docs.sgml
+++ b/doc/C/libgda-5.0-docs.sgml
@@ -1720,6 +1720,9 @@ g_object_unref (eng);
<index id="index-4-2-8" role="4.2.8">
<title>Index of new symbols in 4.2.8</title>
</index>
+ <index id="index-4-2-9" role="4.2.9">
+ <title>Index of new symbols in 4.2.9</title>
+ </index>
<index id="index-5-0" role="5.0">
<title>Index of new symbols in 5.0</title>
</index>
diff --git a/doc/C/libgda-ui-sections.txt b/doc/C/libgda-ui-sections.txt
index 21cae09..13656e3 100644
--- a/doc/C/libgda-ui-sections.txt
+++ b/doc/C/libgda-ui-sections.txt
@@ -2,6 +2,8 @@
<FILE>libgdaui</FILE>
<TITLE>LibgdaUI Initialization</TITLE>
gdaui_init
+gdaui_get_default_path
+gdaui_set_default_path
<SUBSECTION Standard>
</SECTION>
diff --git a/libgda-ui/data-entries/plugins/common-pict.c b/libgda-ui/data-entries/plugins/common-pict.c
index 2aeb1a2..1c3defd 100644
--- a/libgda-ui/data-entries/plugins/common-pict.c
+++ b/libgda-ui/data-entries/plugins/common-pict.c
@@ -1,4 +1,4 @@
-/* common-pict.c
+/*
* Copyright (C) 2006 - 2011 Vivien Malerba <malerba gnome-db org>
*
* This library is free software; you can redistribute it and/or
@@ -21,6 +21,7 @@
#include <string.h>
#include <libgda/gda-quark-list.h>
#include <libgda/gda-blob-op.h>
+#include <libgda-ui/libgda-ui.h>
/*
* Fills in @bindata->data and @bindata->data_length with the contents of @value.
@@ -335,7 +336,9 @@ file_load_cb (GtkWidget *button, PictMenuData *menudata)
filter = gtk_file_filter_new ();
gtk_file_filter_add_pixbuf_formats (filter);
gtk_file_chooser_set_filter (GTK_FILE_CHOOSER (dlg), filter);
-
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dlg),
+ gdaui_get_default_path ());
+
if (gtk_dialog_run (GTK_DIALOG (dlg)) == GTK_RESPONSE_ACCEPT) {
char *filename;
gsize length;
@@ -343,6 +346,7 @@ file_load_cb (GtkWidget *button, PictMenuData *menudata)
gchar *data;
filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dlg));
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dlg)));
if (g_file_get_contents (filename, &data, &length, &error)) {
if (menudata->bindata->data) {
@@ -456,6 +460,8 @@ file_save_cb (GtkWidget *button, PictMenuData *menudata)
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT,
NULL);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dlg),
+ gdaui_get_default_path ());
gtk_file_chooser_set_extra_widget (GTK_FILE_CHOOSER (dlg), expander);
if (gtk_dialog_run (GTK_DIALOG (dlg)) == GTK_RESPONSE_ACCEPT) {
@@ -466,6 +472,7 @@ file_save_cb (GtkWidget *button, PictMenuData *menudata)
format = gtk_combo_box_get_active (GTK_COMBO_BOX (combo));
filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dlg));
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dlg)));
if (format == 0) {
/* save data AS IS */
diff --git a/libgda-ui/data-entries/plugins/gdaui-entry-filesel.c b/libgda-ui/data-entries/plugins/gdaui-entry-filesel.c
index e7ca003..728ffe7 100644
--- a/libgda-ui/data-entries/plugins/gdaui-entry-filesel.c
+++ b/libgda-ui/data-entries/plugins/gdaui-entry-filesel.c
@@ -1,6 +1,5 @@
-/* gdaui-entry-filesel.c
- *
- * Copyright (C) 2005 - 2010 Vivien Malerba
+/*
+ * Copyright (C) 2005 - 2011 Vivien Malerba
*
* This Library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public License as
@@ -21,6 +20,7 @@
#include <glib/gi18n-lib.h>
#include "gdaui-entry-filesel.h"
#include <libgda/gda-data-handler.h>
+#include <libgda-ui/libgda-ui.h>
/*
* Main static functions
@@ -201,6 +201,8 @@ button_clicked_cb (G_GNUC_UNUSED GtkWidget *button, GdauiEntryFilesel *filesel)
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
GTK_STOCK_APPLY, GTK_RESPONSE_ACCEPT,
NULL);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dlg),
+ gdaui_get_default_path ());
result = gtk_dialog_run (GTK_DIALOG (dlg));
if (result == GTK_RESPONSE_ACCEPT) {
@@ -209,6 +211,7 @@ button_clicked_cb (G_GNUC_UNUSED GtkWidget *button, GdauiEntryFilesel *filesel)
file = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dlg));
gtk_entry_set_text (GTK_ENTRY (filesel->priv->entry), file);
g_free (file);
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dlg)));
}
gtk_widget_destroy (dlg);
}
diff --git a/libgda-ui/gdaui-decl.h b/libgda-ui/gdaui-decl.h
index 5cfb529..2170e56 100644
--- a/libgda-ui/gdaui-decl.h
+++ b/libgda-ui/gdaui-decl.h
@@ -1,6 +1,5 @@
-/* gdaui-decl.h
- *
- * Copyright (C) 2003 - 2009 Vivien Malerba <malerba gnome-db org>
+/*
+ * Copyright (C) 2003 - 2011 Vivien Malerba <malerba gnome-db org>
*
* This Library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public License as
@@ -43,8 +42,4 @@ typedef struct _GdauiDataProxyIface GdauiDataProxyIface;
#define GDAUI_COLOR_NORMAL_INVALID "#ff6a6a"
#define GDAUI_COLOR_PRELIGHT_INVALID "#ff7b7b"
-#define GDAUI_REFERER_ACTIVE "#e0ffe0"
-#define GDAUI_REFERER_INACTIVE "#ffe0e0"
-#define GDAUI_REFERER_UNKNOWN "#e0e0ff"
-
#endif
diff --git a/libgda-ui/gdaui-init.c b/libgda-ui/gdaui-init.c
index c212af2..aa1cd5a 100644
--- a/libgda-ui/gdaui-init.c
+++ b/libgda-ui/gdaui-init.c
@@ -734,3 +734,40 @@ get_spec_with_isocodes (const gchar *file)
return retval;
}
+
+static gchar *gdaui_path = NULL;
+
+/**
+ * gdaui_get_default_path:
+ *
+ * Get the default path used when saving a file, or when showing a #GtkFileChooser file chooser.
+ * When the application starts, the default path will be the same as the onde returned by
+ * g_get_current_dir().
+ *
+ * Returns: (transfer none): the default path, or %NULL
+ *
+ * Since: 4.2.9
+ */
+const gchar *
+gdaui_get_default_path (void)
+{
+ if (! gdaui_path)
+ gdaui_path = g_get_current_dir ();
+ return gdaui_path;
+}
+
+/**
+ * gdaui_set_default_path:
+ *
+ * Define the default path used when saving a file, or when showing a #GtkFileChooser file chooser.
+ *
+ * Since: 4.2.9
+ */
+void
+gdaui_set_default_path (const gchar *path)
+{
+ g_free (gdaui_path);
+ gdaui_path = NULL;
+ if (path)
+ gdaui_path = g_strdup (path);
+}
diff --git a/libgda-ui/gdaui-raw-grid.c b/libgda-ui/gdaui-raw-grid.c
index 7a0a2a0..38f8819 100644
--- a/libgda-ui/gdaui-raw-grid.c
+++ b/libgda-ui/gdaui-raw-grid.c
@@ -21,13 +21,9 @@
#include <gdk/gdkkeysyms.h>
#include <glib/gi18n-lib.h>
#include <libgda/libgda.h>
-#include "gdaui-raw-grid.h"
-#include "gdaui-data-proxy.h"
-#include "gdaui-data-filter.h"
-#include "gdaui-data-selector.h"
+#include <libgda-ui.h>
#include "internal/utility.h"
#include "marshallers/gdaui-marshal.h"
-#include "gdaui-easy.h"
#include "data-entries/gdaui-data-cell-renderer-combo.h"
#include "data-entries/gdaui-data-cell-renderer-info.h"
#include <libgda/binreloc/gda-binreloc.h>
@@ -850,7 +846,7 @@ create_columns_data (GdauiRawGrid *grid)
/* keep track of the columns shown and hidden */
static void
-column_visibility_changed (GtkTreeViewColumn *column, GParamSpec *pspec, ColumnData *cdata)
+column_visibility_changed (GtkTreeViewColumn *column, G_GNUC_UNUSED GParamSpec *pspec, ColumnData *cdata)
{
cdata->hidden = !gtk_tree_view_column_get_visible (column);
}
@@ -1752,7 +1748,7 @@ static GtkWidget *new_check_menu_item (const gchar *label,
gpointer user_data);
static void
-hidden_column_mitem_toggled_cb (GtkCheckMenuItem *check, GdauiRawGrid *grid)
+hidden_column_mitem_toggled_cb (GtkCheckMenuItem *check, G_GNUC_UNUSED GdauiRawGrid *grid)
{
ColumnData *cdata;
gboolean act;
@@ -1961,6 +1957,8 @@ menu_save_as_cb (G_GNUC_UNUSED GtkWidget *widget, GdauiRawGrid *grid)
g_object_set_data (G_OBJECT (dialog), "filename", filename);
gtk_box_pack_start (GTK_BOX (hbox), filename, TRUE, TRUE, 0);
gtk_widget_show (filename);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (filename),
+ gdaui_get_default_path ());
str = g_strdup_printf ("<b>%s:</b>", _("Details"));
label = gtk_label_new ("");
@@ -2106,6 +2104,7 @@ save_as_response_cb (GtkDialog *dialog, gint response_id, GdauiRawGrid *grid)
types = g_object_get_data (G_OBJECT (dialog), "types");
filename = g_object_get_data (G_OBJECT (dialog), "filename");
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (filename)));
selection_only = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON
(g_object_get_data (G_OBJECT (dialog), "sel_only")));
null_as_empty = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON
diff --git a/libgda-ui/gdaui-rt-editor.c b/libgda-ui/gdaui-rt-editor.c
index c89357d..83f3a78 100644
--- a/libgda-ui/gdaui-rt-editor.c
+++ b/libgda-ui/gdaui-rt-editor.c
@@ -1,5 +1,4 @@
-/* gdaui-rt-editor.c
- *
+/*
* Copyright (C) 2010 - 2011 Vivien Malerba <malerba gnome-db org>
*
* This Library is free software; you can redistribute it and/or
@@ -19,13 +18,13 @@
*/
#include <string.h>
-#include "gdaui-rt-editor.h"
#include <glib/gi18n-lib.h>
#include <gdk-pixbuf/gdk-pixdata.h>
#include "bullet.h"
#include "bulleth.h"
#define MAX_BULLETS 2
//gchar * bullet_strings[] = {"â?¢", "â?¦"};
+#include <libgda-ui.h>
GdkPixbuf *bullet_pix[MAX_BULLETS] = {NULL};
gchar *lists_tokens[MAX_BULLETS] = {"- ", " - "};
@@ -675,6 +674,8 @@ add_image_cb (G_GNUC_UNUSED GtkAction *action, GdauiRtEditor *rte)
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT,
NULL);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dlg),
+ gdaui_get_default_path ());
filter = gtk_file_filter_new ();
gtk_file_filter_add_pixbuf_formats (filter);
gtk_file_chooser_set_filter (GTK_FILE_CHOOSER (dlg), filter);
@@ -684,6 +685,7 @@ add_image_cb (G_GNUC_UNUSED GtkAction *action, GdauiRtEditor *rte)
GError *error = NULL;
filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dlg));
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dlg)));
GdkPixbuf *pixbuf;
pixbuf = gdk_pixbuf_new_from_file (filename, &error);
diff --git a/libgda-ui/libgda-ui.h b/libgda-ui/libgda-ui.h
index 05cbf64..ae6433a 100644
--- a/libgda-ui/libgda-ui.h
+++ b/libgda-ui/libgda-ui.h
@@ -1,5 +1,5 @@
-/* GDA library
- * Copyright (C) 2009 - 2010 The GNOME Foundation.
+/*
+ * Copyright (C) 2009 - 2011 The GNOME Foundation.
*
* AUTHORS:
* Vivien Malerba <malerba gnome-db org>
@@ -48,7 +48,17 @@
G_BEGIN_DECLS
-void gdaui_init (void);
+/**
+ * SECTION:libgdaui
+ * @short_description: Library initialization and information
+ * @title: Library initialization
+ * @stability: Stable
+ * @see_also:
+ */
+
+void gdaui_init (void);
+const gchar *gdaui_get_default_path (void);
+void gdaui_set_default_path (const gchar *path);
G_END_DECLS
diff --git a/libgda-ui/libgda-ui.symbols b/libgda-ui/libgda-ui.symbols
index 97ec1d8..81731ba 100644
--- a/libgda-ui/libgda-ui.symbols
+++ b/libgda-ui/libgda-ui.symbols
@@ -135,6 +135,7 @@
gdaui_formatted_entry_set_insert_func
gdaui_form_get_type
gdaui_form_new
+ gdaui_get_default_path
gdaui_grid_get_type
gdaui_grid_new
gdaui_grid_set_sample_size
@@ -172,6 +173,7 @@
gdaui_server_operation_get_type
gdaui_server_operation_new
gdaui_server_operation_new_in_dialog
+ gdaui_set_default_path
gdaui_tree_store_get_iter
gdaui_tree_store_get_node
gdaui_tree_store_get_type
diff --git a/libgda/libgda.symbols b/libgda/libgda.symbols
index 0cf408a..9eeead1 100644
--- a/libgda/libgda.symbols
+++ b/libgda/libgda.symbols
@@ -824,7 +824,6 @@
gda_transaction_status_add_event_sql
gda_transaction_status_add_event_sub
gda_transaction_status_add_event_svp
- gda_transaction_status_dump
gda_transaction_status_event_type_get_type
gda_transaction_status_find
gda_transaction_status_find_current
diff --git a/tools/browser/canvas/browser-canvas.c b/tools/browser/canvas/browser-canvas.c
index ea92812..ccbccec 100644
--- a/tools/browser/canvas/browser-canvas.c
+++ b/tools/browser/canvas/browser-canvas.c
@@ -1,6 +1,5 @@
-/* browser-canvas.c
- *
- * Copyright (C) 2007 - 2010 Vivien Malerba
+/*
+ * Copyright (C) 2007 - 2011 Vivien Malerba
*
* This Program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
@@ -483,6 +482,8 @@ popup_export_cb (G_GNUC_UNUSED GtkMenuItem *mitem, BrowserCanvas *canvas)
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT,
NULL);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dlg),
+ gdaui_get_default_path ());
filter = gtk_file_filter_new ();
gtk_file_filter_set_name (filter, _("PNG Image"));
gtk_file_filter_add_mime_type (filter, "image/png");
@@ -499,6 +500,7 @@ popup_export_cb (G_GNUC_UNUSED GtkMenuItem *mitem, BrowserCanvas *canvas)
gchar *lcfilename;
cairo_surface_t *surface = NULL;
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dlg)));
filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dlg));
if (filename) {
GooCanvasBounds bounds;
diff --git a/tools/browser/common/gdaui-data-import.c b/tools/browser/common/gdaui-data-import.c
index 600403c..0082868 100644
--- a/tools/browser/common/gdaui-data-import.c
+++ b/tools/browser/common/gdaui-data-import.c
@@ -21,12 +21,7 @@
#include "gdaui-data-import.h"
#include <libgda/libgda.h>
#include <glib/gi18n-lib.h>
-#include <libgda-ui/gdaui-combo.h>
-#include <libgda-ui/gdaui-grid.h>
-#include <libgda-ui/gdaui-raw-grid.h>
-#include <libgda-ui/gdaui-data-proxy.h>
-#include <libgda-ui/gdaui-data-proxy-info.h>
-#include <libgda-ui/gdaui-data-selector.h>
+#include <libgda-ui/libgda-ui.h>
#include <libgda/binreloc/gda-binreloc.h>
static void gdaui_data_import_class_init (GdauiDataImportClass *class);
@@ -144,6 +139,7 @@ gdaui_data_import_init (GdauiDataImport * import)
gtk_table_attach (GTK_TABLE (table), label, 0, 1, 0, 1, GTK_SHRINK | GTK_FILL, 0, 0, 0);
entry = gtk_file_chooser_button_new (_("File to import data from"), GTK_FILE_CHOOSER_ACTION_OPEN);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (entry), gdaui_get_default_path ());
import->priv->file_chooser = entry;
filter = gtk_file_filter_new ();
gtk_file_filter_set_name (filter, _("Comma separated values"));
@@ -425,6 +421,7 @@ spec_changed_cb (GtkWidget *wid, GdauiDataImport *import)
GDAUI_DATA_PROXY_INFO_CURRENT_ROW, NULL);
gtk_box_pack_start (GTK_BOX (import->priv->preview_box), import->priv->preview_grid, TRUE, TRUE, 0);
gtk_widget_show (import->priv->preview_grid);
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (import->priv->file_chooser)));
}
else
gtk_widget_show (import->priv->no_data_label);
diff --git a/tools/browser/ldap-browser/entry-properties.c b/tools/browser/ldap-browser/entry-properties.c
index 23f5dce..e320997 100644
--- a/tools/browser/ldap-browser/entry-properties.c
+++ b/tools/browser/ldap-browser/entry-properties.c
@@ -26,6 +26,7 @@
#include "entry-properties.h"
#include "marshal.h"
#include <time.h>
+#include <libgda-ui/libgda-ui.h>
struct _EntryPropertiesPrivate {
BrowserConnection *bcnc;
@@ -219,6 +220,8 @@ data_save_cb (GtkWidget *mitem, EntryProperties *eprop)
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT,
NULL);
+ gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog),
+ gdaui_get_default_path ());
if (gtk_dialog_run (GTK_DIALOG (dialog)) == GTK_RESPONSE_ACCEPT) {
char *filename;
GValue *binvalue;
@@ -236,6 +239,7 @@ data_save_cb (GtkWidget *mitem, EntryProperties *eprop)
lerror && lerror->message ? lerror->message : _("No detail"));
g_clear_error (&lerror);
}
+ gdaui_set_default_path (gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog)));
g_free (filename);
}
gtk_widget_destroy (dialog);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]