Home | History | Annotate | Download | only in support
      1 //===----------------------------------------------------------------------===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is dual licensed under the MIT and the University of Illinois Open
      6 // Source Licenses. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 
     10 #ifndef NASTY_VECTOR_H
     11 #define NASTY_VECTOR_H
     12 
     13 #include <vector>
     14 #include <list>
     15 
     16 template <class T>
     17 class nasty_vector
     18 {
     19 public:
     20     typedef typename std::vector<T>                           nested_container;
     21     typedef typename nested_container::value_type             value_type;
     22     typedef typename nested_container::reference              reference;
     23     typedef typename nested_container::const_reference        const_reference;
     24     typedef typename nested_container::iterator               iterator;
     25     typedef typename nested_container::const_iterator         const_iterator;
     26 
     27     typedef typename nested_container::size_type              size_type;
     28     typedef typename nested_container::difference_type        difference_type;
     29     typedef typename nested_container::pointer                pointer;
     30     typedef typename nested_container::const_pointer          const_pointer;
     31 
     32     typedef typename nested_container::reverse_iterator       reverse_iterator;
     33     typedef typename nested_container::const_reverse_iterator const_reverse_iterator;
     34 
     35     nasty_vector() : v_() {}
     36     explicit nasty_vector(size_type n) : v_(n) {}
     37     nasty_vector(size_type n, const value_type& value) : v_(n, value) {}
     38     template <class InputIterator> nasty_vector(InputIterator first, InputIterator last) : v_(first, last) {}
     39 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
     40     nasty_vector(std::initializer_list<value_type> il) : v_(il) {}
     41 #endif
     42     ~nasty_vector() {}
     43 
     44     template <class InputIterator>
     45         void assign(InputIterator first, InputIterator last) { v_.assign(first, last); }
     46     void assign(size_type n, const value_type& u) { v_.assign(n, u); }
     47 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
     48     void assign(std::initializer_list<value_type> il)  { v_.assign(il); }
     49 #endif
     50 
     51     iterator               begin() _NOEXCEPT         { return v_.begin(); }
     52     const_iterator         begin()   const _NOEXCEPT { return v_.begin(); }
     53     iterator               end() _NOEXCEPT           { return v_.end(); }
     54     const_iterator         end()     const _NOEXCEPT { return v_.end(); }
     55 
     56     reverse_iterator       rbegin() _NOEXCEPT        { return v_.rbegin(); }
     57     const_reverse_iterator rbegin()  const _NOEXCEPT { return v_.rbegin(); }
     58     reverse_iterator       rend() _NOEXCEPT          { return v_.rend(); }
     59     const_reverse_iterator rend()    const _NOEXCEPT { return v_.rend(); }
     60 
     61     const_iterator         cbegin()  const _NOEXCEPT { return v_.cbegin(); }
     62     const_iterator         cend()    const _NOEXCEPT { return v_.cend(); }
     63     const_reverse_iterator crbegin() const _NOEXCEPT { return v_.crbegin(); }
     64     const_reverse_iterator crend()   const _NOEXCEPT { return v_.crend(); }
     65 
     66     size_type size() const _NOEXCEPT      { return v_.size(); }
     67     size_type max_size() const _NOEXCEPT  { return v_.max_size(); }
     68     size_type capacity() const _NOEXCEPT  { return v_.capacity(); }
     69     bool empty() const _NOEXCEPT          { return v_.empty(); }
     70     void reserve(size_type n)             { v_.reserve(n); };
     71     void shrink_to_fit() _NOEXCEPT        { v_.shrink_to_fit(); }
     72 
     73     reference       operator[](size_type n)       { return v_[n]; }
     74     const_reference operator[](size_type n) const { return v_[n]; }
     75     reference       at(size_type n)               { return v_.at(n); }
     76     const_reference at(size_type n) const         { return v_.at(n); }
     77 
     78     reference       front()       { return v_.front(); }
     79     const_reference front() const { return v_.front(); }
     80     reference       back()        { return v_.back(); }
     81     const_reference back() const  { return v_.back(); }
     82 
     83     value_type*       data() _NOEXCEPT       { return v_.data(); }
     84     const value_type* data() const _NOEXCEPT { return v_.data(); }
     85 
     86     void push_back(const value_type& x)     { v_.push_back(x); }
     87 #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
     88     void push_back(value_type&& x)          { v_.push_back(std::forward<value_type&&>(x)); }
     89 #ifndef _LIBCPP_HAS_NO_VARIADICS
     90     template <class... Args>
     91         void emplace_back(Args&&... args)   { v_.emplace_back(std::forward<Args>(args)...); }
     92 #endif
     93 #endif
     94     void pop_back()                         { v_.pop_back(); }
     95 
     96 #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
     97 #ifndef _LIBCPP_HAS_NO_VARIADICS
     98     template <class... Args> iterator emplace(const_iterator pos, Args&&... args)
     99     { return v_.emplace(pos, std::forward<Args>(args)...); }
    100 #endif
    101 #endif
    102 
    103     iterator insert(const_iterator pos, const value_type& x) { return v_.insert(pos, x); }
    104 #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
    105     iterator insert(const_iterator pos, value_type&& x)      { return v_.insert(pos, std::forward<value_type>(x)); }
    106 #endif
    107     iterator insert(const_iterator pos, size_type n, const value_type& x) { return v_.insert(pos, n, x); }
    108     template <class InputIterator>
    109         iterator insert(const_iterator pos, InputIterator first, InputIterator last)
    110     { return v_.insert(pos, first, last); }
    111 
    112 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
    113     iterator insert(const_iterator pos, std::initializer_list<value_type> il) { return v_.insert(pos, il); }
    114 #endif
    115 
    116     iterator erase(const_iterator pos)                        { return v_.erase(pos); }
    117     iterator erase(const_iterator first, const_iterator last) { return v_.erase(first, last); }
    118 
    119     void clear() _NOEXCEPT { v_.clear(); }
    120 
    121     void resize(size_type sz)                      { v_.resize(sz); }
    122     void resize(size_type sz, const value_type& c) { v_.resize(sz, c); }
    123 
    124     void swap(nasty_vector &nv) _NOEXCEPT_(std::__is_nothrow_swappable<nested_container>::value)
    125     { v_.swap(nv.v_); }
    126 
    127     nasty_vector *operator &()             { return nullptr; }  // nasty
    128     const nasty_vector *operator &() const { return nullptr; }  // nasty
    129 
    130     nested_container v_;
    131 };
    132 
    133 template <class T>
    134 bool operator==(const nasty_vector<T>& x, const nasty_vector<T>& y) { return x.v_ == y.v_; }
    135 
    136 template <class T>
    137 class nasty_list
    138 {
    139 public:
    140 
    141     typedef typename std::list<T>                             nested_container;
    142     typedef typename nested_container::value_type             value_type;
    143     typedef typename nested_container::reference              reference;
    144     typedef typename nested_container::const_reference        const_reference;
    145     typedef typename nested_container::iterator               iterator;
    146     typedef typename nested_container::const_iterator         const_iterator;
    147 
    148     typedef typename nested_container::size_type              size_type;
    149     typedef typename nested_container::difference_type        difference_type;
    150     typedef typename nested_container::pointer                pointer;
    151     typedef typename nested_container::const_pointer          const_pointer;
    152 
    153     typedef typename nested_container::reverse_iterator       reverse_iterator;
    154     typedef typename nested_container::const_reverse_iterator const_reverse_iterator;
    155 
    156     nasty_list() : l_() {}
    157     explicit nasty_list(size_type n)  : l_(n) {}
    158     nasty_list(size_type n, const value_type& value)  : l_(n,value) {}
    159     template <class Iter>
    160         nasty_list(Iter first, Iter last)  : l_(first, last) {}
    161 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
    162     nasty_list(std::initializer_list<value_type> il) : l_(il) {}
    163 #endif
    164 
    165     ~nasty_list() {}
    166 
    167 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
    168     nasty_list& operator=(std::initializer_list<value_type> il) { l_ = il; return *this; }
    169 #endif
    170     template <class Iter>
    171         void assign(Iter first, Iter last) { l_.assign(first, last); }
    172     void assign(size_type n, const value_type& t) { l_.assign(n, t); }
    173 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
    174     void assign(std::initializer_list<value_type> il) { l_.assign(il); }
    175 #endif
    176 
    177 
    178     iterator               begin() _NOEXCEPT         { return l_.begin(); }
    179     const_iterator         begin()   const _NOEXCEPT { return l_.begin(); }
    180     iterator               end() _NOEXCEPT           { return l_.end(); }
    181     const_iterator         end()     const _NOEXCEPT { return l_.end(); }
    182 
    183     reverse_iterator       rbegin() _NOEXCEPT        { return l_.rbegin(); }
    184     const_reverse_iterator rbegin()  const _NOEXCEPT { return l_.rbegin(); }
    185     reverse_iterator       rend() _NOEXCEPT          { return l_.rend(); }
    186     const_reverse_iterator rend()    const _NOEXCEPT { return l_.rend(); }
    187 
    188     const_iterator         cbegin()  const _NOEXCEPT { return l_.cbegin(); }
    189     const_iterator         cend()    const _NOEXCEPT { return l_.cend(); }
    190     const_reverse_iterator crbegin() const _NOEXCEPT { return l_.crbegin(); }
    191     const_reverse_iterator crend()   const _NOEXCEPT { return l_.crend(); }
    192 
    193     reference       front()       { return l_.front(); }
    194     const_reference front() const { return l_.front(); }
    195     reference       back()        { return l_.back(); }
    196     const_reference back() const  { return l_.back(); }
    197 
    198     size_type size() const _NOEXCEPT      { return l_.size(); }
    199     size_type max_size() const _NOEXCEPT  { return l_.max_size(); }
    200     bool empty() const _NOEXCEPT          { return l_.empty(); }
    201 
    202     void push_front(const value_type& x)    { l_.push_front(x); }
    203     void push_back(const value_type& x)     { l_.push_back(x); }
    204 #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
    205     void push_back(value_type&& x)          { l_.push_back(std::forward<value_type&&>(x)); }
    206     void push_front(value_type&& x)         { l_.push_back(std::forward<value_type&&>(x)); }
    207 #ifndef _LIBCPP_HAS_NO_VARIADICS
    208     template <class... Args>
    209         void emplace_back(Args&&... args)   { l_.emplace_back(std::forward<Args>(args)...); }
    210     template <class... Args>
    211         void emplace_front(Args&&... args)  { l_.emplace_front(std::forward<Args>(args)...); }
    212 #endif
    213 #endif
    214     void pop_front()                        { l_.pop_front(); }
    215     void pop_back()                         { l_.pop_back(); }
    216 
    217 #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
    218 #ifndef _LIBCPP_HAS_NO_VARIADICS
    219     template <class... Args> iterator emplace(const_iterator pos, Args&&... args)
    220     { return l_.emplace(pos, std::forward<Args>(args)...); }
    221 #endif
    222 #endif
    223 
    224     iterator insert(const_iterator pos, const value_type& x) { return l_.insert(pos, x); }
    225 #ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
    226     iterator insert(const_iterator pos, value_type&& x)      { return l_.insert(pos, std::forward<value_type>(x)); }
    227 #endif
    228     iterator insert(const_iterator pos, size_type n, const value_type& x) { return l_.insert(pos, n, x); }
    229     template <class InputIterator>
    230         iterator insert(const_iterator pos, InputIterator first, InputIterator last)
    231     { return l_.insert(pos, first, last); }
    232 
    233 #ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
    234     iterator insert(const_iterator pos, std::initializer_list<value_type> il) { return l_.insert(pos, il); }
    235 #endif
    236 
    237     iterator erase(const_iterator pos)                      { return l_.erase(pos); }
    238     iterator erase(const_iterator pos, const_iterator last) { return l_.erase(pos, last); }
    239 
    240     void resize(size_type sz)                      { l_.resize(); }
    241     void resize(size_type sz, const value_type& c) { l_.resize(c); }
    242 
    243     void swap(nasty_list &nl) _NOEXCEPT_(std::__is_nothrow_swappable<nested_container>::value)
    244     { l_.swap(nl.l_); }
    245 
    246     void clear() _NOEXCEPT { l_.clear(); }
    247 
    248 //     void splice(const_iterator position, list& x);
    249 //     void splice(const_iterator position, list&& x);
    250 //     void splice(const_iterator position, list& x, const_iterator i);
    251 //     void splice(const_iterator position, list&& x, const_iterator i);
    252 //     void splice(const_iterator position, list& x, const_iterator first,
    253 //                                                   const_iterator last);
    254 //     void splice(const_iterator position, list&& x, const_iterator first,
    255 //                                                   const_iterator last);
    256 //
    257 //     void remove(const value_type& value);
    258 //     template <class Pred> void remove_if(Pred pred);
    259 //     void unique();
    260 //     template <class BinaryPredicate>
    261 //         void unique(BinaryPredicate binary_pred);
    262 //     void merge(list& x);
    263 //     void merge(list&& x);
    264 //     template <class Compare>
    265 //         void merge(list& x, Compare comp);
    266 //     template <class Compare>
    267 //         void merge(list&& x, Compare comp);
    268 //     void sort();
    269 //     template <class Compare>
    270 //         void sort(Compare comp);
    271 //     void reverse() noexcept;
    272 
    273     nasty_list *operator &()             { return nullptr; }  // nasty
    274     const nasty_list *operator &() const { return nullptr; }  // nasty
    275 
    276     nested_container l_;
    277 };
    278 
    279 template <class T>
    280 bool operator==(const nasty_list<T>& x, const nasty_list<T>& y) { return x.l_ == y.l_; }
    281 
    282 #endif
    283