diff options
Diffstat (limited to 'OpenSim/Data/Migration.cs')
-rw-r--r-- | OpenSim/Data/Migration.cs | 20 |
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)) |