Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
writelines implementation
  • Loading branch information
kumaraditya303 authored Oct 24, 2022
commit 669b661a1aa5e404c9ddff5419643d9d4adbf5e1
13 changes: 7 additions & 6 deletions Lib/asyncio/selector_events.py
Original file line number Diff line number Diff line change
Expand Up @@ -1148,13 +1148,14 @@ def write_eof(self):
self._sock.shutdown(socket.SHUT_WR)

def writelines(self, list_of_data):
Comment thread
kumaraditya303 marked this conversation as resolved.
hasbuffer = len(self._buffer)
self._buffer.extend([memoryview(i) for i in list_of_data])
if not hasbuffer:
# Optimization: try to send now
self._write_ready()
if self._eof:
raise RuntimeError('Cannot call writelines() after write_eof()')
if self._empty_waiter is not None:
raise RuntimeError('unable to writelines; sendfile is in progress')
if not list_of_data:
return
self._maybe_pause_protocol()
self._buffer.extend([memoryview(i) for i in list_of_data])
Comment thread
kumaraditya303 marked this conversation as resolved.
Outdated
self._loop._add_writer(self._sock_fd, self._write_ready)
Comment thread
kumaraditya303 marked this conversation as resolved.
Outdated

def can_write_eof(self):
return True
Expand Down
2 changes: 1 addition & 1 deletion Lib/test/test_asyncio/test_selector_events.py
Original file line number Diff line number Diff line change
Expand Up @@ -810,7 +810,7 @@ def test_write_ready(self):
self.sock.send.return_value = len(data)

transport = self.socket_transport()
transport._buffer.extend(data)
transport._buffer.append(data)
self.loop._add_writer(7, transport._write_ready)
transport._write_ready()
self.assertTrue(self.sock.send.called)
Expand Down