diff options
author | martinko | 2013-08-09 14:03:34 +0000 |
---|---|---|
committer | martinko | 2013-08-09 14:03:34 +0000 |
commit | 49ac8090682a5d76b577eeade3e29c9e4d83650c (patch) | |
tree | 0bd7141f24ccaa9cdaf2120006263bfe47d4f36a /python/skytools/sockutil.py | |
parent | aae5c5b1dde3e456189cdff0fa1cd7b5cb369aa8 (diff) | |
parent | 344d063d4e61bdd382d9e1977964fa1fe6363991 (diff) |
Merge branch 'release/skytools_3_1_5'skytools_3_1_5
Diffstat (limited to 'python/skytools/sockutil.py')
-rw-r--r-- | python/skytools/sockutil.py | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/python/skytools/sockutil.py b/python/skytools/sockutil.py index f950f5a0..dbcd021b 100644 --- a/python/skytools/sockutil.py +++ b/python/skytools/sockutil.py @@ -37,10 +37,13 @@ def set_tcp_keepalive(fd, keepalive = True, if not hasattr(socket, 'SO_KEEPALIVE') or not hasattr(socket, 'fromfd'): return - # get numeric fd and cast to socket - if hasattr(fd, 'fileno'): - fd = fd.fileno() - s = socket.fromfd(fd, socket.AF_INET, socket.SOCK_STREAM) + # need socket object + if isinstance(fd, socket.SocketType): + s = fd + else: + if hasattr(fd, 'fileno'): + fd = fd.fileno() + s = socket.fromfd(fd, socket.AF_INET, socket.SOCK_STREAM) # skip if unix socket if type(s.getsockname()) != type(()): |