aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs39
1 files changed, 12 insertions, 27 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs b/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs
index 0588648..87e23de 100644
--- a/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs
+++ b/OpenSim/Region/ClientStack/Linden/Caps/GetTextureModule.cs
@@ -241,15 +241,10 @@ namespace OpenSim.Region.ClientStack.Linden
241 241
242 lock (responses) 242 lock (responses)
243 { 243 {
244 if (responses.Count > 0) 244 if (responses.Count > 0 && m_queue.Count > 32)
245 { 245 reqinfo.send503 = true;
246 if (m_queue.Count >= 4)
247 {
248 // Never allow more than 4 fetches to wait
249 reqinfo.send503 = true;
250 }
251 }
252 } 246 }
247
253 m_queue.Add(reqinfo); 248 m_queue.Add(reqinfo);
254 }; 249 };
255 250
@@ -266,7 +261,7 @@ namespace OpenSim.Region.ClientStack.Linden
266 Hashtable response = new Hashtable(); 261 Hashtable response = new Hashtable();
267 262
268 response["int_response_code"] = 500; 263 response["int_response_code"] = 500;
269 response["str_response_string"] = "Script timeout"; 264 response["str_response_string"] = "timeout";
270 response["content_type"] = "text/plain"; 265 response["content_type"] = "text/plain";
271 response["keepalive"] = false; 266 response["keepalive"] = false;
272 return response; 267 return response;
@@ -293,6 +288,12 @@ namespace OpenSim.Region.ClientStack.Linden
293 } 288 }
294 } 289 }
295 290
291 if (m_presence == null)
292 m_presence = m_scene.GetScenePresence(Id);
293
294 if (m_presence == null || m_presence.IsDeleted)
295 requestinfo.send503 = true;
296
296 if (requestinfo.send503) 297 if (requestinfo.send503)
297 { 298 {
298 response = new Hashtable(); 299 response = new Hashtable();
@@ -303,26 +304,10 @@ namespace OpenSim.Region.ClientStack.Linden
303 response["keepalive"] = false; 304 response["keepalive"] = false;
304 305
305 Hashtable headers = new Hashtable(); 306 Hashtable headers = new Hashtable();
306 headers["Retry-After"] = 30; 307 headers["Retry-After"] = 20;
307 response["headers"] = headers; 308 response["headers"] = headers;
308 309
309 responses[requestID] = new APollResponse() {bytes = 0, response = response}; 310 responses[requestID] = new APollResponse() { bytes = 0, response = response };
310
311 return;
312 }
313
314 // If the avatar is gone, don't bother to get the texture
315 if (m_scene.GetScenePresence(Id) == null)
316 {
317 response = new Hashtable();
318
319 response["int_response_code"] = 500;
320 response["str_response_string"] = "Script timeout";
321 response["content_type"] = "text/plain";
322 response["keepalive"] = false;
323
324 responses[requestID] = new APollResponse() {bytes = 0, response = response};
325
326 return; 311 return;
327 } 312 }
328 } 313 }