[tracker] libtracker-miner: Improve password provider error handling and reporting
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker] libtracker-miner: Improve password provider error handling and reporting
- Date: Fri, 3 Jun 2011 12:57:43 +0000 (UTC)
commit 4a0a855ea8646fec4f1f56f587bf36d2fbc504c2
Author: Martyn Russell <martyn lanedo com>
Date: Fri Jun 3 12:40:44 2011 +0100
libtracker-miner: Improve password provider error handling and reporting
.../tracker-password-provider-keyfile.c | 30 ++++++++++++--------
1 files changed, 18 insertions(+), 12 deletions(-)
---
diff --git a/src/libtracker-miner/tracker-password-provider-keyfile.c b/src/libtracker-miner/tracker-password-provider-keyfile.c
index a264a78..95cb71a 100644
--- a/src/libtracker-miner/tracker-password-provider-keyfile.c
+++ b/src/libtracker-miner/tracker-password-provider-keyfile.c
@@ -83,7 +83,7 @@ static gchar * password_provider_keyfile_get (TrackerPasswordProvi
static gboolean password_provider_keyfile_forget (TrackerPasswordProvider *provider,
const gchar *service,
GError **error);
-static void load_password_file (TrackerPasswordProviderKeyfile *kf,
+static gboolean load_password_file (TrackerPasswordProviderKeyfile *kf,
GError **error);
static gboolean save_password_file (TrackerPasswordProviderKeyfile *kf,
GError **error);
@@ -131,20 +131,13 @@ password_provider_keyfile_constructed (GObject *object)
{
TrackerPasswordProviderKeyfile *kf;
TrackerPasswordProviderKeyfilePrivate *priv;
- GError *error = NULL;
kf = TRACKER_PASSWORD_PROVIDER_KEYFILE (object);
priv = TRACKER_PASSWORD_PROVIDER_KEYFILE_GET_PRIVATE (kf);
priv->password_file = g_key_file_new ();
- load_password_file (kf, &error);
-
- if (error) {
- g_critical ("Could not load GKeyFile password file, %s",
- error->message);
- g_error_free (error);
- }
+ load_password_file (kf, NULL);
}
static void
@@ -343,17 +336,18 @@ config_dir_ensure_exists_and_return (GError **error)
return directory;
}
-static void
+static gboolean
load_password_file (TrackerPasswordProviderKeyfile *kf,
GError **error)
{
TrackerPasswordProviderKeyfilePrivate *priv;
+ GError *inner_error = NULL;
gchar *filename;
gchar *directory;
directory = config_dir_ensure_exists_and_return (error);
if (!directory) {
- return;
+ return FALSE;
}
filename = g_build_filename (directory, KEYFILE_FILENAME, NULL);
@@ -364,9 +358,21 @@ load_password_file (TrackerPasswordProviderKeyfile *kf,
g_key_file_load_from_file (priv->password_file,
filename,
G_KEY_FILE_KEEP_COMMENTS | G_KEY_FILE_KEEP_TRANSLATIONS,
- error);
+ &inner_error);
+
+ if (inner_error) {
+ g_critical ("Could not load GKeyFile password file '%s', %s",
+ filename,
+ inner_error->message);
+ g_propagate_error (error, inner_error);
+ g_free (filename);
+
+ return FALSE;
+ }
g_free (filename);
+
+ return TRUE;
}
static gboolean
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]