Merge pull request #1046 from laanwj/2012_04_rpcporterror
authorWladimir J. van der Laan <laanwj@gmail.com>
Tue, 10 Apr 2012 20:14:47 +0000 (13:14 -0700)
committerWladimir J. van der Laan <laanwj@gmail.com>
Tue, 10 Apr 2012 20:14:47 +0000 (13:14 -0700)
Show error message instead of exception crash when unable to bind RPC port

src/bitcoinrpc.cpp

index cbdd21c..4075c90 100644 (file)
@@ -2376,9 +2376,21 @@ void ThreadRPCServer2(void* parg)
 
     asio::io_service io_service;
     ip::tcp::endpoint endpoint(bindAddress, GetArg("-rpcport", 8332));
-    ip::tcp::acceptor acceptor(io_service, endpoint);
-
-    acceptor.set_option(boost::asio::ip::tcp::acceptor::reuse_address(true));
+    ip::tcp::acceptor acceptor(io_service);
+    try
+    {
+        acceptor.open(endpoint.protocol());
+        acceptor.set_option(boost::asio::ip::tcp::acceptor::reuse_address(true));
+        acceptor.bind(endpoint);
+        acceptor.listen(socket_base::max_connections);
+    }
+    catch(system::system_error &e)
+    {
+        ThreadSafeMessageBox(strprintf(_("An error occured while setting up the RPC port %i for listening: %s"), endpoint.port(), e.what()),
+                             _("Error"), wxOK | wxMODAL);
+        QueueShutdown();
+        return;
+    }
 
     ssl::context context(io_service, ssl::context::sslv23);
     if (fUseSSL)