Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
9c46e875
Commit
9c46e875
authored
Mar 27, 2012
by
Martin Hurton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
tcp_address: minor cleanups
parent
700e08c3
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
12 additions
and
11 deletions
+12
-11
tcp_address.cpp
src/tcp_address.cpp
+12
-11
No files found.
src/tcp_address.cpp
View file @
9c46e875
...
@@ -213,13 +213,13 @@ int zmq::tcp_address_t::resolve_nic_name (const char *nic_, bool ipv4only_)
...
@@ -213,13 +213,13 @@ int zmq::tcp_address_t::resolve_nic_name (const char *nic_, bool ipv4only_)
#endif
#endif
int
zmq
::
tcp_address_t
::
resolve_interface
(
c
har
const
*
interface_
,
int
zmq
::
tcp_address_t
::
resolve_interface
(
c
onst
char
*
interface_
,
bool
ipv4only_
)
bool
ipv4only_
)
{
{
// Initialize temporary output pointers with storage address.
// Initialize temporary output pointers with storage address.
sockaddr_storage
ss
;
sockaddr_storage
ss
;
sockaddr
*
out_addr
=
(
sockaddr
*
)
&
ss
;
sockaddr
*
out_addr
=
(
sockaddr
*
)
&
ss
;
s
ocklen
_t
out_addrlen
;
s
ize
_t
out_addrlen
;
// Initialise IP-format family/port and populate temporary output pointers
// Initialise IP-format family/port and populate temporary output pointers
// with the address.
// with the address.
...
@@ -228,20 +228,21 @@ int zmq::tcp_address_t::resolve_interface (char const *interface_,
...
@@ -228,20 +228,21 @@ int zmq::tcp_address_t::resolve_interface (char const *interface_,
memset
(
&
ip4_addr
,
0
,
sizeof
(
ip4_addr
));
memset
(
&
ip4_addr
,
0
,
sizeof
(
ip4_addr
));
ip4_addr
.
sin_family
=
AF_INET
;
ip4_addr
.
sin_family
=
AF_INET
;
ip4_addr
.
sin_addr
.
s_addr
=
htonl
(
INADDR_ANY
);
ip4_addr
.
sin_addr
.
s_addr
=
htonl
(
INADDR_ANY
);
out_addrlen
=
(
socklen_t
)
sizeof
(
ip4_addr
)
;
out_addrlen
=
sizeof
ip4_addr
;
memcpy
(
out_addr
,
&
ip4_addr
,
out_addrlen
);
memcpy
(
out_addr
,
&
ip4_addr
,
out_addrlen
);
}
else
{
}
else
{
sockaddr_in6
ip6_addr
;
sockaddr_in6
ip6_addr
;
memset
(
&
ip6_addr
,
0
,
sizeof
(
ip6_addr
));
memset
(
&
ip6_addr
,
0
,
sizeof
(
ip6_addr
));
ip6_addr
.
sin6_family
=
AF_INET6
;
ip6_addr
.
sin6_family
=
AF_INET6
;
memcpy
(
&
ip6_addr
.
sin6_addr
,
&
in6addr_any
,
sizeof
(
in6addr_any
));
memcpy
(
&
ip6_addr
.
sin6_addr
,
&
in6addr_any
,
sizeof
(
in6addr_any
));
out_addrlen
=
(
socklen_t
)
sizeof
(
ip6_addr
)
;
out_addrlen
=
sizeof
ip6_addr
;
memcpy
(
out_addr
,
&
ip6_addr
,
out_addrlen
);
memcpy
(
out_addr
,
&
ip6_addr
,
out_addrlen
);
}
}
// * resolves to INADDR_ANY or in6addr_any.
// * resolves to INADDR_ANY or in6addr_any.
if
(
strcmp
(
interface_
,
"*"
)
==
0
)
{
if
(
strcmp
(
interface_
,
"*"
)
==
0
)
{
zmq_assert
(
out_addrlen
<=
(
socklen_t
)
sizeof
(
address
)
);
zmq_assert
(
out_addrlen
<=
sizeof
address
);
memcpy
(
&
address
,
out_addr
,
out_addrlen
);
memcpy
(
&
address
,
out_addr
,
out_addrlen
);
return
0
;
return
0
;
}
}
...
@@ -251,7 +252,7 @@ int zmq::tcp_address_t::resolve_interface (char const *interface_,
...
@@ -251,7 +252,7 @@ int zmq::tcp_address_t::resolve_interface (char const *interface_,
if
(
rc
!=
0
&&
errno
!=
ENODEV
)
if
(
rc
!=
0
&&
errno
!=
ENODEV
)
return
rc
;
return
rc
;
if
(
rc
==
0
)
{
if
(
rc
==
0
)
{
zmq_assert
(
out_addrlen
<=
(
socklen_t
)
sizeof
(
address
)
);
zmq_assert
(
out_addrlen
<=
sizeof
address
);
memcpy
(
&
address
,
out_addr
,
out_addrlen
);
memcpy
(
&
address
,
out_addr
,
out_addrlen
);
return
0
;
return
0
;
}
}
...
@@ -391,13 +392,13 @@ int zmq::tcp_address_t::resolve (const char *name_, bool local_, bool ipv4only_)
...
@@ -391,13 +392,13 @@ int zmq::tcp_address_t::resolve (const char *name_, bool local_, bool ipv4only_)
addr_str
=
addr_str
.
substr
(
1
,
addr_str
.
size
()
-
2
);
addr_str
=
addr_str
.
substr
(
1
,
addr_str
.
size
()
-
2
);
uint16_t
port
;
uint16_t
port
;
// Allow 0 specifically, to detect invalid port error in atoi if not
//
Allow 0 specifically, to detect invalid port error in atoi if not
if
(
port_str
==
"*"
||
port_str
==
"0"
)
if
(
port_str
==
"*"
||
port_str
==
"0"
)
// Resolve wildcard to 0 to allow autoselection of port
//
Resolve wildcard to 0 to allow autoselection of port
port
=
0
;
port
=
0
;
else
{
else
{
// Parse the port number (0 is not a valid port).
// Parse the port number (0 is not a valid port).
port
=
(
uint16_t
)
atoi
(
port_str
.
c_str
());
port
=
(
uint16_t
)
atoi
(
port_str
.
c_str
());
if
(
port
==
0
)
{
if
(
port
==
0
)
{
errno
=
EINVAL
;
errno
=
EINVAL
;
return
-
1
;
return
-
1
;
...
...
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