From: J. Alexander Treuman Date: Sun, 23 Mar 2008 19:57:37 +0000 (-0400) Subject: mpd.py: use a separate file object for reading and writing sockets X-Git-Tag: v0.2.0~11 X-Git-Url: https://git.kaliko.me/?a=commitdiff_plain;h=cde055b004d6e9f8a8d3c9548d4f4778c6897472;p=python-musicpd.git mpd.py: use a separate file object for reading and writing sockets This is to make it easier to read command output from a file instead of a socket. Useful for testing and benchmarking. --- diff --git a/mpd.py b/mpd.py index 02d2788..33449ca 100644 --- a/mpd.py +++ b/mpd.py @@ -141,8 +141,8 @@ class MPDClient(object): self._commandlist.append(retval) def _writeline(self, line): - self._sockfile.write("%s\n" % line) - self._sockfile.flush() + self._wfile.write("%s\n" % line) + self._wfile.flush() def _writecommand(self, command, args=[]): parts = [command] @@ -151,7 +151,7 @@ class MPDClient(object): self._writeline(" ".join(parts)) def _readline(self): - line = self._sockfile.readline() + line = self._rfile.readline() if not line.endswith("\n"): raise ConnectionError, "Connection lost while reading line" line = line.rstrip("\n") @@ -272,7 +272,7 @@ class MPDClient(object): return self._wrapiterator(self._readcommandlist()) def _hello(self): - line = self._sockfile.readline() + line = self._rfile.readline() if not line.endswith("\n"): raise ConnectionError, "Connection lost while reading MPD hello" if not line.startswith(HELLO_PREFIX): @@ -283,18 +283,21 @@ class MPDClient(object): self.mpd_version = None self._commandlist = None self._sock = None - self._sockfile = _NotConnected() + self._rfile = _NotConnected() + self._wfile = _NotConnected() def connect(self, host, port): if self._sock: self.disconnect() self._sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) self._sock.connect((host, port)) - self._sockfile = self._sock.makefile("rb+") + self._rfile = self._sock.makefile("rb") + self._wfile = self._sock.makefile("wb") self._hello() def disconnect(self): - self._sockfile.close() + self._rfile.close() + self._wfile.close() self._sock.close() self._reset()