OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2004, 2006, 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2004, 2006, 2008 Apple Inc. All rights reserved. |
3 * Copyright (C) 2005-2007 Alexey Proskuryakov <ap@webkit.org> | 3 * Copyright (C) 2005-2007 Alexey Proskuryakov <ap@webkit.org> |
4 * Copyright (C) 2007, 2008 Julien Chaffraix <jchaffraix@webkit.org> | 4 * Copyright (C) 2007, 2008 Julien Chaffraix <jchaffraix@webkit.org> |
5 * Copyright (C) 2008, 2011 Google Inc. All rights reserved. | 5 * Copyright (C) 2008, 2011 Google Inc. All rights reserved. |
6 * Copyright (C) 2012 Intel Corporation | 6 * Copyright (C) 2012 Intel Corporation |
7 * | 7 * |
8 * This library is free software; you can redistribute it and/or | 8 * This library is free software; you can redistribute it and/or |
9 * modify it under the terms of the GNU Lesser General Public | 9 * modify it under the terms of the GNU Lesser General Public |
10 * License as published by the Free Software Foundation; either | 10 * License as published by the Free Software Foundation; either |
(...skipping 1002 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1013 if (!m_loader) | 1013 if (!m_loader) |
1014 return true; | 1014 return true; |
1015 | 1015 |
1016 // Cancelling the ThreadableLoader m_loader may result in calling | 1016 // Cancelling the ThreadableLoader m_loader may result in calling |
1017 // window.onload synchronously. If such an onload handler contains open() | 1017 // window.onload synchronously. If such an onload handler contains open() |
1018 // call on the same XMLHttpRequest object, reentry happens. | 1018 // call on the same XMLHttpRequest object, reentry happens. |
1019 // | 1019 // |
1020 // If, window.onload contains open() and send(), m_loader will be set to | 1020 // If, window.onload contains open() and send(), m_loader will be set to |
1021 // non 0 value. So, we cannot continue the outer open(). In such case, | 1021 // non 0 value. So, we cannot continue the outer open(). In such case, |
1022 // just abort the outer open() by returning false. | 1022 // just abort the outer open() by returning false. |
1023 RefPtrWillBeRawPtr<XMLHttpRequest> protect(this); | |
1024 RefPtr<ThreadableLoader> loader = m_loader.release(); | 1023 RefPtr<ThreadableLoader> loader = m_loader.release(); |
1025 loader->cancel(); | 1024 loader->cancel(); |
1026 | 1025 |
1027 // If abort() called internalAbort() and a nested open() ended up | 1026 // If abort() called internalAbort() and a nested open() ended up |
1028 // clearing the error flag, but didn't send(), make sure the error | 1027 // clearing the error flag, but didn't send(), make sure the error |
1029 // flag is still set. | 1028 // flag is still set. |
1030 bool newLoadStarted = hasPendingActivity(); | 1029 bool newLoadStarted = hasPendingActivity(); |
1031 if (!newLoadStarted) | 1030 if (!newLoadStarted) |
1032 m_error = true; | 1031 m_error = true; |
1033 | 1032 |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1084 } | 1083 } |
1085 | 1084 |
1086 void XMLHttpRequest::handleNetworkError() | 1085 void XMLHttpRequest::handleNetworkError() |
1087 { | 1086 { |
1088 WTF_LOG(Network, "XMLHttpRequest %p handleNetworkError()", this); | 1087 WTF_LOG(Network, "XMLHttpRequest %p handleNetworkError()", this); |
1089 | 1088 |
1090 // Response is cleared next, save needed progress event data. | 1089 // Response is cleared next, save needed progress event data. |
1091 long long expectedLength = m_response.expectedContentLength(); | 1090 long long expectedLength = m_response.expectedContentLength(); |
1092 long long receivedLength = m_receivedLength; | 1091 long long receivedLength = m_receivedLength; |
1093 | 1092 |
| 1093 // Prevent the XMLHttpRequest instance from being destoryed during |
| 1094 // |internalAbort()|. |
| 1095 RefPtrWillBeRawPtr<XMLHttpRequest> protect(this); |
| 1096 |
1094 if (!internalAbort()) | 1097 if (!internalAbort()) |
1095 return; | 1098 return; |
1096 | 1099 |
1097 handleRequestError(NetworkError, EventTypeNames::error, receivedLength, expe
ctedLength); | 1100 handleRequestError(NetworkError, EventTypeNames::error, receivedLength, expe
ctedLength); |
1098 } | 1101 } |
1099 | 1102 |
1100 void XMLHttpRequest::handleDidCancel() | 1103 void XMLHttpRequest::handleDidCancel() |
1101 { | 1104 { |
1102 WTF_LOG(Network, "XMLHttpRequest %p handleDidCancel()", this); | 1105 WTF_LOG(Network, "XMLHttpRequest %p handleDidCancel()", this); |
1103 | 1106 |
1104 // Response is cleared next, save needed progress event data. | 1107 // Response is cleared next, save needed progress event data. |
1105 long long expectedLength = m_response.expectedContentLength(); | 1108 long long expectedLength = m_response.expectedContentLength(); |
1106 long long receivedLength = m_receivedLength; | 1109 long long receivedLength = m_receivedLength; |
1107 | 1110 |
| 1111 // Prevent the XMLHttpRequest instance from being destoryed during |
| 1112 // |internalAbort()|. |
| 1113 RefPtrWillBeRawPtr<XMLHttpRequest> protect(this); |
| 1114 |
1108 if (!internalAbort()) | 1115 if (!internalAbort()) |
1109 return; | 1116 return; |
1110 | 1117 |
1111 handleRequestError(AbortError, EventTypeNames::abort, receivedLength, expect
edLength); | 1118 handleRequestError(AbortError, EventTypeNames::abort, receivedLength, expect
edLength); |
1112 } | 1119 } |
1113 | 1120 |
1114 void XMLHttpRequest::handleRequestError(ExceptionCode exceptionCode, const Atomi
cString& type, long long receivedLength, long long expectedLength) | 1121 void XMLHttpRequest::handleRequestError(ExceptionCode exceptionCode, const Atomi
cString& type, long long receivedLength, long long expectedLength) |
1115 { | 1122 { |
1116 WTF_LOG(Network, "XMLHttpRequest %p handleRequestError()", this); | 1123 WTF_LOG(Network, "XMLHttpRequest %p handleRequestError()", this); |
1117 | 1124 |
(...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1304 void XMLHttpRequest::didFail(const ResourceError& error) | 1311 void XMLHttpRequest::didFail(const ResourceError& error) |
1305 { | 1312 { |
1306 WTF_LOG(Network, "XMLHttpRequest %p didFail()", this); | 1313 WTF_LOG(Network, "XMLHttpRequest %p didFail()", this); |
1307 | 1314 |
1308 // If we are already in an error state, for instance we called abort(), bail
out early. | 1315 // If we are already in an error state, for instance we called abort(), bail
out early. |
1309 if (m_error) | 1316 if (m_error) |
1310 return; | 1317 return; |
1311 | 1318 |
1312 if (error.isCancellation()) { | 1319 if (error.isCancellation()) { |
1313 handleDidCancel(); | 1320 handleDidCancel(); |
| 1321 // Now the XMLHttpRequest instance may be dead. |
1314 return; | 1322 return; |
1315 } | 1323 } |
1316 | 1324 |
1317 if (error.isTimeout()) { | 1325 if (error.isTimeout()) { |
1318 handleDidTimeout(); | 1326 handleDidTimeout(); |
| 1327 // Now the XMLHttpRequest instance may be dead. |
1319 return; | 1328 return; |
1320 } | 1329 } |
1321 | 1330 |
1322 // Network failures are already reported to Web Inspector by ResourceLoader. | 1331 // Network failures are already reported to Web Inspector by ResourceLoader. |
1323 if (error.domain() == errorDomainBlinkInternal) | 1332 if (error.domain() == errorDomainBlinkInternal) |
1324 logConsoleError(executionContext(), "XMLHttpRequest cannot load " + erro
r.failingURL() + ". " + error.localizedDescription()); | 1333 logConsoleError(executionContext(), "XMLHttpRequest cannot load " + erro
r.failingURL() + ". " + error.localizedDescription()); |
1325 | 1334 |
1326 handleNetworkError(); | 1335 handleNetworkError(); |
| 1336 // Now the XMLHttpRequest instance may be dead. |
1327 } | 1337 } |
1328 | 1338 |
1329 void XMLHttpRequest::didFailRedirectCheck() | 1339 void XMLHttpRequest::didFailRedirectCheck() |
1330 { | 1340 { |
1331 WTF_LOG(Network, "XMLHttpRequest %p didFailRedirectCheck()", this); | 1341 WTF_LOG(Network, "XMLHttpRequest %p didFailRedirectCheck()", this); |
1332 | 1342 |
1333 handleNetworkError(); | 1343 handleNetworkError(); |
| 1344 // Now the XMLHttpRequest instance may be dead. |
1334 } | 1345 } |
1335 | 1346 |
1336 void XMLHttpRequest::didFinishLoading(unsigned long identifier, double) | 1347 void XMLHttpRequest::didFinishLoading(unsigned long identifier, double) |
1337 { | 1348 { |
1338 WTF_LOG(Network, "XMLHttpRequest %p didFinishLoading(%lu)", this, identifier
); | 1349 WTF_LOG(Network, "XMLHttpRequest %p didFinishLoading(%lu)", this, identifier
); |
1339 | 1350 |
1340 if (m_error) | 1351 if (m_error) |
1341 return; | 1352 return; |
1342 | 1353 |
1343 if (m_state < HEADERS_RECEIVED) | 1354 if (m_state < HEADERS_RECEIVED) |
(...skipping 251 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1595 } | 1606 } |
1596 | 1607 |
1597 void XMLHttpRequest::handleDidTimeout() | 1608 void XMLHttpRequest::handleDidTimeout() |
1598 { | 1609 { |
1599 WTF_LOG(Network, "XMLHttpRequest %p handleDidTimeout()", this); | 1610 WTF_LOG(Network, "XMLHttpRequest %p handleDidTimeout()", this); |
1600 | 1611 |
1601 // Response is cleared next, save needed progress event data. | 1612 // Response is cleared next, save needed progress event data. |
1602 long long expectedLength = m_response.expectedContentLength(); | 1613 long long expectedLength = m_response.expectedContentLength(); |
1603 long long receivedLength = m_receivedLength; | 1614 long long receivedLength = m_receivedLength; |
1604 | 1615 |
| 1616 // Prevent the XMLHttpRequest instance from being destoryed during |
| 1617 // |internalAbort()|. |
| 1618 RefPtrWillBeRawPtr<XMLHttpRequest> protect(this); |
| 1619 |
1605 if (!internalAbort()) | 1620 if (!internalAbort()) |
1606 return; | 1621 return; |
1607 | 1622 |
1608 handleRequestError(TimeoutError, EventTypeNames::timeout, receivedLength, ex
pectedLength); | 1623 handleRequestError(TimeoutError, EventTypeNames::timeout, receivedLength, ex
pectedLength); |
1609 } | 1624 } |
1610 | 1625 |
1611 void XMLHttpRequest::suspend() | 1626 void XMLHttpRequest::suspend() |
1612 { | 1627 { |
1613 m_progressEventThrottle.suspend(); | 1628 m_progressEventThrottle.suspend(); |
1614 } | 1629 } |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1658 visitor->trace(m_streamSource); | 1673 visitor->trace(m_streamSource); |
1659 visitor->trace(m_responseDocument); | 1674 visitor->trace(m_responseDocument); |
1660 visitor->trace(m_responseDocumentParser); | 1675 visitor->trace(m_responseDocumentParser); |
1661 visitor->trace(m_progressEventThrottle); | 1676 visitor->trace(m_progressEventThrottle); |
1662 visitor->trace(m_upload); | 1677 visitor->trace(m_upload); |
1663 visitor->trace(m_blobLoader); | 1678 visitor->trace(m_blobLoader); |
1664 XMLHttpRequestEventTarget::trace(visitor); | 1679 XMLHttpRequestEventTarget::trace(visitor); |
1665 } | 1680 } |
1666 | 1681 |
1667 } // namespace blink | 1682 } // namespace blink |
OLD | NEW |