diff options
Diffstat (limited to 'OpenSim/Framework/WebUtil.cs')
-rw-r--r-- | OpenSim/Framework/WebUtil.cs | 122 |
1 files changed, 87 insertions, 35 deletions
diff --git a/OpenSim/Framework/WebUtil.cs b/OpenSim/Framework/WebUtil.cs index c7f1bdb..7f341d2 100644 --- a/OpenSim/Framework/WebUtil.cs +++ b/OpenSim/Framework/WebUtil.cs | |||
@@ -89,8 +89,9 @@ namespace OpenSim.Framework | |||
89 | /// <remarks> | 89 | /// <remarks> |
90 | /// This is to truncate any really large post data, such as an asset. In theory, the first section should | 90 | /// This is to truncate any really large post data, such as an asset. In theory, the first section should |
91 | /// give us useful information about the call (which agent it relates to if applicable, etc.). | 91 | /// give us useful information about the call (which agent it relates to if applicable, etc.). |
92 | /// This is also used to truncate messages when using DebugLevel 5. | ||
92 | /// </remarks> | 93 | /// </remarks> |
93 | public const int MaxRequestDiagLength = 100; | 94 | public const int MaxRequestDiagLength = 200; |
94 | 95 | ||
95 | /// <summary> | 96 | /// <summary> |
96 | /// Dictionary of end points | 97 | /// Dictionary of end points |
@@ -165,35 +166,54 @@ namespace OpenSim.Framework | |||
165 | 166 | ||
166 | public static void LogOutgoingDetail(Stream outputStream) | 167 | public static void LogOutgoingDetail(Stream outputStream) |
167 | { | 168 | { |
169 | LogOutgoingDetail("", outputStream); | ||
170 | } | ||
171 | |||
172 | public static void LogOutgoingDetail(string context, Stream outputStream) | ||
173 | { | ||
168 | using (StreamReader reader = new StreamReader(Util.Copy(outputStream), Encoding.UTF8)) | 174 | using (StreamReader reader = new StreamReader(Util.Copy(outputStream), Encoding.UTF8)) |
169 | { | 175 | { |
170 | string output; | 176 | string output; |
171 | 177 | ||
172 | if (DebugLevel == 5) | 178 | if (DebugLevel == 5) |
173 | { | 179 | { |
174 | const int sampleLength = 80; | 180 | char[] chars = new char[WebUtil.MaxRequestDiagLength + 1]; // +1 so we know to add "..." only if needed |
175 | char[] sampleChars = new char[sampleLength]; | 181 | int len = reader.Read(chars, 0, WebUtil.MaxRequestDiagLength + 1); |
176 | reader.Read(sampleChars, 0, sampleLength); | 182 | output = new string(chars, 0, len); |
177 | output = new string(sampleChars); | ||
178 | } | 183 | } |
179 | else | 184 | else |
180 | { | 185 | { |
181 | output = reader.ReadToEnd(); | 186 | output = reader.ReadToEnd(); |
182 | } | 187 | } |
183 | 188 | ||
184 | LogOutgoingDetail(output); | 189 | LogOutgoingDetail(context, output); |
185 | } | 190 | } |
186 | } | 191 | } |
187 | 192 | ||
188 | public static void LogOutgoingDetail(string output) | 193 | public static void LogOutgoingDetail(string output) |
189 | { | 194 | { |
195 | LogOutgoingDetail("", output); | ||
196 | } | ||
197 | |||
198 | public static void LogOutgoingDetail(string context, string output) | ||
199 | { | ||
190 | if (DebugLevel == 5) | 200 | if (DebugLevel == 5) |
191 | { | 201 | { |
192 | output = output.Substring(0, 80); | 202 | if (output.Length > MaxRequestDiagLength) |
193 | output = output + "..."; | 203 | output = output.Substring(0, MaxRequestDiagLength) + "..."; |
194 | } | 204 | } |
195 | 205 | ||
196 | m_log.DebugFormat("[WEB UTIL]: {0}", output.Replace("\n", @"\n")); | 206 | m_log.DebugFormat("[LOGHTTP]: {0}{1}", context, Util.BinaryToASCII(output)); |
207 | } | ||
208 | |||
209 | public static void LogResponseDetail(Stream inputStream) | ||
210 | { | ||
211 | LogOutgoingDetail("RESPONSE: ", inputStream); | ||
212 | } | ||
213 | |||
214 | public static void LogResponseDetail(string input) | ||
215 | { | ||
216 | LogOutgoingDetail("RESPONSE: ", input); | ||
197 | } | 217 | } |
198 | 218 | ||
199 | private static OSDMap ServiceOSDRequestWorker(string url, OSDMap data, string method, int timeout, bool compressed) | 219 | private static OSDMap ServiceOSDRequestWorker(string url, OSDMap data, string method, int timeout, bool compressed) |
@@ -202,7 +222,7 @@ namespace OpenSim.Framework | |||
202 | 222 | ||
203 | if (DebugLevel >= 3) | 223 | if (DebugLevel >= 3) |
204 | m_log.DebugFormat( | 224 | m_log.DebugFormat( |
205 | "[WEB UTIL]: HTTP OUT {0} ServiceOSD {1} {2} (timeout {3}, compressed {4})", | 225 | "[LOGHTTP]: HTTP OUT {0} ServiceOSD {1} {2} (timeout {3}, compressed {4})", |
206 | reqnum, method, url, timeout, compressed); | 226 | reqnum, method, url, timeout, compressed); |
207 | 227 | ||
208 | string errorMessage = "unknown error"; | 228 | string errorMessage = "unknown error"; |
@@ -268,7 +288,9 @@ namespace OpenSim.Framework | |||
268 | using (StreamReader reader = new StreamReader(responseStream)) | 288 | using (StreamReader reader = new StreamReader(responseStream)) |
269 | { | 289 | { |
270 | string responseStr = reader.ReadToEnd(); | 290 | string responseStr = reader.ReadToEnd(); |
271 | // m_log.DebugFormat("[WEB UTIL]: <{0}> response is <{1}>",reqnum,responseStr); | 291 | // m_log.DebugFormat("[LOGHTTP]: <{0}> response is <{1}>",reqnum,responseStr); |
292 | if (WebUtil.DebugLevel >= 5) | ||
293 | WebUtil.LogResponseDetail(responseStr); | ||
272 | return CanonicalizeResults(responseStr); | 294 | return CanonicalizeResults(responseStr); |
273 | } | 295 | } |
274 | } | 296 | } |
@@ -292,7 +314,7 @@ namespace OpenSim.Framework | |||
292 | int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); | 314 | int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); |
293 | if (tickdiff > LongCallTime) | 315 | if (tickdiff > LongCallTime) |
294 | m_log.InfoFormat( | 316 | m_log.InfoFormat( |
295 | "[WEB UTIL]: Slow ServiceOSD request {0} {1} {2} took {3}ms, {4}ms writing, {5}", | 317 | "[LOGHTTP]: Slow ServiceOSD request {0} {1} {2} took {3}ms, {4}ms writing, {5}", |
296 | reqnum, | 318 | reqnum, |
297 | method, | 319 | method, |
298 | url, | 320 | url, |
@@ -303,12 +325,12 @@ namespace OpenSim.Framework | |||
303 | : ""); | 325 | : ""); |
304 | else if (DebugLevel >= 4) | 326 | else if (DebugLevel >= 4) |
305 | m_log.DebugFormat( | 327 | m_log.DebugFormat( |
306 | "[WEB UTIL]: HTTP OUT {0} took {1}ms, {2}ms writing", | 328 | "[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing", |
307 | reqnum, tickdiff, tickdata); | 329 | reqnum, tickdiff, tickdata); |
308 | } | 330 | } |
309 | 331 | ||
310 | m_log.DebugFormat( | 332 | m_log.DebugFormat( |
311 | "[WEB UTIL]: ServiceOSD request {0} {1} {2} FAILED: {3}", reqnum, url, method, errorMessage); | 333 | "[LOGHTTP]: ServiceOSD request {0} {1} {2} FAILED: {3}", reqnum, url, method, errorMessage); |
312 | 334 | ||
313 | return ErrorResponseMap(errorMessage); | 335 | return ErrorResponseMap(errorMessage); |
314 | } | 336 | } |
@@ -387,7 +409,7 @@ namespace OpenSim.Framework | |||
387 | 409 | ||
388 | if (DebugLevel >= 3) | 410 | if (DebugLevel >= 3) |
389 | m_log.DebugFormat( | 411 | m_log.DebugFormat( |
390 | "[WEB UTIL]: HTTP OUT {0} ServiceForm {1} {2} (timeout {3})", | 412 | "[LOGHTTP]: HTTP OUT {0} ServiceForm {1} {2} (timeout {3})", |
391 | reqnum, method, url, timeout); | 413 | reqnum, method, url, timeout); |
392 | 414 | ||
393 | string errorMessage = "unknown error"; | 415 | string errorMessage = "unknown error"; |
@@ -431,6 +453,8 @@ namespace OpenSim.Framework | |||
431 | using (StreamReader reader = new StreamReader(responseStream)) | 453 | using (StreamReader reader = new StreamReader(responseStream)) |
432 | { | 454 | { |
433 | string responseStr = reader.ReadToEnd(); | 455 | string responseStr = reader.ReadToEnd(); |
456 | if (WebUtil.DebugLevel >= 5) | ||
457 | WebUtil.LogResponseDetail(responseStr); | ||
434 | OSD responseOSD = OSDParser.Deserialize(responseStr); | 458 | OSD responseOSD = OSDParser.Deserialize(responseStr); |
435 | 459 | ||
436 | if (responseOSD.Type == OSDType.Map) | 460 | if (responseOSD.Type == OSDType.Map) |
@@ -457,7 +481,7 @@ namespace OpenSim.Framework | |||
457 | int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); | 481 | int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); |
458 | if (tickdiff > LongCallTime) | 482 | if (tickdiff > LongCallTime) |
459 | m_log.InfoFormat( | 483 | m_log.InfoFormat( |
460 | "[WEB UTIL]: Slow ServiceForm request {0} {1} {2} took {3}ms, {4}ms writing, {5}", | 484 | "[LOGHTTP]: Slow ServiceForm request {0} {1} {2} took {3}ms, {4}ms writing, {5}", |
461 | reqnum, | 485 | reqnum, |
462 | method, | 486 | method, |
463 | url, | 487 | url, |
@@ -468,11 +492,11 @@ namespace OpenSim.Framework | |||
468 | : ""); | 492 | : ""); |
469 | else if (DebugLevel >= 4) | 493 | else if (DebugLevel >= 4) |
470 | m_log.DebugFormat( | 494 | m_log.DebugFormat( |
471 | "[WEB UTIL]: HTTP OUT {0} took {1}ms, {2}ms writing", | 495 | "[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing", |
472 | reqnum, tickdiff, tickdata); | 496 | reqnum, tickdiff, tickdata); |
473 | } | 497 | } |
474 | 498 | ||
475 | m_log.WarnFormat("[WEB UTIL]: ServiceForm request {0} {1} {2} failed: {2}", reqnum, method, url, errorMessage); | 499 | m_log.WarnFormat("[LOGHTTP]: ServiceForm request {0} {1} {2} failed: {2}", reqnum, method, url, errorMessage); |
476 | 500 | ||
477 | return ErrorResponseMap(errorMessage); | 501 | return ErrorResponseMap(errorMessage); |
478 | } | 502 | } |
@@ -753,7 +777,7 @@ namespace OpenSim.Framework | |||
753 | 777 | ||
754 | if (WebUtil.DebugLevel >= 3) | 778 | if (WebUtil.DebugLevel >= 3) |
755 | m_log.DebugFormat( | 779 | m_log.DebugFormat( |
756 | "[WEB UTIL]: HTTP OUT {0} AsynchronousRequestObject {1} {2}", | 780 | "[LOGHTTP]: HTTP OUT {0} AsynchronousRequestObject {1} {2}", |
757 | reqnum, verb, requestUrl); | 781 | reqnum, verb, requestUrl); |
758 | 782 | ||
759 | int tickstart = Util.EnvironmentTickCount(); | 783 | int tickstart = Util.EnvironmentTickCount(); |
@@ -793,14 +817,15 @@ namespace OpenSim.Framework | |||
793 | 817 | ||
794 | int length = (int)buffer.Length; | 818 | int length = (int)buffer.Length; |
795 | request.ContentLength = length; | 819 | request.ContentLength = length; |
820 | byte[] data = buffer.ToArray(); | ||
796 | 821 | ||
797 | if (WebUtil.DebugLevel >= 5) | 822 | if (WebUtil.DebugLevel >= 5) |
798 | WebUtil.LogOutgoingDetail(buffer); | 823 | WebUtil.LogOutgoingDetail(System.Text.Encoding.UTF8.GetString(data)); |
799 | 824 | ||
800 | request.BeginGetRequestStream(delegate(IAsyncResult res) | 825 | request.BeginGetRequestStream(delegate(IAsyncResult res) |
801 | { | 826 | { |
802 | using (Stream requestStream = request.EndGetRequestStream(res)) | 827 | using (Stream requestStream = request.EndGetRequestStream(res)) |
803 | requestStream.Write(buffer.ToArray(), 0, length); | 828 | requestStream.Write(data, 0, length); |
804 | 829 | ||
805 | // capture how much time was spent writing | 830 | // capture how much time was spent writing |
806 | tickdata = Util.EnvironmentTickCountSubtract(tickstart); | 831 | tickdata = Util.EnvironmentTickCountSubtract(tickstart); |
@@ -812,7 +837,11 @@ namespace OpenSim.Framework | |||
812 | try | 837 | try |
813 | { | 838 | { |
814 | using (Stream respStream = response.GetResponseStream()) | 839 | using (Stream respStream = response.GetResponseStream()) |
840 | { | ||
841 | if (WebUtil.DebugLevel >= 5) | ||
842 | WebUtil.LogResponseDetail(respStream); | ||
815 | deserial = (TResponse)deserializer.Deserialize(respStream); | 843 | deserial = (TResponse)deserializer.Deserialize(respStream); |
844 | } | ||
816 | } | 845 | } |
817 | catch (System.InvalidOperationException) | 846 | catch (System.InvalidOperationException) |
818 | { | 847 | { |
@@ -837,7 +866,11 @@ namespace OpenSim.Framework | |||
837 | try | 866 | try |
838 | { | 867 | { |
839 | using (Stream respStream = response.GetResponseStream()) | 868 | using (Stream respStream = response.GetResponseStream()) |
869 | { | ||
870 | if (WebUtil.DebugLevel >= 5) | ||
871 | WebUtil.LogResponseDetail(respStream); | ||
840 | deserial = (TResponse)deserializer.Deserialize(respStream); | 872 | deserial = (TResponse)deserializer.Deserialize(respStream); |
873 | } | ||
841 | } | 874 | } |
842 | catch (System.InvalidOperationException) | 875 | catch (System.InvalidOperationException) |
843 | { | 876 | { |
@@ -907,7 +940,7 @@ namespace OpenSim.Framework | |||
907 | } | 940 | } |
908 | 941 | ||
909 | m_log.InfoFormat( | 942 | m_log.InfoFormat( |
910 | "[ASYNC REQUEST]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}", | 943 | "[LOGHTTP]: [ASYNC REQUEST]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}", |
911 | reqnum, | 944 | reqnum, |
912 | verb, | 945 | verb, |
913 | requestUrl, | 946 | requestUrl, |
@@ -918,7 +951,7 @@ namespace OpenSim.Framework | |||
918 | else if (WebUtil.DebugLevel >= 4) | 951 | else if (WebUtil.DebugLevel >= 4) |
919 | { | 952 | { |
920 | m_log.DebugFormat( | 953 | m_log.DebugFormat( |
921 | "[WEB UTIL]: HTTP OUT {0} took {1}ms, {2}ms writing", | 954 | "[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing", |
922 | reqnum, tickdiff, tickdata); | 955 | reqnum, tickdiff, tickdata); |
923 | } | 956 | } |
924 | } | 957 | } |
@@ -951,7 +984,7 @@ namespace OpenSim.Framework | |||
951 | 984 | ||
952 | if (WebUtil.DebugLevel >= 3) | 985 | if (WebUtil.DebugLevel >= 3) |
953 | m_log.DebugFormat( | 986 | m_log.DebugFormat( |
954 | "[WEB UTIL]: HTTP OUT {0} SynchronousRestForms {1} {2}", | 987 | "[LOGHTTP]: HTTP OUT {0} SynchronousRestForms {1} {2}", |
955 | reqnum, verb, requestUrl); | 988 | reqnum, verb, requestUrl); |
956 | 989 | ||
957 | int tickstart = Util.EnvironmentTickCount(); | 990 | int tickstart = Util.EnvironmentTickCount(); |
@@ -978,15 +1011,16 @@ namespace OpenSim.Framework | |||
978 | 1011 | ||
979 | length = (int)obj.Length; | 1012 | length = (int)obj.Length; |
980 | request.ContentLength = length; | 1013 | request.ContentLength = length; |
1014 | byte[] data = buffer.ToArray(); | ||
981 | 1015 | ||
982 | if (WebUtil.DebugLevel >= 5) | 1016 | if (WebUtil.DebugLevel >= 5) |
983 | WebUtil.LogOutgoingDetail(buffer); | 1017 | WebUtil.LogOutgoingDetail(System.Text.Encoding.UTF8.GetString(data)); |
984 | 1018 | ||
985 | Stream requestStream = null; | 1019 | Stream requestStream = null; |
986 | try | 1020 | try |
987 | { | 1021 | { |
988 | requestStream = request.GetRequestStream(); | 1022 | requestStream = request.GetRequestStream(); |
989 | requestStream.Write(buffer.ToArray(), 0, length); | 1023 | requestStream.Write(data, 0, length); |
990 | } | 1024 | } |
991 | catch (Exception e) | 1025 | catch (Exception e) |
992 | { | 1026 | { |
@@ -1036,7 +1070,7 @@ namespace OpenSim.Framework | |||
1036 | int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); | 1070 | int tickdiff = Util.EnvironmentTickCountSubtract(tickstart); |
1037 | if (tickdiff > WebUtil.LongCallTime) | 1071 | if (tickdiff > WebUtil.LongCallTime) |
1038 | m_log.InfoFormat( | 1072 | m_log.InfoFormat( |
1039 | "[FORMS]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}", | 1073 | "[LOGHTTP]: [FORMS]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}", |
1040 | reqnum, | 1074 | reqnum, |
1041 | verb, | 1075 | verb, |
1042 | requestUrl, | 1076 | requestUrl, |
@@ -1045,9 +1079,12 @@ namespace OpenSim.Framework | |||
1045 | obj.Length > WebUtil.MaxRequestDiagLength ? obj.Remove(WebUtil.MaxRequestDiagLength) : obj); | 1079 | obj.Length > WebUtil.MaxRequestDiagLength ? obj.Remove(WebUtil.MaxRequestDiagLength) : obj); |
1046 | else if (WebUtil.DebugLevel >= 4) | 1080 | else if (WebUtil.DebugLevel >= 4) |
1047 | m_log.DebugFormat( | 1081 | m_log.DebugFormat( |
1048 | "[WEB UTIL]: HTTP OUT {0} took {1}ms, {2}ms writing", | 1082 | "[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing", |
1049 | reqnum, tickdiff, tickdata); | 1083 | reqnum, tickdiff, tickdata); |
1050 | 1084 | ||
1085 | if (WebUtil.DebugLevel >= 5) | ||
1086 | WebUtil.LogResponseDetail(respstring); | ||
1087 | |||
1051 | return respstring; | 1088 | return respstring; |
1052 | } | 1089 | } |
1053 | 1090 | ||
@@ -1089,7 +1126,7 @@ namespace OpenSim.Framework | |||
1089 | 1126 | ||
1090 | if (WebUtil.DebugLevel >= 3) | 1127 | if (WebUtil.DebugLevel >= 3) |
1091 | m_log.DebugFormat( | 1128 | m_log.DebugFormat( |
1092 | "[WEB UTIL]: HTTP OUT {0} SynchronousRestObject {1} {2}", | 1129 | "[LOGHTTP]: HTTP OUT {0} SynchronousRestObject {1} {2}", |
1093 | reqnum, verb, requestUrl); | 1130 | reqnum, verb, requestUrl); |
1094 | 1131 | ||
1095 | int tickstart = Util.EnvironmentTickCount(); | 1132 | int tickstart = Util.EnvironmentTickCount(); |
@@ -1126,14 +1163,15 @@ namespace OpenSim.Framework | |||
1126 | 1163 | ||
1127 | int length = (int)buffer.Length; | 1164 | int length = (int)buffer.Length; |
1128 | request.ContentLength = length; | 1165 | request.ContentLength = length; |
1166 | byte[] data = buffer.ToArray(); | ||
1129 | 1167 | ||
1130 | if (WebUtil.DebugLevel >= 5) | 1168 | if (WebUtil.DebugLevel >= 5) |
1131 | WebUtil.LogOutgoingDetail(buffer); | 1169 | WebUtil.LogOutgoingDetail(System.Text.Encoding.UTF8.GetString(data)); |
1132 | 1170 | ||
1133 | try | 1171 | try |
1134 | { | 1172 | { |
1135 | using (Stream requestStream = request.GetRequestStream()) | 1173 | using (Stream requestStream = request.GetRequestStream()) |
1136 | requestStream.Write(buffer.ToArray(), 0, length); | 1174 | requestStream.Write(data, 0, length); |
1137 | } | 1175 | } |
1138 | catch (Exception e) | 1176 | catch (Exception e) |
1139 | { | 1177 | { |
@@ -1159,7 +1197,21 @@ namespace OpenSim.Framework | |||
1159 | using (Stream respStream = resp.GetResponseStream()) | 1197 | using (Stream respStream = resp.GetResponseStream()) |
1160 | { | 1198 | { |
1161 | XmlSerializer deserializer = new XmlSerializer(typeof(TResponse)); | 1199 | XmlSerializer deserializer = new XmlSerializer(typeof(TResponse)); |
1162 | deserial = (TResponse)deserializer.Deserialize(respStream); | 1200 | |
1201 | if (WebUtil.DebugLevel >= 5) | ||
1202 | { | ||
1203 | byte[] data = new byte[resp.ContentLength]; | ||
1204 | Util.ReadStream(respStream, data); | ||
1205 | |||
1206 | WebUtil.LogResponseDetail(System.Text.Encoding.UTF8.GetString(data)); | ||
1207 | |||
1208 | using (MemoryStream temp = new MemoryStream(data)) | ||
1209 | deserial = (TResponse)deserializer.Deserialize(temp); | ||
1210 | } | ||
1211 | else | ||
1212 | { | ||
1213 | deserial = (TResponse)deserializer.Deserialize(respStream); | ||
1214 | } | ||
1163 | } | 1215 | } |
1164 | } | 1216 | } |
1165 | else | 1217 | else |
@@ -1210,7 +1262,7 @@ namespace OpenSim.Framework | |||
1210 | } | 1262 | } |
1211 | 1263 | ||
1212 | m_log.InfoFormat( | 1264 | m_log.InfoFormat( |
1213 | "[SynchronousRestObjectRequester]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}", | 1265 | "[LOGHTTP]: [SynchronousRestObjectRequester]: Slow request {0} {1} {2} took {3}ms, {4}ms writing, {5}", |
1214 | reqnum, | 1266 | reqnum, |
1215 | verb, | 1267 | verb, |
1216 | requestUrl, | 1268 | requestUrl, |
@@ -1221,7 +1273,7 @@ namespace OpenSim.Framework | |||
1221 | else if (WebUtil.DebugLevel >= 4) | 1273 | else if (WebUtil.DebugLevel >= 4) |
1222 | { | 1274 | { |
1223 | m_log.DebugFormat( | 1275 | m_log.DebugFormat( |
1224 | "[WEB UTIL]: HTTP OUT {0} took {1}ms, {2}ms writing", | 1276 | "[LOGHTTP]: HTTP OUT {0} took {1}ms, {2}ms writing", |
1225 | reqnum, tickdiff, tickdata); | 1277 | reqnum, tickdiff, tickdata); |
1226 | } | 1278 | } |
1227 | } | 1279 | } |
@@ -1234,4 +1286,4 @@ namespace OpenSim.Framework | |||
1234 | return deserial; | 1286 | return deserial; |
1235 | } | 1287 | } |
1236 | } | 1288 | } |
1237 | } \ No newline at end of file | 1289 | } |