| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009, 2011, 2012 Google Inc. All rights reserved. | 2 * Copyright (C) 2009, 2011, 2012 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 176 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 187 bool SocketStreamHandle::send(const char* data, int length) | 187 bool SocketStreamHandle::send(const char* data, int length) |
| 188 { | 188 { |
| 189 if (m_state == Connecting || m_state == Closing) | 189 if (m_state == Connecting || m_state == Closing) |
| 190 return false; | 190 return false; |
| 191 if (!m_buffer.isEmpty()) { | 191 if (!m_buffer.isEmpty()) { |
| 192 if (m_buffer.size() + length > bufferSize) { | 192 if (m_buffer.size() + length > bufferSize) { |
| 193 // FIXME: report error to indicate that buffer has no more space. | 193 // FIXME: report error to indicate that buffer has no more space. |
| 194 return false; | 194 return false; |
| 195 } | 195 } |
| 196 m_buffer.append(data, length); | 196 m_buffer.append(data, length); |
| 197 if (m_client) | |
| 198 m_client->didUpdateBufferedAmount(this, bufferedAmount()); | |
| 199 return true; | 197 return true; |
| 200 } | 198 } |
| 201 int bytesWritten = 0; | 199 int bytesWritten = 0; |
| 202 if (m_state == Open) | 200 if (m_state == Open) |
| 203 bytesWritten = sendInternal(data, length); | 201 bytesWritten = sendInternal(data, length); |
| 204 if (bytesWritten < 0) | 202 if (bytesWritten < 0) |
| 205 return false; | 203 return false; |
| 204 if (m_client) |
| 205 m_client->didConsumeBufferedAmount(this, bytesWritten); |
| 206 if (m_buffer.size() + length - bytesWritten > bufferSize) { | 206 if (m_buffer.size() + length - bytesWritten > bufferSize) { |
| 207 // FIXME: report error to indicate that buffer has no more space. | 207 // FIXME: report error to indicate that buffer has no more space. |
| 208 return false; | 208 return false; |
| 209 } | 209 } |
| 210 if (bytesWritten < length) { | 210 if (bytesWritten < length) { |
| 211 m_buffer.append(data + bytesWritten, length - bytesWritten); | 211 m_buffer.append(data + bytesWritten, length - bytesWritten); |
| 212 if (m_client) | |
| 213 m_client->didUpdateBufferedAmount(this, bufferedAmount()); | |
| 214 } | 212 } |
| 215 return true; | 213 return true; |
| 216 } | 214 } |
| 217 | 215 |
| 218 void SocketStreamHandle::close() | 216 void SocketStreamHandle::close() |
| 219 { | 217 { |
| 220 if (m_state == Closed) | 218 if (m_state == Closed) |
| 221 return; | 219 return; |
| 222 m_state = Closing; | 220 m_state = Closing; |
| 223 if (!m_buffer.isEmpty()) | 221 if (!m_buffer.isEmpty()) |
| (...skipping 28 matching lines...) Expand all Loading... |
| 252 } | 250 } |
| 253 } | 251 } |
| 254 bool pending; | 252 bool pending; |
| 255 do { | 253 do { |
| 256 int bytesWritten = sendInternal(m_buffer.firstBlockData(), m_buffer.firs
tBlockSize()); | 254 int bytesWritten = sendInternal(m_buffer.firstBlockData(), m_buffer.firs
tBlockSize()); |
| 257 pending = bytesWritten != static_cast<int>(m_buffer.firstBlockSize()); | 255 pending = bytesWritten != static_cast<int>(m_buffer.firstBlockSize()); |
| 258 if (bytesWritten <= 0) | 256 if (bytesWritten <= 0) |
| 259 return false; | 257 return false; |
| 260 ASSERT(m_buffer.size() - bytesWritten <= bufferSize); | 258 ASSERT(m_buffer.size() - bytesWritten <= bufferSize); |
| 261 m_buffer.consume(bytesWritten); | 259 m_buffer.consume(bytesWritten); |
| 260 if (m_client) |
| 261 m_client->didConsumeBufferedAmount(this, bytesWritten); |
| 262 } while (!pending && !m_buffer.isEmpty()); | 262 } while (!pending && !m_buffer.isEmpty()); |
| 263 if (m_client) | |
| 264 m_client->didUpdateBufferedAmount(this, bufferedAmount()); | |
| 265 return true; | 263 return true; |
| 266 } | 264 } |
| 267 | 265 |
| 268 int SocketStreamHandle::sendInternal(const char* buf, int len) | 266 int SocketStreamHandle::sendInternal(const char* buf, int len) |
| 269 { | 267 { |
| 270 if (!m_internal) | 268 if (!m_internal) |
| 271 return 0; | 269 return 0; |
| 272 return m_internal->send(buf, len); | 270 return m_internal->send(buf, len); |
| 273 } | 271 } |
| 274 | 272 |
| 275 void SocketStreamHandle::closeInternal() | 273 void SocketStreamHandle::closeInternal() |
| 276 { | 274 { |
| 277 if (m_internal) | 275 if (m_internal) |
| 278 m_internal->close(); | 276 m_internal->close(); |
| 279 } | 277 } |
| 280 | 278 |
| 281 } // namespace WebCore | 279 } // namespace WebCore |
| OLD | NEW |