From 1c08f46ec3397f4e4fd5897107c0df89bec70d84 Mon Sep 17 00:00:00 2001 From: Homer Horwitz Date: Thu, 18 Sep 2008 20:10:09 +0000 Subject: - Add Dispose method to IRegionDataStore - Add necessary dummy Dispose-methods where they are missing - Implement the SQLite Dispose-methods (currently only used for unit tests, in the next commit) --- OpenSim/Data/MSSQL/MSSQLRegionData.cs | 5 +++ OpenSim/Data/MySQL/MySQLRegionData.cs | 2 ++ OpenSim/Data/NHibernate/NHibernateRegionData.cs | 2 ++ OpenSim/Data/Null/NullDataStore.cs | 4 +++ OpenSim/Data/SQLite/SQLiteAssetData.cs | 9 ++++- OpenSim/Data/SQLite/SQLiteInventoryStore.cs | 33 +++++++++++++----- OpenSim/Data/SQLite/SQLiteRegionData.cs | 40 ++++++++++++++++++++++ OpenSim/Data/SQLite/SQLiteUserData.cs | 25 +++++++++++++- .../Environment/Interfaces/IRegionDataStore.cs | 5 +++ 9 files changed, 115 insertions(+), 10 deletions(-) diff --git a/OpenSim/Data/MSSQL/MSSQLRegionData.cs b/OpenSim/Data/MSSQL/MSSQLRegionData.cs index 8b808d3..ae94252 100644 --- a/OpenSim/Data/MSSQL/MSSQLRegionData.cs +++ b/OpenSim/Data/MSSQL/MSSQLRegionData.cs @@ -156,6 +156,11 @@ namespace OpenSim.Data.MSSQL //After this we have a empty fully configured DataSet. } + + /// + /// Dispose the database + /// + public void Dispose() {} /// /// Loads the objects present in the region. diff --git a/OpenSim/Data/MySQL/MySQLRegionData.cs b/OpenSim/Data/MySQL/MySQLRegionData.cs index 9c36d49..284c970 100644 --- a/OpenSim/Data/MySQL/MySQLRegionData.cs +++ b/OpenSim/Data/MySQL/MySQLRegionData.cs @@ -203,6 +203,8 @@ namespace OpenSim.Data.MySQL } } + public void Dispose() {} + /// /// Get the wait_timeout value for our connection /// diff --git a/OpenSim/Data/NHibernate/NHibernateRegionData.cs b/OpenSim/Data/NHibernate/NHibernateRegionData.cs index 07bf05c..ecb29fe 100644 --- a/OpenSim/Data/NHibernate/NHibernateRegionData.cs +++ b/OpenSim/Data/NHibernate/NHibernateRegionData.cs @@ -105,6 +105,8 @@ namespace OpenSim.Data.NHibernate * **********************************************************************/ + public void Dispose() {} + public void StoreRegionSettings(RegionSettings rs) { } diff --git a/OpenSim/Data/Null/NullDataStore.cs b/OpenSim/Data/Null/NullDataStore.cs index aea03d6..94ad4af 100644 --- a/OpenSim/Data/Null/NullDataStore.cs +++ b/OpenSim/Data/Null/NullDataStore.cs @@ -43,6 +43,10 @@ namespace OpenSim.Data.Null return; } + public void Dispose() + { + } + public void StoreRegionSettings(RegionSettings rs) { } diff --git a/OpenSim/Data/SQLite/SQLiteAssetData.cs b/OpenSim/Data/SQLite/SQLiteAssetData.cs index 8b14f09..17af2b0 100644 --- a/OpenSim/Data/SQLite/SQLiteAssetData.cs +++ b/OpenSim/Data/SQLite/SQLiteAssetData.cs @@ -56,7 +56,14 @@ namespace OpenSim.Data.SQLite private SqliteConnection m_conn; - override public void Dispose() { } + override public void Dispose() + { + if (m_conn != null) + { + m_conn.Close(); + m_conn = null; + } + } /// /// diff --git a/OpenSim/Data/SQLite/SQLiteInventoryStore.cs b/OpenSim/Data/SQLite/SQLiteInventoryStore.cs index ca7e612..49d351a 100644 --- a/OpenSim/Data/SQLite/SQLiteInventoryStore.cs +++ b/OpenSim/Data/SQLite/SQLiteInventoryStore.cs @@ -46,6 +46,7 @@ namespace OpenSim.Data.SQLite private const string invItemsSelect = "select * from inventoryitems"; private const string invFoldersSelect = "select * from inventoryfolders"; + private SqliteConnection conn; private DataSet ds; private SqliteDataAdapter invItemsDa; private SqliteDataAdapter invFoldersDa; @@ -71,7 +72,7 @@ namespace OpenSim.Data.SQLite dbconnect = "URI=file:inventoryStore.db,version=3"; } m_log.Info("[INVENTORY DB]: Sqlite - connecting: " + dbconnect); - SqliteConnection conn = new SqliteConnection(dbconnect); + conn = new SqliteConnection(dbconnect); conn.Open(); @@ -102,6 +103,29 @@ namespace OpenSim.Data.SQLite } /// + /// Closes the inventory interface + /// + public void Dispose() + { + if(conn != null) { + conn.Close(); + conn = null; + } + if(invItemsDa != null) { + invItemsDa.Dispose(); + invItemsDa = null; + } + if(invFoldersDa != null) { + invFoldersDa.Dispose(); + invFoldersDa = null; + } + if(ds != null) { + ds.Dispose(); + ds = null; + } + } + + /// /// /// /// @@ -278,13 +302,6 @@ namespace OpenSim.Data.SQLite } /// - /// Closes the inventory interface - /// - public void Dispose() - { - } - - /// /// The name of this DB provider /// /// Name of DB provider diff --git a/OpenSim/Data/SQLite/SQLiteRegionData.cs b/OpenSim/Data/SQLite/SQLiteRegionData.cs index 36b3d2f..f71535f 100644 --- a/OpenSim/Data/SQLite/SQLiteRegionData.cs +++ b/OpenSim/Data/SQLite/SQLiteRegionData.cs @@ -203,6 +203,46 @@ namespace OpenSim.Data.SQLite } } + public void Dispose() + { + if(m_conn != null) { + m_conn.Close(); + m_conn = null; + } + if(ds != null) { + ds.Dispose(); + ds = null; + } + if(primDa != null) { + primDa.Dispose(); + primDa = null; + } + if(shapeDa != null) { + shapeDa.Dispose(); + shapeDa = null; + } + if(itemsDa != null) { + itemsDa.Dispose(); + itemsDa = null; + } + if(terrainDa != null) { + terrainDa.Dispose(); + terrainDa = null; + } + if(landDa != null) { + landDa.Dispose(); + landDa = null; + } + if(landAccessListDa != null) { + landAccessListDa.Dispose(); + landAccessListDa = null; + } + if(regionSettingsDa != null) { + regionSettingsDa.Dispose(); + regionSettingsDa = null; + } + } + public void StoreRegionSettings(RegionSettings rs) { lock (ds) diff --git a/OpenSim/Data/SQLite/SQLiteUserData.cs b/OpenSim/Data/SQLite/SQLiteUserData.cs index 2c1e3c3..a238ebf 100644 --- a/OpenSim/Data/SQLite/SQLiteUserData.cs +++ b/OpenSim/Data/SQLite/SQLiteUserData.cs @@ -122,7 +122,30 @@ namespace OpenSim.Data.SQLite return; } - public override void Dispose () {} + public override void Dispose () + { + if(g_conn != null) { + g_conn.Close(); + g_conn = null; + } + if(ds != null) { + ds.Dispose(); + ds = null; + } + if(da != null) { + da.Dispose(); + da = null; + } + if(daf != null) { + daf.Dispose(); + daf = null; + } + if(dua != null) { + dua.Dispose(); + dua = null; + } + aplist = null; + } /// /// see IUserDataPlugin, diff --git a/OpenSim/Region/Environment/Interfaces/IRegionDataStore.cs b/OpenSim/Region/Environment/Interfaces/IRegionDataStore.cs index 5f10ec5..0ee4933 100644 --- a/OpenSim/Region/Environment/Interfaces/IRegionDataStore.cs +++ b/OpenSim/Region/Environment/Interfaces/IRegionDataStore.cs @@ -42,6 +42,11 @@ namespace OpenSim.Region.Environment.Interfaces void Initialise(string filename); /// + /// Dispose the database + /// + void Dispose(); + + /// /// Stores all object's details apart from inventory /// /// -- cgit v1.1