Commit 1195092c authored by Ian Barber's avatar Ian Barber

Merge pull request #574 from pijyoi/master

fix memory leak in ipc_listener wildcard
parents 5c54bc35 38327927
...@@ -119,19 +119,24 @@ int zmq::ipc_listener_t::get_address (std::string &addr_) ...@@ -119,19 +119,24 @@ int zmq::ipc_listener_t::get_address (std::string &addr_)
int zmq::ipc_listener_t::set_address (const char *addr_) int zmq::ipc_listener_t::set_address (const char *addr_)
{ {
// Create addr on stack for auto-cleanup
std::string addr (addr_);
// Allow wildcard file // Allow wildcard file
if (*addr_ == '*') { if (addr[0] == '*') {
addr_ = tempnam(NULL, NULL); char *tmpstr = tempnam (NULL, NULL);
addr.assign (tmpstr);
free (tmpstr);
} }
// Get rid of the file associated with the UNIX domain socket that // Get rid of the file associated with the UNIX domain socket that
// may have been left behind by the previous run of the application. // may have been left behind by the previous run of the application.
::unlink (addr_); ::unlink (addr.c_str());
filename.clear (); filename.clear ();
// Initialise the address structure. // Initialise the address structure.
ipc_address_t address; ipc_address_t address;
int rc = address.resolve (addr_); int rc = address.resolve (addr.c_str());
if (rc != 0) if (rc != 0)
return -1; return -1;
...@@ -147,10 +152,10 @@ int zmq::ipc_listener_t::set_address (const char *addr_) ...@@ -147,10 +152,10 @@ int zmq::ipc_listener_t::set_address (const char *addr_)
if (rc != 0) if (rc != 0)
goto error; goto error;
filename.assign(addr_); filename.assign (addr.c_str());
has_file = true; has_file = true;
// Listen for incomming connections. // Listen for incoming connections.
rc = listen (s, options.backlog); rc = listen (s, options.backlog);
if (rc != 0) if (rc != 0)
goto error; goto error;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment