LCOV - code coverage report
Current view: top level - port - cpl_threadsafe_queue.hpp (source / functions) Hit Total Coverage
Test: gdal_filtered.info Lines: 29 29 100.0 %
Date: 2025-01-18 12:42:00 Functions: 13 13 100.0 %

          Line data    Source code
       1             : /******************************************************************************
       2             :  *
       3             :  * Project:  CPL
       4             :  * Purpose:  Implementation of a thread-safe queue
       5             :  * Author:   Even Rouault <even dot rouault at spatialys.com>
       6             :  *
       7             :  ******************************************************************************
       8             :  * Copyright (c) 2022, Even Rouault <even dot rouault at spatialys.com>
       9             :  *
      10             :  * SPDX-License-Identifier: MIT
      11             :  ****************************************************************************/
      12             : 
      13             : #ifndef CPL_THREADSAFE_QUEUE_INCLUDED
      14             : #define CPL_THREADSAFE_QUEUE_INCLUDED
      15             : 
      16             : #include <condition_variable>
      17             : #include <mutex>
      18             : #include <queue>
      19             : 
      20             : namespace cpl
      21             : {
      22             : template <class T> class ThreadSafeQueue
      23             : {
      24             :   private:
      25             :     mutable std::mutex m_mutex{};
      26             :     std::condition_variable m_cv{};
      27             :     std::queue<T> m_queue{};
      28             : 
      29             :   public:
      30        3677 :     ThreadSafeQueue() = default;
      31             : 
      32           5 :     void clear()
      33             :     {
      34          10 :         std::lock_guard<std::mutex> lock(m_mutex);
      35         148 :         while (!m_queue.empty())
      36         143 :             m_queue.pop();
      37           5 :     }
      38             : 
      39          17 :     bool empty() const
      40             :     {
      41          34 :         std::lock_guard<std::mutex> lock(m_mutex);
      42          34 :         return m_queue.empty();
      43             :     }
      44             : 
      45      227576 :     size_t size() const
      46             :     {
      47      455152 :         std::lock_guard<std::mutex> lock(m_mutex);
      48      455152 :         return m_queue.size();
      49             :     }
      50             : 
      51          12 :     void push(const T &value)
      52             :     {
      53          24 :         std::lock_guard<std::mutex> lock(m_mutex);
      54          12 :         m_queue.push(value);
      55          12 :         m_cv.notify_one();
      56          12 :     }
      57             : 
      58        1046 :     void push(T &&value)
      59             :     {
      60        2092 :         std::lock_guard<std::mutex> lock(m_mutex);
      61        1046 :         m_queue.push(std::move(value));
      62        1046 :         m_cv.notify_one();
      63        1046 :     }
      64             : 
      65         885 :     T get_and_pop_front()
      66             :     {
      67        1769 :         std::unique_lock<std::mutex> lock(m_mutex);
      68        1104 :         while (m_queue.empty())
      69             :         {
      70         219 :             m_cv.wait(lock);
      71             :         }
      72         885 :         T val = m_queue.front();
      73         885 :         m_queue.pop();
      74        1770 :         return val;
      75             :     }
      76             : };
      77             : 
      78             : }  // namespace cpl
      79             : 
      80             : #endif  // CPL_THREADSAFE_QUEUE_INCLUDED

Generated by: LCOV version 1.14