2014-03-26 Richard Biener <rguenther@suse.de>
[official-gcc.git] / libsanitizer / tsan / tsan_vector.h
blob4da8b83d5c3ff191d114a8e7ad751aab336af1b0
1 //===-- tsan_vector.h -------------------------------------------*- C++ -*-===//
2 //
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
5 //
6 //===----------------------------------------------------------------------===//
7 //
8 // This file is a part of ThreadSanitizer (TSan), a race detector.
9 //
10 //===----------------------------------------------------------------------===//
12 // Low-fat STL-like vector container.
14 #ifndef TSAN_VECTOR_H
15 #define TSAN_VECTOR_H
17 #include "tsan_defs.h"
18 #include "tsan_mman.h"
20 namespace __tsan {
22 template<typename T>
23 class Vector {
24 public:
25 explicit Vector(MBlockType typ)
26 : typ_(typ)
27 , begin_()
28 , end_()
29 , last_() {
32 ~Vector() {
33 if (begin_)
34 internal_free(begin_);
37 void Reset() {
38 if (begin_)
39 internal_free(begin_);
40 begin_ = 0;
41 end_ = 0;
42 last_ = 0;
45 uptr Size() const {
46 return end_ - begin_;
49 T &operator[](uptr i) {
50 DCHECK_LT(i, end_ - begin_);
51 return begin_[i];
54 const T &operator[](uptr i) const {
55 DCHECK_LT(i, end_ - begin_);
56 return begin_[i];
59 T *PushBack(T v = T()) {
60 EnsureSize(Size() + 1);
61 end_[-1] = v;
62 return &end_[-1];
65 void PopBack() {
66 DCHECK_GT(end_, begin_);
67 end_--;
70 void Resize(uptr size) {
71 uptr old_size = Size();
72 EnsureSize(size);
73 if (old_size < size) {
74 for (uptr i = old_size; i < size; i++)
75 begin_[i] = T();
79 private:
80 const MBlockType typ_;
81 T *begin_;
82 T *end_;
83 T *last_;
85 void EnsureSize(uptr size) {
86 if (size <= Size())
87 return;
88 if (size <= (uptr)(last_ - begin_)) {
89 end_ = begin_ + size;
90 return;
92 uptr cap0 = last_ - begin_;
93 uptr cap = 2 * cap0;
94 if (cap == 0)
95 cap = 16;
96 if (cap < size)
97 cap = size;
98 T *p = (T*)internal_alloc(typ_, cap * sizeof(T));
99 if (cap0) {
100 internal_memcpy(p, begin_, cap0 * sizeof(T));
101 internal_free(begin_);
103 begin_ = p;
104 end_ = begin_ + size;
105 last_ = begin_ + cap;
108 Vector(const Vector&);
109 void operator=(const Vector&);
111 } // namespace __tsan
113 #endif // #ifndef TSAN_VECTOR_H