// Copyright 2016 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef V8_BASE_RING_BUFFER_H_ #define V8_BASE_RING_BUFFER_H_ #include "src/base/macros.h" namespace v8 { namespace base { template <typename T> class RingBuffer { public: RingBuffer() { Reset(); } RingBuffer(const RingBuffer&) = delete; RingBuffer& operator=(const RingBuffer&) = delete; static const int kSize = 10; void Push(const T& value) { if (count_ == kSize) { elements_[start_++] = value; if (start_ == kSize) start_ = 0; } else { DCHECK_EQ(start_, 0); elements_[count_++] = value; } } int Count() const { return count_; } template <typename Callback> T Sum(Callback callback, const T& initial) const { int j = start_ + count_ - 1; if (j >= kSize) j -= kSize; T result = initial; for (int i = 0; i < count_; i++) { result = callback(result, elements_[j]); if (--j == -1) j += kSize; } return result; } void Reset() { start_ = count_ = 0; } private: T elements_[kSize]; int start_; int count_; }; } // namespace base } // namespace v8 #endif // V8_BASE_RING_BUFFER_H_