aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Data/Migration.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Data/Migration.cs')
-rw-r--r--OpenSim/Data/Migration.cs20
1 files changed, 16 insertions, 4 deletions
diff --git a/OpenSim/Data/Migration.cs b/OpenSim/Data/Migration.cs
index e51dc22..0fb9e78 100644
--- a/OpenSim/Data/Migration.cs
+++ b/OpenSim/Data/Migration.cs
@@ -128,7 +128,7 @@ namespace OpenSim.Data
128 return; 128 return;
129 129
130 // to prevent people from killing long migrations. 130 // to prevent people from killing long migrations.
131 m_log.InfoFormat("[MIGRATIONS] Upgrading {0} to latest revision.", _type); 131 m_log.InfoFormat("[MIGRATIONS] Upgrading {0} to latest revision {1}.", _type, migrations.Keys[migrations.Count - 1]);
132 m_log.Info("[MIGRATIONS] NOTE: this may take a while, don't interupt this process!"); 132 m_log.Info("[MIGRATIONS] NOTE: this may take a while, don't interupt this process!");
133 133
134 DbCommand cmd = _conn.CreateCommand(); 134 DbCommand cmd = _conn.CreateCommand();
@@ -138,7 +138,17 @@ namespace OpenSim.Data
138 cmd.CommandText = kvp.Value; 138 cmd.CommandText = kvp.Value;
139 // we need to up the command timeout to infinite as we might be doing long migrations. 139 // we need to up the command timeout to infinite as we might be doing long migrations.
140 cmd.CommandTimeout = 0; 140 cmd.CommandTimeout = 0;
141 cmd.ExecuteNonQuery(); 141 try
142 {
143 cmd.ExecuteNonQuery();
144 }
145 catch (Exception e)
146 {
147 m_log.DebugFormat("[MIGRATIONS] Cmd was {0}", cmd.CommandText);
148 m_log.DebugFormat("[MIGRATIONS]: An error has occurred in the migration {0}.\n This may mean you could see errors trying to run OpenSim. If you see database related errors, you will need to fix the issue manually. Continuing.", e.Message);
149 cmd.CommandText = "ROLLBACK;";
150 cmd.ExecuteNonQuery();
151 }
142 152
143 if (version == 0) 153 if (version == 0)
144 { 154 {
@@ -149,8 +159,9 @@ namespace OpenSim.Data
149 UpdateVersion(_type, newversion); 159 UpdateVersion(_type, newversion);
150 } 160 }
151 version = newversion; 161 version = newversion;
152 cmd.Dispose();
153 } 162 }
163
164 cmd.Dispose();
154 } 165 }
155 166
156 // private int MaxVersion() 167 // private int MaxVersion()
@@ -246,7 +257,8 @@ namespace OpenSim.Data
246 if (m.Success) 257 if (m.Success)
247 { 258 {
248 int version = int.Parse(m.Groups[1].ToString()); 259 int version = int.Parse(m.Groups[1].ToString());
249 if (version > after) { 260 if (version > after)
261 {
250 using (Stream resource = _assem.GetManifestResourceStream(s)) 262 using (Stream resource = _assem.GetManifestResourceStream(s))
251 { 263 {
252 using (StreamReader resourceReader = new StreamReader(resource)) 264 using (StreamReader resourceReader = new StreamReader(resource))