OLD | NEW |
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #ifndef VM_RING_BUFFER_H_ | 5 #ifndef VM_RING_BUFFER_H_ |
6 #define VM_RING_BUFFER_H_ | 6 #define VM_RING_BUFFER_H_ |
7 | 7 |
8 #include "platform/assert.h" | 8 #include "platform/assert.h" |
9 #include "platform/utils.h" | 9 #include "platform/utils.h" |
10 | 10 |
(...skipping 13 matching lines...) Expand all Loading... |
24 const T& Get(int i) const { | 24 const T& Get(int i) const { |
25 ASSERT(0 <= i && i < Size()); | 25 ASSERT(0 <= i && i < Size()); |
26 return data_[(count_ - i - 1) & kMask]; | 26 return data_[(count_ - i - 1) & kMask]; |
27 } | 27 } |
28 | 28 |
29 // Returns the number of elements currently stored in this buffer (at most N). | 29 // Returns the number of elements currently stored in this buffer (at most N). |
30 int Size() const { return Utils::Minimum(count_, static_cast<int64_t>(N)); } | 30 int Size() const { return Utils::Minimum(count_, static_cast<int64_t>(N)); } |
31 | 31 |
32 private: | 32 private: |
33 static const int kMask = N - 1; | 33 static const int kMask = N - 1; |
34 COMPILE_ASSERT((N & kMask) == 0, N_must_be_power_of_two); | 34 COMPILE_ASSERT((N & kMask) == 0); |
35 T data_[N]; | 35 T data_[N]; |
36 int64_t count_; | 36 int64_t count_; |
37 }; | 37 }; |
38 | 38 |
39 } // namespace dart | 39 } // namespace dart |
40 | 40 |
41 #endif // VM_RING_BUFFER_H_ | 41 #endif // VM_RING_BUFFER_H_ |
OLD | NEW |