Files
TrinityCore/src/common/Threading/ThreadPool.h
Shauren 585e170ad6 Core/Network: Refactor AsyncAcceptor to use async_accept overload producing sockets through argument instead of having to preallocate it
* Also improve main() cleanup to fully process all queued async operations (including their cancellations)
2026-01-12 20:59:19 +01:00

56 lines
1.4 KiB
C++

/*
* This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
*
* 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 TRINITY_THREAD_POOL_H
#define TRINITY_THREAD_POOL_H
#include <boost/asio/post.hpp>
#include <boost/asio/thread_pool.hpp>
#include <thread>
namespace Trinity
{
class ThreadPool
{
public:
using executor_type = boost::asio::thread_pool::executor_type;
explicit ThreadPool(std::size_t numThreads = std::thread::hardware_concurrency()) : _impl(numThreads) { }
template<typename T>
decltype(auto) PostWork(T&& work)
{
return boost::asio::post(_impl, std::forward<T>(work));
}
void Join()
{
_impl.join();
}
void Stop()
{
_impl.stop();
}
private:
boost::asio::thread_pool _impl;
};
}
#endif // TRINITY_THREAD_POOL_H