aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/clickhouse/src/Processors/RowsBeforeLimitCounter.h
blob: f5eb40ff84a50c8155a374418c1061e4ba4c3859 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#pragma once
#include <atomic>
#include <memory>

namespace DB
{

/// This class helps to calculate rows_before_limit_at_least.
class RowsBeforeLimitCounter
{
public:
    void add(uint64_t rows)
    {
        setAppliedLimit();
        rows_before_limit.fetch_add(rows, std::memory_order_release);
    }

    void set(uint64_t rows)
    {
        setAppliedLimit();
        rows_before_limit.store(rows, std::memory_order_release);
    }

    uint64_t get() const { return rows_before_limit.load(std::memory_order_acquire); }

    void setAppliedLimit() { has_applied_limit.store(true, std::memory_order_release); }
    bool hasAppliedLimit() const { return has_applied_limit.load(std::memory_order_acquire); }

private:
    std::atomic<uint64_t> rows_before_limit = 0;
    std::atomic_bool has_applied_limit = false;
};

using RowsBeforeLimitCounterPtr = std::shared_ptr<RowsBeforeLimitCounter>;

}