Don't set Hidden=true when disabling autostart, because gnome-session skips
[beagle.git] / beagled / SqliteUtils.cs
blob054ae7c930b065fe20ffac242b23e7b1210c29aa
1 //
2 // SqliteUtils.cs
3 //
4 // Copyright (C) 2004-2006 Novell, Inc.
5 //
7 //
8 // Permission is hereby granted, free of charge, to any person obtaining a copy
9 // of this software and associated documentation files (the "Software"), to deal
10 // in the Software without restriction, including without limitation the rights
11 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 // copies of the Software, and to permit persons to whom the Software is
13 // furnished to do so, subject to the following conditions:
15 // The above copyright notice and this permission notice shall be included in all
16 // copies or substantial portions of the Software.
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
24 // SOFTWARE.
27 using System;
28 using System.Threading;
30 using Mono.Data.SqliteClient;
32 namespace Beagle.Util {
34 public class SqliteUtils {
36 // static class
37 private SqliteUtils () { }
39 public static int DoNonQuery (SqliteConnection connection, string command_text)
41 SqliteCommand command;
42 command = new SqliteCommand ();
43 command.Connection = connection;
44 command.CommandText = command_text;
45 int ret = 0;
47 while (true) {
48 try {
49 ret = command.ExecuteNonQuery ();
50 break;
51 } catch (SqliteBusyException ex) {
52 Thread.Sleep (50);
56 command.Dispose ();
57 return ret;
60 public static int DoNonQuery (SqliteConnection connection, string format, params object [] args)
62 return DoNonQuery (connection, String.Format (format, args));
65 public static SqliteCommand QueryCommand (SqliteConnection connection, string where_format, params object [] where_args)
67 SqliteCommand command;
68 command = new SqliteCommand ();
69 command.Connection = connection;
70 command.CommandText =
71 "SELECT unique_id, directory, filename, last_mtime, last_attrtime, filter_name, filter_version " +
72 "FROM file_attributes WHERE " +
73 String.Format (where_format, where_args);
74 return command;
77 public static SqliteDataReader ExecuteReaderOrWait (SqliteCommand command)
79 SqliteDataReader reader = null;
80 while (reader == null) {
81 try {
82 reader = command.ExecuteReader ();
83 } catch (SqliteBusyException ex) {
84 Thread.Sleep (50);
87 return reader;
90 public static bool ReadOrWait (SqliteDataReader reader)
92 while (true) {
93 try {
94 return reader.Read ();
95 } catch (SqliteBusyException ex) {
96 Thread.Sleep (50);
101 public static string Sanitize (string item)
103 return item.Replace ("'", "''");