OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2011 Google Inc. All rights reserved. | 2 * Copyright (C) 2011 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 13 matching lines...) Expand all Loading... |
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 */ | 29 */ |
30 | 30 |
31 #include "config.h" | 31 #include "config.h" |
32 #include "modules/websockets/ThreadableWebSocketChannelClientWrapper.h" | 32 #include "modules/websockets/ThreadableWebSocketChannelClientWrapper.h" |
33 | 33 |
| 34 #include "core/dom/CrossThreadTask.h" |
| 35 #include "core/dom/ExecutionContext.h" |
| 36 #include "platform/CrossThreadCopier.h" |
| 37 #include "wtf/PassRefPtr.h" |
| 38 #include "wtf/RefPtr.h" |
| 39 |
34 namespace WebCore { | 40 namespace WebCore { |
35 | 41 |
36 ThreadableWebSocketChannelClientWrapper::ThreadableWebSocketChannelClientWrapper
(WebSocketChannelClient* client) | 42 ThreadableWebSocketChannelClientWrapper::ThreadableWebSocketChannelClientWrapper
(WebSocketChannelClient* client) |
37 : m_client(client) | 43 : m_client(client) |
| 44 , m_suspended(false) |
| 45 { |
| 46 } |
| 47 |
| 48 ThreadableWebSocketChannelClientWrapper::~ThreadableWebSocketChannelClientWrappe
r() |
38 { | 49 { |
39 } | 50 } |
40 | 51 |
41 PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientWrapper> ThreadableWebSoc
ketChannelClientWrapper::create(WebSocketChannelClient* client) | 52 PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientWrapper> ThreadableWebSoc
ketChannelClientWrapper::create(WebSocketChannelClient* client) |
42 { | 53 { |
43 return adoptRefWillBeNoop(new ThreadableWebSocketChannelClientWrapper(client
)); | 54 return adoptRefWillBeNoop(new ThreadableWebSocketChannelClientWrapper(client
)); |
44 } | 55 } |
45 | 56 |
46 void ThreadableWebSocketChannelClientWrapper::clearClient() | 57 void ThreadableWebSocketChannelClientWrapper::clearClient() |
47 { | 58 { |
48 m_client = 0; | 59 m_client = 0; |
49 } | 60 } |
50 | 61 |
51 void ThreadableWebSocketChannelClientWrapper::didConnect(const String& subprotoc
ol, const String& extensions) | 62 void ThreadableWebSocketChannelClientWrapper::didConnect(const String& subprotoc
ol, const String& extensions) |
52 { | 63 { |
53 if (m_client) | 64 m_pendingTasks.append(createCallbackTask(&didConnectCallback, this, subproto
col, extensions)); |
54 m_client->didConnect(subprotocol, extensions); | 65 if (!m_suspended) |
| 66 processPendingTasks(); |
55 } | 67 } |
56 | 68 |
57 void ThreadableWebSocketChannelClientWrapper::didReceiveMessage(const String& me
ssage) | 69 void ThreadableWebSocketChannelClientWrapper::didReceiveMessage(const String& me
ssage) |
58 { | 70 { |
59 if (m_client) | 71 m_pendingTasks.append(createCallbackTask(&didReceiveMessageCallback, this, m
essage)); |
60 m_client->didReceiveMessage(message); | 72 if (!m_suspended) |
| 73 processPendingTasks(); |
61 } | 74 } |
62 | 75 |
63 void ThreadableWebSocketChannelClientWrapper::didReceiveBinaryData(PassOwnPtr<Ve
ctor<char> > binaryData) | 76 void ThreadableWebSocketChannelClientWrapper::didReceiveBinaryData(PassOwnPtr<Ve
ctor<char> > binaryData) |
64 { | 77 { |
65 if (m_client) | 78 m_pendingTasks.append(createCallbackTask(&didReceiveBinaryDataCallback, this
, binaryData)); |
66 m_client->didReceiveBinaryData(binaryData); | 79 if (!m_suspended) |
| 80 processPendingTasks(); |
67 } | 81 } |
68 | 82 |
69 void ThreadableWebSocketChannelClientWrapper::didConsumeBufferedAmount(unsigned
long consumed) | 83 void ThreadableWebSocketChannelClientWrapper::didConsumeBufferedAmount(unsigned
long consumed) |
70 { | 84 { |
71 if (m_client) | 85 m_pendingTasks.append(createCallbackTask(&didConsumeBufferedAmountCallback,
this, consumed)); |
72 m_client->didConsumeBufferedAmount(consumed); | 86 if (!m_suspended) |
| 87 processPendingTasks(); |
73 } | 88 } |
74 | 89 |
75 void ThreadableWebSocketChannelClientWrapper::didStartClosingHandshake() | 90 void ThreadableWebSocketChannelClientWrapper::didStartClosingHandshake() |
76 { | 91 { |
77 if (m_client) | 92 m_pendingTasks.append(createCallbackTask(&didStartClosingHandshakeCallback,
this)); |
78 m_client->didStartClosingHandshake(); | 93 if (!m_suspended) |
| 94 processPendingTasks(); |
79 } | 95 } |
80 | 96 |
81 void ThreadableWebSocketChannelClientWrapper::didClose(WebSocketChannelClient::C
losingHandshakeCompletionStatus closingHandshakeCompletion, unsigned short code,
const String& reason) | 97 void ThreadableWebSocketChannelClientWrapper::didClose(WebSocketChannelClient::C
losingHandshakeCompletionStatus closingHandshakeCompletion, unsigned short code,
const String& reason) |
82 { | 98 { |
83 if (m_client) | 99 m_pendingTasks.append(createCallbackTask(&didCloseCallback, this, closingHan
dshakeCompletion, code, reason)); |
84 m_client->didClose(closingHandshakeCompletion, code, reason); | 100 if (!m_suspended) |
| 101 processPendingTasks(); |
85 } | 102 } |
86 | 103 |
87 void ThreadableWebSocketChannelClientWrapper::didReceiveMessageError() | 104 void ThreadableWebSocketChannelClientWrapper::didReceiveMessageError() |
88 { | 105 { |
89 if (m_client) | 106 m_pendingTasks.append(createCallbackTask(&didReceiveMessageErrorCallback, th
is)); |
90 m_client->didReceiveMessageError(); | 107 if (!m_suspended) |
| 108 processPendingTasks(); |
| 109 } |
| 110 |
| 111 void ThreadableWebSocketChannelClientWrapper::suspend() |
| 112 { |
| 113 m_suspended = true; |
| 114 } |
| 115 |
| 116 void ThreadableWebSocketChannelClientWrapper::resume() |
| 117 { |
| 118 m_suspended = false; |
| 119 processPendingTasks(); |
| 120 } |
| 121 |
| 122 void ThreadableWebSocketChannelClientWrapper::processPendingTasks() |
| 123 { |
| 124 if (m_suspended) |
| 125 return; |
| 126 Vector<OwnPtr<ExecutionContextTask> > tasks; |
| 127 tasks.swap(m_pendingTasks); |
| 128 for (Vector<OwnPtr<ExecutionContextTask> >::const_iterator iter = tasks.begi
n(); iter != tasks.end(); ++iter) |
| 129 (*iter)->performTask(0); |
| 130 } |
| 131 |
| 132 void ThreadableWebSocketChannelClientWrapper::didConnectCallback(ExecutionContex
t* context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientWrapper> wrap
per, const String& subprotocol, const String& extensions) |
| 133 { |
| 134 ASSERT_UNUSED(context, !context); |
| 135 if (wrapper->m_client) |
| 136 wrapper->m_client->didConnect(subprotocol, extensions); |
| 137 } |
| 138 |
| 139 void ThreadableWebSocketChannelClientWrapper::didReceiveMessageCallback(Executio
nContext* context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientWrappe
r> wrapper, const String& message) |
| 140 { |
| 141 ASSERT_UNUSED(context, !context); |
| 142 if (wrapper->m_client) |
| 143 wrapper->m_client->didReceiveMessage(message); |
| 144 } |
| 145 |
| 146 void ThreadableWebSocketChannelClientWrapper::didReceiveBinaryDataCallback(Execu
tionContext* context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientWra
pper> wrapper, PassOwnPtr<Vector<char> > binaryData) |
| 147 { |
| 148 ASSERT_UNUSED(context, !context); |
| 149 if (wrapper->m_client) |
| 150 wrapper->m_client->didReceiveBinaryData(binaryData); |
| 151 } |
| 152 |
| 153 void ThreadableWebSocketChannelClientWrapper::didConsumeBufferedAmountCallback(E
xecutionContext* context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClien
tWrapper> wrapper, unsigned long consumed) |
| 154 { |
| 155 ASSERT_UNUSED(context, !context); |
| 156 if (wrapper->m_client) |
| 157 wrapper->m_client->didConsumeBufferedAmount(consumed); |
| 158 } |
| 159 |
| 160 void ThreadableWebSocketChannelClientWrapper::didStartClosingHandshakeCallback(E
xecutionContext* context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClien
tWrapper> wrapper) |
| 161 { |
| 162 ASSERT_UNUSED(context, !context); |
| 163 if (wrapper->m_client) |
| 164 wrapper->m_client->didStartClosingHandshake(); |
| 165 } |
| 166 |
| 167 void ThreadableWebSocketChannelClientWrapper::didCloseCallback(ExecutionContext*
context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientWrapper> wrappe
r, WebSocketChannelClient::ClosingHandshakeCompletionStatus closingHandshakeComp
letion, unsigned short code, const String& reason) |
| 168 { |
| 169 ASSERT_UNUSED(context, !context); |
| 170 if (wrapper->m_client) |
| 171 wrapper->m_client->didClose(closingHandshakeCompletion, code, reason); |
| 172 } |
| 173 |
| 174 void ThreadableWebSocketChannelClientWrapper::didReceiveMessageErrorCallback(Exe
cutionContext* context, PassRefPtrWillBeRawPtr<ThreadableWebSocketChannelClientW
rapper> wrapper) |
| 175 { |
| 176 ASSERT_UNUSED(context, !context); |
| 177 if (wrapper->m_client) |
| 178 wrapper->m_client->didReceiveMessageError(); |
91 } | 179 } |
92 | 180 |
93 } // namespace WebCore | 181 } // namespace WebCore |
OLD | NEW |