X-Git-Url: http://git.kaliko.me/?p=python-musicpd.git;a=blobdiff_plain;f=mpd.py;h=c924b3c758940ba4a1d4d43014339dc34e92cce7;hp=ce1784b4227da5aa437801ef2d536b91d8cb4851;hb=285bcce3de90f2e5474978d0bbb5fa4485b957f3;hpb=4f4b01dd0d04a341f6834fdca4d777ff5d6850db diff --git a/mpd.py b/mpd.py index ce1784b..c924b3c 100644 --- a/mpd.py +++ b/mpd.py @@ -275,6 +275,7 @@ class MPDClient(object): line = self._rfile.readline() if not line.endswith("\n"): raise ConnectionError, "Connection lost while reading MPD hello" + line = line.rstrip("\n") if not line.startswith(HELLO_PREFIX): raise ProtocolError, "Got invalid MPD hello: '%s'" % line self.mpd_version = line[len(HELLO_PREFIX):].strip() @@ -289,11 +290,29 @@ class MPDClient(object): def connect(self, host, port): if self._sock: raise ConnectionError, "Already connected" - self._sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) - self._sock.connect((host, port)) + msg = "getaddrinfo returns an empty list" + for res in socket.getaddrinfo(host, port, socket.AF_UNSPEC, + socket.SOCK_STREAM, socket.IPPROTO_TCP, + socket.AI_ADDRCONFIG): + af, socktype, proto, canonname, sa = res + try: + self._sock = socket.socket(af, socktype, proto) + self._sock.connect(sa) + except socket.error, msg: + if self._sock: + self._sock.close() + self._sock = None + continue + break + if not self._sock: + raise socket.error, msg self._rfile = self._sock.makefile("rb") self._wfile = self._sock.makefile("wb") - self._hello() + try: + self._hello() + except (socket.error, MPDError): + self.disconnect() + raise def disconnect(self): self._rfile.close()