aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Data/SQLite/SQLiteAvatarData.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Data/SQLite/SQLiteAvatarData.cs (renamed from OpenSim/Grid/Manager/OpenGridServices.Manager/BlockingQueue.cs)48
1 files changed, 31 insertions, 17 deletions
diff --git a/OpenSim/Grid/Manager/OpenGridServices.Manager/BlockingQueue.cs b/OpenSim/Data/SQLite/SQLiteAvatarData.cs
index 2e39cd0..b3f4a4c 100644
--- a/OpenSim/Grid/Manager/OpenGridServices.Manager/BlockingQueue.cs
+++ b/OpenSim/Data/SQLite/SQLiteAvatarData.cs
@@ -26,34 +26,48 @@
26 */ 26 */
27 27
28using System; 28using System;
29using System.Threading;
30using System.Collections.Generic; 29using System.Collections.Generic;
31using System.Text; 30using System.Data;
31using System.Reflection;
32using System.Threading;
33using log4net;
34using OpenMetaverse;
35using OpenSim.Framework;
36using Mono.Data.SqliteClient;
32 37
33namespace OpenGridServices.Manager 38namespace OpenSim.Data.SQLite
34{ 39{
35 public class BlockingQueue<T> 40 /// <summary>
41 /// A SQLite Interface for Avatar Data
42 /// </summary>
43 public class SQLiteAvatarData : SQLiteGenericTableHandler<AvatarBaseData>,
44 IAvatarData
36 { 45 {
37 private Queue<T> _queue = new Queue<T>(); 46 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
38 private object _queueSync = new object();
39 47
40 public void Enqueue(T value) 48 public SQLiteAvatarData(string connectionString, string realm) :
49 base(connectionString, realm, "Avatar")
41 { 50 {
42 lock (_queueSync)
43 {
44 _queue.Enqueue(value);
45 Monitor.Pulse(_queueSync);
46 }
47 } 51 }
48 52
49 public T Dequeue() 53 public bool Delete(UUID principalID, string name)
50 { 54 {
51 lock (_queueSync) 55 SqliteCommand cmd = new SqliteCommand();
56
57 cmd.CommandText = String.Format("delete from {0} where `PrincipalID` = :PrincipalID and `Name` = :Name", m_Realm);
58 cmd.Parameters.Add(":PrincipalID", principalID.ToString());
59 cmd.Parameters.Add(":Name", name);
60
61 try
52 { 62 {
53 if (_queue.Count < 1) 63 if (ExecuteNonQuery(cmd, m_Connection) > 0)
54 Monitor.Wait(_queueSync); 64 return true;
55 65
56 return _queue.Dequeue(); 66 return false;
67 }
68 finally
69 {
70 CloseCommand(cmd);
57 } 71 }
58 } 72 }
59 } 73 }