Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
0377d3a4
Commit
0377d3a4
authored
Apr 30, 2020
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More fixes for broadcast host names in c-ares.
parent
9f152568
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
2 deletions
+15
-2
src/gevent/resolver/ares.py
src/gevent/resolver/ares.py
+15
-2
No files found.
src/gevent/resolver/ares.py
View file @
0377d3a4
...
...
@@ -7,6 +7,8 @@ import os
from
_socket
import
getaddrinfo
as
native_getaddrinfo
from
_socket
import
gethostbyname_ex
as
native_gethostbyname_ex
from
_socket
import
gethostbyname
as
native_gethostbyname
from
_socket
import
gethostbyaddr
as
native_gethostbyaddr
from
_socket
import
gaierror
from
_socket
import
herror
from
_socket
import
error
...
...
@@ -157,6 +159,14 @@ class Resolver(AbstractResolver):
self
.
fork_watcher
.
stop
()
def
gethostbyname
(
self
,
hostname
,
family
=
AF_INET
):
# The native ``gethostbyname`` and ``gethostbyname_ex`` have some different
# behaviour with special names. Notably, ``gethostbyname`` will handle
# both "<broadcast>" and "255.255.255.255", while ``gethostbyname_ex`` refuses to
# handle those; they result in different errors, too. So we can't
# pass those throgh.
hostname
=
self
.
_hostname_to_bytes
(
hostname
)
if
hostname
in
self
.
_LOCAL_AND_BROADCAST_HOSTNAMES
:
return
native_gethostbyname
(
hostname
)
hostname
=
_resolve_special
(
hostname
,
family
)
return
self
.
gethostbyname_ex
(
hostname
,
family
)[
-
1
][
0
]
...
...
@@ -187,8 +197,9 @@ class Resolver(AbstractResolver):
def
gethostbyname_ex
(
self
,
hostname
,
family
=
AF_INET
):
hostname
=
self
.
_hostname_to_bytes
(
hostname
)
if
hostname
in
self
.
_LOCAL_AND_BROADCAST_HOSTNAMES
:
# The broadcast specials aren't handled here, but they may produce
# special errors that are hard to replicate across all systems.
return
native_gethostbyname_ex
(
hostname
)
while
True
:
...
...
@@ -314,7 +325,8 @@ class Resolver(AbstractResolver):
raise
def
_gethostbyaddr
(
self
,
ip_address
):
ip_address
=
self
.
_hostname_to_bytes
(
ip_address
)
if
ip_address
in
self
.
_LOCAL_AND_BROADCAST_HOSTNAMES
:
return
native_gethostbyaddr
(
ip_address
)
waiter
=
Waiter
(
self
.
hub
)
try
:
...
...
@@ -335,6 +347,7 @@ class Resolver(AbstractResolver):
def
gethostbyaddr
(
self
,
ip_address
):
ip_address
=
_resolve_special
(
ip_address
,
AF_UNSPEC
)
ip_address
=
self
.
_hostname_to_bytes
(
ip_address
)
while
True
:
ares
=
self
.
cares
try
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment