aboutsummaryrefslogtreecommitdiff
path: root/src/common/Asio
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2019-04-14 00:13:23 +0200
committerShauren <shauren.trinity@gmail.com>2019-04-14 00:13:23 +0200
commitbcda8dd7421cfa1950a3e47081f2f28d032d38ac (patch)
treed751264dc0fbce02f94b6bc3c42238f785605d91 /src/common/Asio
parent18aca970ce1042535945fca53e13fd7059aa2a50 (diff)
Core/Dep: Boost 1.70 compatibility
Diffstat (limited to 'src/common/Asio')
-rw-r--r--src/common/Asio/AsioHacksFwd.h24
-rw-r--r--src/common/Asio/DeadlineTimer.h45
-rw-r--r--src/common/Asio/IoContext.h19
3 files changed, 72 insertions, 16 deletions
diff --git a/src/common/Asio/AsioHacksFwd.h b/src/common/Asio/AsioHacksFwd.h
index 3e65395a3ca..2cb2282a10a 100644
--- a/src/common/Asio/AsioHacksFwd.h
+++ b/src/common/Asio/AsioHacksFwd.h
@@ -46,29 +46,25 @@ namespace boost
typedef basic_endpoint<tcp> tcp_endpoint;
}
+#if BOOST_VERSION >= 107000
+ class executor;
-#if BOOST_VERSION >= 106600
- template <typename Time, typename TimeTraits>
- class basic_deadline_timer;
-
- typedef basic_deadline_timer<posix_time::ptime, time_traits<posix_time::ptime>> deadline_timer;
+ namespace ip
+ {
+ template <typename InternetProtocol, typename Executor>
+ class basic_resolver;
+ typedef basic_resolver<tcp, executor> tcp_resolver;
+ }
+#elif BOOST_VERSION >= 106600
namespace ip
{
template <typename InternetProtocol>
class basic_resolver;
typedef basic_resolver<tcp> tcp_resolver;
- }
+ }
#else
- template <typename TimeType, typename TimeTraits>
- class deadline_timer_service;
-
- template <typename Time, typename TimeTraits, typename TimerService>
- class basic_deadline_timer;
-
- typedef basic_deadline_timer<posix_time::ptime, time_traits<posix_time::ptime>, deadline_timer_service<posix_time::ptime, time_traits<posix_time::ptime>>> deadline_timer;
-
namespace ip
{
template <typename InternetProtocol>
diff --git a/src/common/Asio/DeadlineTimer.h b/src/common/Asio/DeadlineTimer.h
new file mode 100644
index 00000000000..4e0c3a10b44
--- /dev/null
+++ b/src/common/Asio/DeadlineTimer.h
@@ -0,0 +1,45 @@
+/*
+ * Copyright (C) 2008-2019 TrinityCore <https://www.trinitycore.org/>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+ * more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef DeadlineTimer_h__
+#define DeadlineTimer_h__
+
+#include <boost/asio/deadline_timer.hpp>
+
+#if BOOST_VERSION >= 107000
+#define BasicDeadlineTimerThirdTemplateArg , boost::asio::io_context::executor_type
+#elif BOOST_VERSION >= 106600
+#define BasicDeadlineTimerThirdTemplateArg
+#else
+#define BasicDeadlineTimerThirdTemplateArg , boost::asio::deadline_timer_service<boost::posix_time::ptime, boost::asio::time_traits<boost::posix_time::ptime>>
+#endif
+
+#define DeadlineTimerBase boost::asio::basic_deadline_timer<boost::posix_time::ptime, boost::asio::time_traits<boost::posix_time::ptime> BasicDeadlineTimerThirdTemplateArg>
+
+namespace Trinity
+{
+ namespace Asio
+ {
+ class DeadlineTimer : public DeadlineTimerBase
+ {
+ public:
+ using DeadlineTimerBase::basic_deadline_timer;
+ };
+ }
+}
+
+#endif // DeadlineTimer_h__
diff --git a/src/common/Asio/IoContext.h b/src/common/Asio/IoContext.h
index e92222e8d0a..8ac0cc0a4e1 100644
--- a/src/common/Asio/IoContext.h
+++ b/src/common/Asio/IoContext.h
@@ -35,9 +35,24 @@ namespace Trinity
{
namespace Asio
{
- class IoContext : public IoContextBaseNamespace::IoContextBase
+ class IoContext
{
- using IoContextBaseNamespace::IoContextBase::IoContextBase;
+ public:
+ IoContext() : _impl() { }
+ explicit IoContext(int concurrency_hint) : _impl(concurrency_hint) { }
+
+ operator IoContextBaseNamespace::IoContextBase&() { return _impl; }
+ operator IoContextBaseNamespace::IoContextBase const&() const { return _impl; }
+
+ std::size_t run() { return _impl.run(); }
+ void stop() { _impl.stop(); }
+
+#if BOOST_VERSION >= 106600
+ boost::asio::io_context::executor_type get_executor() noexcept { return _impl.get_executor(); }
+#endif
+
+ private:
+ IoContextBaseNamespace::IoContextBase _impl;
};
template<typename T>