zeitgeist team mailing list archive
-
zeitgeist team
-
Mailing list archive
-
Message #05198
[Branch ~zeitgeist/zeitgeist/bluebird] Rev 435: Storage Monitor Extensions: fix bug lp:950983
------------------------------------------------------------
revno: 435
committer: Seif Lotfy <seif@xxxxxxxxx>
branch nick: zeitgeist
timestamp: Mon 2012-03-19 11:02:10 +0100
message:
Storage Monitor Extensions: fix bug lp:950983
modified:
extensions/storage-monitor.vala
--
lp:zeitgeist
https://code.launchpad.net/~zeitgeist/zeitgeist/bluebird
Your team Zeitgeist Framework Team is subscribed to branch lp:zeitgeist.
To unsubscribe from this branch go to https://code.launchpad.net/~zeitgeist/zeitgeist/bluebird/+edit-subscription
=== modified file 'extensions/storage-monitor.vala'
--- extensions/storage-monitor.vala 2012-02-10 13:35:02 +0000
+++ extensions/storage-monitor.vala 2012-03-19 10:02:10 +0000
@@ -112,8 +112,10 @@
private Sqlite.Statement get_storages_stmt;
private Sqlite.Statement store_storage_medium_stmt;
+ private Sqlite.Statement update_storage_medium_stmt;
private Sqlite.Statement insert_unavailable_medium_stmt;
private Sqlite.Statement update_medium_state_stmt;
+ private Sqlite.Statement get_storage_medium_id_stmt;
private NetworkMonitor network;
private uint watch_connman;
@@ -236,7 +238,7 @@
database.assert_query_success (rc, "Storage retrieval query error");
sql = """
- INSERT OR REPLACE INTO storage (
+ INSERT INTO storage (
value, state, icon, display_name
) VALUES (
?, ?, ?, ?
@@ -245,6 +247,14 @@
database.assert_query_success (rc, "Storage insertion query error");
sql = """
+ UPDATE storage SET
+ state=?, icon=?, display_name=?
+ WHERE value=?
+ """;
+ rc = db.prepare_v2 (sql, -1, out update_storage_medium_stmt);
+ database.assert_query_success (rc, "Storage update query error");
+
+ sql = """
INSERT INTO storage (
state, value
) VALUES (
@@ -262,6 +272,13 @@
rc = db.prepare_v2 (sql, -1, out update_medium_state_stmt);
database.assert_query_success (rc,
"update_medium_state_stmt error");
+
+ sql = """
+ SELECT id FROM storage WHERE value=?
+ """;
+ rc = db.prepare_v2 (sql, -1, out get_storage_medium_id_stmt);
+ database.assert_query_success (rc,
+ "get_storage_medium_id_stmt error");
}
public override void pre_insert_events (GenericArray<Event?> events,
@@ -355,15 +372,31 @@
string display_name)
{
debug ("VOLUME ADDED: %s".printf(medium_name));
- store_storage_medium_stmt.reset ();
- store_storage_medium_stmt.bind_text (1, medium_name);
- store_storage_medium_stmt.bind_int (2, 1);
- store_storage_medium_stmt.bind_text (3, icon);
- store_storage_medium_stmt.bind_text (4, display_name);
- int rc = store_storage_medium_stmt.step ();
- database.assert_query_success (rc, "add_storage_medium",
- Sqlite.DONE);
+ get_storage_medium_id_stmt.reset ();
+ get_storage_medium_id_stmt.bind_text (1, medium_name);
+ if (get_storage_medium_id_stmt.step () == Sqlite.ROW)
+ {
+ update_storage_medium_stmt.reset ();
+ update_storage_medium_stmt.bind_int (1, 1);
+ update_storage_medium_stmt.bind_text (2, icon);
+ update_storage_medium_stmt.bind_text (3, display_name);
+ update_storage_medium_stmt.bind_text (4, medium_name);
+ int rc = update_storage_medium_stmt.step ();
+ database.assert_query_success (rc, "update_storage_medium",
+ Sqlite.DONE);
+ }
+ else
+ {
+ store_storage_medium_stmt.reset ();
+ store_storage_medium_stmt.bind_text (1, medium_name);
+ store_storage_medium_stmt.bind_int (2, 1);
+ store_storage_medium_stmt.bind_text (3, icon);
+ store_storage_medium_stmt.bind_text (4, display_name);
+ int rc = store_storage_medium_stmt.step ();
+ database.assert_query_success (rc, "add_storage_medium",
+ Sqlite.DONE);
+ }
storage_available (medium_name, StorageMedia.to_variant (
medium_name, true, icon, display_name));