diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/CoreModules/World/Archiver/ArchiveReadRequest.cs | 13 | ||||
-rw-r--r-- | OpenSim/Region/CoreModules/World/Archiver/DearchiveScenesGroup.cs | 15 |
2 files changed, 19 insertions, 9 deletions
diff --git a/OpenSim/Region/CoreModules/World/Archiver/ArchiveReadRequest.cs b/OpenSim/Region/CoreModules/World/Archiver/ArchiveReadRequest.cs index 994fe01..e8973b9 100644 --- a/OpenSim/Region/CoreModules/World/Archiver/ArchiveReadRequest.cs +++ b/OpenSim/Region/CoreModules/World/Archiver/ArchiveReadRequest.cs | |||
@@ -1150,7 +1150,7 @@ namespace OpenSim.Region.CoreModules.World.Archiver | |||
1150 | 1150 | ||
1151 | m_log.InfoFormat("[ARCHIVER]: Loading OAR with version {0}", version); | 1151 | m_log.InfoFormat("[ARCHIVER]: Loading OAR with version {0}", version); |
1152 | } | 1152 | } |
1153 | if (xtr.Name.ToString() == "datetime") | 1153 | else if (xtr.Name.ToString() == "datetime") |
1154 | { | 1154 | { |
1155 | int value; | 1155 | int value; |
1156 | if (Int32.TryParse(xtr.ReadElementContentAsString(), out value)) | 1156 | if (Int32.TryParse(xtr.ReadElementContentAsString(), out value)) |
@@ -1169,7 +1169,7 @@ namespace OpenSim.Region.CoreModules.World.Archiver | |||
1169 | { | 1169 | { |
1170 | string id = xtr.ReadElementContentAsString(); | 1170 | string id = xtr.ReadElementContentAsString(); |
1171 | dearchivedScenes.DefaultOriginalID = id; | 1171 | dearchivedScenes.DefaultOriginalID = id; |
1172 | if (multiRegion) | 1172 | if(multiRegion) |
1173 | dearchivedScenes.SetRegionOriginalID(id); | 1173 | dearchivedScenes.SetRegionOriginalID(id); |
1174 | } | 1174 | } |
1175 | else if (xtr.Name.ToString() == "dir") | 1175 | else if (xtr.Name.ToString() == "dir") |
@@ -1183,21 +1183,24 @@ namespace OpenSim.Region.CoreModules.World.Archiver | |||
1183 | if (Vector3.TryParse(size, out value)) | 1183 | if (Vector3.TryParse(size, out value)) |
1184 | { | 1184 | { |
1185 | m_incomingRegionSize = value; | 1185 | m_incomingRegionSize = value; |
1186 | dearchivedScenes.SetRegionSize(m_incomingRegionSize); | 1186 | if(multiRegion) |
1187 | m_log.DebugFormat("[ARCHIVER]: Found region_size info {0}", m_incomingRegionSize.ToString()); | 1187 | dearchivedScenes.SetRegionSize(m_incomingRegionSize); |
1188 | m_log.DebugFormat("[ARCHIVER]: Found region_size info {0}", | ||
1189 | m_incomingRegionSize.ToString()); | ||
1188 | } | 1190 | } |
1189 | } | 1191 | } |
1190 | } | 1192 | } |
1191 | } | 1193 | } |
1192 | 1194 | ||
1193 | dearchivedScenes.MultiRegionFormat = multiRegion; | 1195 | dearchivedScenes.MultiRegionFormat = multiRegion; |
1194 | if (!multiRegion && dearchivedScenes.GetScenesCount() == 0) | 1196 | if (!multiRegion) |
1195 | { | 1197 | { |
1196 | // Add the single scene | 1198 | // Add the single scene |
1197 | dearchivedScenes.StartRow(); | 1199 | dearchivedScenes.StartRow(); |
1198 | dearchivedScenes.StartRegion(); | 1200 | dearchivedScenes.StartRegion(); |
1199 | dearchivedScenes.SetRegionOriginalID(dearchivedScenes.DefaultOriginalID); | 1201 | dearchivedScenes.SetRegionOriginalID(dearchivedScenes.DefaultOriginalID); |
1200 | dearchivedScenes.SetRegionDirectory(""); | 1202 | dearchivedScenes.SetRegionDirectory(""); |
1203 | dearchivedScenes.SetRegionSize(m_incomingRegionSize); | ||
1201 | } | 1204 | } |
1202 | 1205 | ||
1203 | ControlFileLoaded = true; | 1206 | ControlFileLoaded = true; |
diff --git a/OpenSim/Region/CoreModules/World/Archiver/DearchiveScenesGroup.cs b/OpenSim/Region/CoreModules/World/Archiver/DearchiveScenesGroup.cs index 87969c2..e2222fe 100644 --- a/OpenSim/Region/CoreModules/World/Archiver/DearchiveScenesGroup.cs +++ b/OpenSim/Region/CoreModules/World/Archiver/DearchiveScenesGroup.cs | |||
@@ -129,20 +129,27 @@ namespace OpenSim.Region.CoreModules.World.Archiver | |||
129 | public void SetRegionOriginalID(string id) | 129 | public void SetRegionOriginalID(string id) |
130 | { | 130 | { |
131 | m_curRegion = new RegionInfo(); | 131 | m_curRegion = new RegionInfo(); |
132 | m_curRegion.Location = new Point((int)m_curX, (int)m_curY); | 132 | int x = (int)((m_curX == null) ? 0 : m_curX); |
133 | int y = (int)((m_curY == null) ? 0 : m_curY); | ||
134 | |||
135 | m_curRegion.Location = new Point(x, y); | ||
133 | m_curRegion.OriginalID = id; | 136 | m_curRegion.OriginalID = id; |
134 | // 'curRegion' will be saved in 'm_directory2region' when SetRegionDir() is called | 137 | // 'curRegion' will be saved in 'm_directory2region' when SetRegionDir() is called |
135 | } | 138 | } |
136 | 139 | ||
137 | public void SetRegionDirectory(string directory) | 140 | public void SetRegionDirectory(string directory) |
138 | { | 141 | { |
139 | m_curRegion.Directory = directory; | 142 | if(m_curRegion != null) |
140 | m_directory2region[directory] = m_curRegion; | 143 | { |
144 | m_curRegion.Directory = directory; | ||
145 | m_directory2region[directory] = m_curRegion; | ||
146 | } | ||
141 | } | 147 | } |
142 | 148 | ||
143 | public void SetRegionSize(Vector3 size) | 149 | public void SetRegionSize(Vector3 size) |
144 | { | 150 | { |
145 | m_curRegion.RegionSize = size; | 151 | if(m_curRegion != null) |
152 | m_curRegion.RegionSize = size; | ||
146 | } | 153 | } |
147 | 154 | ||
148 | /// <summary> | 155 | /// <summary> |