class Cpprestsdk < Formula desc "C++ libraries for cloud-based client-server communication" homepage "https://github.com/Microsoft/cpprestsdk" # pull from git tag to get submodules url "https://github.com/Microsoft/cpprestsdk.git", :tag => "v2.10.14", :revision => "6f602bee67b088a299d7901534af3bce6334ab38" head "https://github.com/Microsoft/cpprestsdk.git", :branch => "development" bottle do cellar :any sha256 "c8a92d2adfea4a4b6c685ad9bd1b405541b82da25edf0da87a5374fe80fa5baa" => :mojave sha256 "72fad0d3264e172131fab6bf10a0fe4921720d40b904cd461f6cf471853172d0" => :high_sierra sha256 "8ae441fdbb263b13aa0c7e992f616e02eefab8d1e7a1ad12613daa340d918d83" => :sierra end depends_on "cmake" => :build depends_on "boost" depends_on "openssl" # Fix for boost 1.70.0 https://github.com/microsoft/cpprestsdk/issues/1054 # From websocketpp pull request https://github.com/zaphoyd/websocketpp/pull/814 patch :DATA def install system "cmake", "-DBUILD_SAMPLES=OFF", "-DBUILD_TESTS=OFF", "Release", *std_cmake_args system "make", "install" end test do (testpath/"test.cc").write <<~EOS #include #include int main() { web::http::client::http_client client(U("https://github.com/")); std::cout << client.request(web::http::methods::GET).get().extract_string().get() << std::endl; } EOS flags = ["-stdlib=libc++", "-std=c++11", "-I#{include}", "-I#{Formula["boost"].include}", "-I#{Formula["openssl"].include}", "-L#{lib}", "-L#{Formula["openssl"].lib}", "-L#{Formula["boost"].lib}", "-lssl", "-lcrypto", "-lboost_random", "-lboost_chrono", "-lboost_thread-mt", "-lboost_system-mt", "-lboost_regex", "-lboost_filesystem", "-lcpprest"] + ENV.cflags.to_s.split system ENV.cxx, "-o", "test_cpprest", "test.cc", *flags system "./test_cpprest" end end __END__ diff -pur a/Release/libs/websocketpp/websocketpp/transport/asio/connection.hpp b/Release/libs/websocketpp/websocketpp/transport/asio/connection.hpp --- a/Release/libs/websocketpp/websocketpp/transport/asio/connection.hpp 2019-06-08 17:26:20.000000000 +0200 +++ b/Release/libs/websocketpp/websocketpp/transport/asio/connection.hpp 2019-06-08 17:23:38.000000000 +0200 @@ -311,9 +311,8 @@ public: * needed. */ timer_ptr set_timer(long duration, timer_handler callback) { - timer_ptr new_timer = lib::make_shared( - lib::ref(*m_io_service), - lib::asio::milliseconds(duration) + timer_ptr new_timer( + new lib::asio::steady_timer(*m_io_service, lib::asio::milliseconds(duration)) ); if (config::enable_multithreading) { @@ -461,8 +460,7 @@ protected: m_io_service = io_service; if (config::enable_multithreading) { - m_strand = lib::make_shared( - lib::ref(*io_service)); + m_strand.reset(new lib::asio::io_service::strand(*io_service)); } lib::error_code ec = socket_con_type::init_asio(io_service, m_strand, diff -pur a/Release/libs/websocketpp/websocketpp/transport/asio/endpoint.hpp b/Release/libs/websocketpp/websocketpp/transport/asio/endpoint.hpp --- a/Release/libs/websocketpp/websocketpp/transport/asio/endpoint.hpp 2019-06-08 17:26:20.000000000 +0200 +++ b/Release/libs/websocketpp/websocketpp/transport/asio/endpoint.hpp 2019-06-08 17:24:25.000000000 +0200 @@ -195,8 +195,7 @@ public: m_io_service = ptr; m_external_io_service = true; - m_acceptor = lib::make_shared( - lib::ref(*m_io_service)); + m_acceptor.reset(new lib::asio::ip::tcp::acceptor(*m_io_service)); m_state = READY; ec = lib::error_code(); @@ -688,9 +687,7 @@ public: * @since 0.3.0 */ void start_perpetual() { - m_work = lib::make_shared( - lib::ref(*m_io_service) - ); + m_work.reset(new lib::asio::io_service::work(*m_io_service)); } /// Clears the endpoint's perpetual flag, allowing it to exit when empty @@ -854,8 +851,7 @@ protected: // Create a resolver if (!m_resolver) { - m_resolver = lib::make_shared( - lib::ref(*m_io_service)); + m_resolver.reset(new lib::asio::ip::tcp::resolver(*m_io_service)); } tcon->set_uri(u); diff -pur a/Release/libs/websocketpp/websocketpp/transport/asio/security/none.hpp b/Release/libs/websocketpp/websocketpp/transport/asio/security/none.hpp --- a/Release/libs/websocketpp/websocketpp/transport/asio/security/none.hpp 2019-06-08 17:26:20.000000000 +0200 +++ b/Release/libs/websocketpp/websocketpp/transport/asio/security/none.hpp 2019-06-08 17:24:44.000000000 +0200 @@ -168,8 +168,7 @@ protected: return socket::make_error_code(socket::error::invalid_state); } - m_socket = lib::make_shared( - lib::ref(*service)); + m_socket.reset(new lib::asio::ip::tcp::socket(*service)); if (m_socket_init_handler) { m_socket_init_handler(m_hdl, *m_socket); diff -pur a/Release/libs/websocketpp/websocketpp/transport/asio/security/tls.hpp b/Release/libs/websocketpp/websocketpp/transport/asio/security/tls.hpp --- a/Release/libs/websocketpp/websocketpp/transport/asio/security/tls.hpp 2019-06-08 17:26:20.000000000 +0200 +++ b/Release/libs/websocketpp/websocketpp/transport/asio/security/tls.hpp 2019-06-08 17:25:04.000000000 +0200 @@ -193,8 +193,7 @@ protected: if (!m_context) { return socket::make_error_code(socket::error::invalid_tls_context); } - m_socket = lib::make_shared( - _WEBSOCKETPP_REF(*service),lib::ref(*m_context)); + m_socket.reset(new socket_type(*service, *m_context)); if (m_socket_init_handler) { m_socket_init_handler(m_hdl, get_socket());