xtd 0.2.0
Loading...
Searching...
No Matches
list.h
Go to the documentation of this file.
1
4#pragma once
5#include "helpers/allocator.h"
6#include "ilist.h"
7#include "params.h"
8#include "../object_model/read_only_collection.h"
9#include "../../argument_exception.h"
10#include "../../index_out_of_range_exception.h"
11#include "../../box_integer.h"
12#include "../../invalid_operation_exception.h"
13#include "../../intptr.h"
14#include "../../is.h"
15#include "../../literals.h"
16#include "../../object.h"
17#include "../../new_ptr.h"
18#include "../../ptr.h"
19#include "../../string.h"
20#include <utility>
21#include <vector>
22
24namespace xtd {
26 namespace collections {
28 namespace generic {
70 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
71 class list : public xtd::object, public xtd::collections::generic::ilist<type_t>, public xtd::iequatable<xtd::collections::generic::list<type_t, allocator_t>> {
72 public:
74
77 using value_type = type_t;
81 using base_type = typename std::vector<typename std::conditional<std::is_same<bool, value_type>::value, xtd::byte, value_type>::type, allocator_type>;
93 using const_pointer = const value_type*;
99 using reverse_iterator = typename base_type::reverse_iterator;
101 using const_reverse_iterator = typename base_type::const_reverse_iterator;
105
107
112
114
125 list() noexcept = default;
126
129 explicit list(const allocator_type& alloc) noexcept : data_(xtd::new_ptr<struct data>(alloc)) {}
134 list(size_type count, const type_t& value, const allocator_type& alloc = allocator_type()) : data_(xtd::new_ptr<struct data>(count, value, alloc)) {}
138 explicit list(size_type count, const allocator_type& alloc = allocator_type()) : data_(xtd::new_ptr<struct data>(count, alloc)) {}
143 template<typename input_iterator_t>
144 list(input_iterator_t first, input_iterator_t last, const allocator_type& alloc = allocator_type()) : data_(xtd::new_ptr<struct data>(first, last, alloc)) {}
153 list(const xtd::collections::generic::ienumerable<type_t>& collection, const allocator_type& alloc = allocator_type()) : data_(xtd::new_ptr<struct data>(collection, alloc)) {}
154
157 list(const list& list) : data_(xtd::new_ptr<struct data>(list)) {}
160 list(const base_type& list) : data_(xtd::new_ptr<struct data>(list)) {}
164 list(const list& list, const allocator_type& alloc) : data_(xtd::new_ptr<struct data>(list, alloc)) {}
168 list(const base_type& list, const allocator_type& alloc) : data_(xtd::new_ptr<struct data>(list, alloc)) {}
172 list(std::initializer_list<type_t> items, const allocator_type& alloc = allocator_type()) : data_(xtd::new_ptr<struct data>(items, alloc)) {}
173
176 list(list&& other) : data_(xtd::new_ptr<struct data>(std::move(other))) {other.data_ = xtd::new_ptr<struct data>();}
179 list(base_type&& other) : data_(xtd::new_ptr<struct data>(std::move(other))) {other.clear();}
183 list(list&& other, const allocator_type& alloc) : data_(xtd::new_ptr<struct data>(std::move(other)), alloc) {other.data_ = xtd::new_ptr<struct data>();}
187 list(base_type&& other, const allocator_type& alloc) : data_(xtd::new_ptr<struct data>(std::move(other), alloc)) {other.items.clear();}
189
191
196 virtual reference back() {return at(count() - 1);}
200 virtual const_reference back() const {return at(count() - 1);}
201
204 const_iterator begin() const noexcept override {return ienumerable<value_type>::begin();}
207 iterator begin() noexcept override {return ienumerable<value_type>::begin();}
208
231 virtual size_type capacity() const noexcept {return data_->items.capacity();}
254 virtual void capacity(size_type value) {
255 if (value < count()) throw argument_out_of_range_exception {csf_};
256 reserve(value);
257 }
258
261 const_iterator cbegin() const noexcept override {return ienumerable<value_type>::cbegin();}
262
265 const_iterator cend() const noexcept override {return ienumerable<value_type>::cend();}
266
288 size_type count() const noexcept override {return size();}
289
293 virtual const_reverse_iterator crbegin() const noexcept {return data_->items.crbegin();}
294
298 virtual const_reverse_iterator crend() const noexcept {return data_->items.crend();}
299
303 virtual pointer data() noexcept {return reinterpret_cast<pointer>(data_->items.data());}
307 virtual const_pointer data() const noexcept {return reinterpret_cast<const_pointer>(data_->items.data());}
308
311 virtual bool empty() const noexcept {return data_->items.empty();}
312
315 const_iterator end() const noexcept override {return ienumerable<value_type>::end();}
318 iterator end() noexcept override {return ienumerable<value_type>::end();}
319
323 virtual reference front() {return at(0);}
327 virtual const_reference front() const {return at(0);}
328
329 bool is_fixed_size() const noexcept override {return false;}
330 bool is_read_only() const noexcept override {return false;}
331 bool is_synchronized() const noexcept override {return false;}
332
335 virtual const base_type& items() const noexcept {return data_->items;}
338 virtual base_type& items() noexcept {return data_->items;}
339
342 virtual size_type max_size() const noexcept {return data_->items.max_size();}
343
347 virtual reverse_iterator rbegin() noexcept {return data_->items.rbegin();}
351 virtual const_reverse_iterator rbegin() const noexcept {return data_->items.rbegin();}
352
356 virtual reverse_iterator rend() noexcept {return data_->items.rend();}
360 virtual const_reverse_iterator rend() const noexcept {return data_->items.rend();}
361
364 virtual size_type size() const noexcept {return data_->items.size();}
365
366 const xtd::object& sync_root() const noexcept override {return data_->sync_root;}
368
370
385 void add(const type_t& item) override {push_back(item);}
386
396
405 void add_range(std::initializer_list<type_t> il) {insert_range(count(), il);}
406
408 template<typename enumerable_t>
409 void add_range(const enumerable_t& enumerable) {insert_range(count(), enumerable);}
411
415 void assign(size_type count, const type_t& value) {
416 ++data_->version;
417 data_->items.assign(count, value);
418 }
419
424 template<typename input_iterator_t>
425 void assign(input_iterator_t first, input_iterator_t last) {
426 ++data_->version;
427 data_->items.assign(first, last);
428 }
429
435 auto read_only_list = new_ptr<list<value_type>>();
436 read_only_list->data_ = data_;
437 return read_only_collection {read_only_list};
438 }
439
442 virtual void assign(std::initializer_list<type_t> items) {
443 clear();
444 for (auto item : items)
445 push_back(item);
446 }
447
452 virtual reference at(size_type index) {
453 if (index >= count()) throw index_out_of_range_exception {csf_};
454 return reinterpret_cast<reference>(data_->items.at(index));
455 }
460 virtual const_reference at(size_type index) const {
461 if (index >= count()) throw index_out_of_range_exception {csf_};
462 return reinterpret_cast<const_reference>(data_->items.at(index));
463 }
464
465 void clear() override {
466 ++data_->version;
467 data_->items.clear();
468 }
469
470 bool contains(const type_t& value) const noexcept override {
471 for (const type_t& item : data_->items)
472 if (item == value) return true;
473 return false;
474 }
475
486 virtual void copy_to(xtd::array<type_t>& array) const {copy_to(0, array, 0, count());}
487
488 void copy_to(xtd::array<type_t>& array, size_type array_index) const override {copy_to(0, array, array_index, count());}
489
504 virtual void copy_to(size_type index, xtd::array<type_t>& array, size_type array_index, size_type count) const {
505 if (index + count > this->count() || array_index + count > array.size()) throw xtd::argument_exception {csf_};
506 auto i = size_type {0}, c = size_type {0};
507 for (const type_t& item : *this) {
508 if (i >= index + count) return;
509 if (i >= index) {
510 array[array_index + c] = item;
511 c += 1;
512 }
513 i += 1;
514 }
515 }
516
523 template<typename... args_t>
524 iterator emplace(const_iterator pos, args_t&&... args) {
525 ++data_->version;
526 return data_->items.eplace(std::forward<args_t>(args)...);
527 }
528
533 template<typename... args_t>
534 reference emplace_back(args_t&&... args) {
535 ++data_->version;
536 return data_->items.emplace_back(std::forward<args_t>(args)...);
537 }
538
539 bool equals(const object& obj) const noexcept override {return is<list<value_type>>(obj) && equals(static_cast<const list<value_type>&>(obj));}
540 bool equals(const list& rhs) const noexcept override {return data_->items == rhs.data_->items && data_->version == rhs.data_->version;}
541
550 ++data_->version;
551 return to_iterator(data_->items.erase(to_base_type_iterator(pos)));
552 }
562 ++data_->version;
563 return to_iterator(data_->items.erase(to_base_type_iterator(first), to_base_type_iterator(last)));
564 }
565
568 virtual allocator_type get_allocator() const {return data_->items.get_allocator();}
569
573 virtual base_type& get_base_type() noexcept {return data_->items;}
576 virtual const base_type& get_base_type() const noexcept {return data_->items;}
577
578 enumerator<value_type> get_enumerator() const noexcept override {
579 class list_enumerator : public ienumerator<value_type> {
580 public:
581 explicit list_enumerator(const list& items, size_type version) : items_(items), version_(version) {}
582
583 const value_type& current() const override {
584 if (version_ != items_.data_->version) throw xtd::invalid_operation_exception {"Collection was modified; enumeration operation may not execute.", csf_};
585 return items_.at(index_);
586 }
587
588 bool move_next() override {
589 if (version_ != items_.data_->version) throw xtd::invalid_operation_exception {"Collection was modified; enumeration operation may not execute.", csf_};
590 return ++index_ < items_.count();
591 }
592
593 void reset() override {
594 version_ = items_.data_->version;
595 index_ = list::npos;
596 }
597
598 protected:
599 const list& items_;
600 size_type index_ = list::npos;
601 size_type version_ = 0;
602 };
603 return {new_ptr<list_enumerator>(*this, data_->version)};
604 }
605
619 if (index + count > this->count()) throw xtd::argument_exception {csf_};
620
621 return list<type_t> {begin() + index, begin() + index + count};
622 }
623
627 size_type index_of(const type_t& value) const noexcept override {
628 if (count() == 0) return npos;
629 return index_of(value, 0, count());
630 }
631
637 virtual size_type index_of(const type_t& value, size_type index) const {return index_of(value, index, count() - index);}
638
645 virtual size_type index_of(const type_t& value, size_type index, size_type count) const {
646 if (index >= this->count()) throw xtd::argument_out_of_range_exception {csf_};
647 if (index + count > this->count()) throw xtd::argument_out_of_range_exception {csf_};
648
649 for (auto i = index; i < index + count; ++i)
650 if (at(i) == value) return i;
651 return npos;
652 }
653
660 virtual iterator insert(const_iterator pos, const type_t& value) {
661 ++data_->version;
662 return to_iterator(data_->items.insert(to_base_type_iterator(pos), value));
663 }
670 virtual iterator insert(const_iterator pos, const type_t&& value) {
671 ++data_->version;
672 return to_iterator(data_->items.insert(to_base_type_iterator(pos), value));
673 }
681 virtual iterator insert(const_iterator pos, size_type count, const type_t& value) {
682 ++data_->version;
683 return to_iterator(data_->items.insert(to_base_type_iterator(pos), count, value));
684 }
692 template<typename input_iterator_t>
693 iterator insert(const_iterator pos, input_iterator_t first, input_iterator_t last) {
694 ++data_->version;
695 return to_iterator(data_->items.insert(to_base_type_iterator(pos), first, last));
696 }
703 virtual iterator insert(const_iterator pos, const std::initializer_list<type_t>& items) {
704 ++data_->version;
705 return to_iterator(data_->items.insert(to_base_type_iterator(pos), items.begin(), items.end()));
706 }
707
713 void insert(size_type index, const type_t& value) override {
714 if (index > count()) throw xtd::argument_out_of_range_exception {csf_};
715 insert(begin() + index, value);
716 }
717
728 if (index > count()) throw xtd::argument_out_of_range_exception {csf_};
729
730 // If the collection is this instance, it must be copied to avoid an infinite loop.
731 if (reinterpret_cast<xtd::intptr>(&enumerable) == reinterpret_cast<xtd::intptr>(this)) {
732 auto items = list<type_t>(enumerable.begin(), enumerable.end());
733 insert(begin() + index, items.begin(), items.end());
734 return;
735 }
736
737 insert(begin() + index, enumerable.begin(), enumerable.end());
738 }
739
749 virtual void insert_range(size_type index, const std::initializer_list<type_t>& items) {
750 if (index > count()) throw xtd::argument_out_of_range_exception {csf_};
751 insert(begin() + index, items);
752 }
753
755 template<typename ienumerable_t>
756 void insert_range(size_type index, const ienumerable_t& enumerable) {
757 if (index > count()) throw xtd::argument_out_of_range_exception {csf_};
758
759 // If the collection is this instance, it must be copied to avoid an infinite loop.
760 if (reinterpret_cast<xtd::intptr>(&enumerable) == reinterpret_cast<xtd::intptr>(this)) {
761 auto items = list<type_t>(enumerable.begin(), enumerable.end());
762 insert(begin() + index, items.begin(), items.end());
763 return;
764 }
765
766 insert(begin() + index, enumerable.begin(), enumerable.end());
767 }
769
773 virtual void pop_back() {
774 ++data_->version;
775 data_->items.pop_back();
776 }
777
782 virtual void push_back(const type_t& value) {
783 ++data_->version;
784 data_->items.push_back(value);
785 }
790 virtual void push_back(type_t&& value) {
791 ++data_->version;
792 data_->items.push_back(value);
793 }
794
795 bool remove(const type_t& item) override {
796 if (count() == 0) return false;
797 for (auto index = size_type {0}; index < count(); ++index) {
798 if (at(index) != item) continue;
799 remove_at(index);
800 return true;
801 }
802 return false;
803 }
804
808 void remove_at(size_type index) override {
809 if (index >= count()) throw xtd::argument_out_of_range_exception {csf_};
810
811 if (index == count() - 1) pop_back();
812 else erase(begin() + index);
813 }
814
823 virtual void remove_range(size_type index, size_type count) {
824 if (index + count >= this->count()) throw xtd::argument_out_of_range_exception {csf_};
825
826 erase(begin() + index, begin() + index + count);
827 }
828
834 virtual void reserve(size_type new_cap) {data_->items.reserve(new_cap);}
835
840 virtual void resize(size_type count) {
841 if (count == size()) return;
842 ++data_->version;
843 data_->items.resize(count);
844 }
850 virtual void resize(size_type count, const value_type& value) {
851 ++data_->version;
852 data_->items.resize(count, value);
853 }
854
858 virtual void shrink_to_fit() {data_->items.shrink_to_fit();}
859
862 virtual void swap(list& other) noexcept {
863 ++data_->version;
864 data_->items.swap(other.data_->items);
865 }
866
874 virtual xtd::array<value_type> to_array() const noexcept {return xtd::array<value_type>(begin(), end());}
875
876 string to_string() const noexcept override {return xtd::string::format("[{}]", xtd::string::join(", ", *this));}
877
898 virtual void trim_excess() {shrink_to_fit();}
900
902
907 list& operator =(const list& other) = default;
911 list& operator =(list&& other) noexcept {
912 data_->version = std::move(other.data_->version);
913 data_->items = std::move(other.data_->items);
914 return *this;
915 }
919 list& operator =(std::initializer_list<type_t>& items) {
920 data_->version = 0;
921 data_->items = items;
922 return *this;
923 }
924
929 const_reference operator [](size_type index) const override {return at(index);}
934 reference operator [](size_type index) override {return at(index);}
935
938 virtual operator const base_type&() const noexcept {return data_->items;}
941 virtual operator base_type&() noexcept {return data_->items;}
943
944 private:
945 typename base_type::iterator to_base_type_iterator(iterator value) noexcept {
946 if (value == begin()) return data_->items.begin();
947 if (value == end()) return data_->items.end();
948 return data_->items.begin() + (value - begin());
949 }
950
951 iterator to_iterator(typename base_type::iterator value) noexcept {
952 if (value == data_->items.begin()) return begin();
953 if (value == data_->items.end()) return end();
954 return begin() + (value - data_->items.begin());
955 }
956
957 struct data {
958 data() = default;
959 explicit data(const allocator_type& alloc) noexcept : items(alloc) {}
960 data(size_type count, const type_t& value, const allocator_type& alloc = allocator_type()) : items(count, value, alloc) {}
961 explicit data(size_type count, const allocator_type& alloc = allocator_type()) : items(count, alloc) {}
962 template<typename input_iterator_t>
963 data(input_iterator_t first, input_iterator_t last, const allocator_type& alloc = allocator_type()) : items(first, last, alloc) {}
964 data(const xtd::collections::generic::ienumerable<type_t>& collection, const allocator_type& alloc = allocator_type()) : items(collection.begin(), collection.end(), alloc) {}
965 data(const list& list) : items(list.data_->items), version(list.data_->version) {}
966 data(const base_type& list) : items(list) {}
967 data(const list& list, const allocator_type& alloc) : items(list.data_->items, alloc), version(list.data_->version) {}
968 data(const base_type& list, const allocator_type& alloc) : items(list, alloc) {}
969 data(std::initializer_list<type_t> items, const allocator_type& alloc = allocator_type()) : items(items.begin(), items.end(), alloc) {}
970 data(list&& other) : items(std::move(other.data_->items)), version(std::move(other.data_->version)) {other.data_->items.clear(); other.data_->version = 0;}
971 data(base_type&& other) : items(std::move(other)) {other.clear();}
972 data(list&& other, const allocator_type& alloc) : items(other.data_->items, alloc), version{std::move(other.data_->version)} {other.data_->items.clear(); other.data_->version = 0;}
973 data(base_type&& other, const allocator_type& alloc) : items(std::move(other), alloc) {}
974
975 data(const data&) = default;
976 data& operator =(const data&) = default;
977
978 base_type items;
979 size_type version = 0;
980 xtd::object sync_root;
981 };
982
983 xtd::ptr<struct data> data_ = xtd::new_ptr<struct data>();
984 };
985
987 // C++17 deduction
988 // {
989 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
990 list(std::initializer_list<type_t>) -> list<type_t, allocator_t>;
991
992 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
993 list(const xtd::collections::generic::ienumerable<type_t>&) -> list<type_t, allocator_t>;
994
995 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
996 list(const xtd::collections::generic::ilist<type_t>&) -> list<type_t, allocator_t>;
997
998 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
999 list(const std::vector<type_t>&) -> list<type_t, allocator_t>;
1000
1001 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
1002 list(const list<type_t, allocator_t>&) -> list<type_t, allocator_t>;
1003
1004 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
1005 list(std::vector<type_t>&&) -> list<type_t, allocator_t>;
1006
1007 template<typename type_t, typename allocator_t = xtd::collections::generic::helpers::allocator<typename std::conditional<std::is_same<bool, type_t>::value, char, type_t>::type>>
1008 list(list<type_t, allocator_t>&&) -> list<type_t, allocator_t>;
1009 // }
1011 }
1012 }
1013}
Contains xtd::collections::generic::helpers::allocator alias.
The exception that is thrown when one of the arguments provided to a method is not valid.
Definition argument_exception.h:23
The exception that is thrown when one of the arguments provided to a method is out of range.
Definition argument_out_of_range_exception.h:22
static basic_string join(const basic_string separator, const collection_t &values) noexcept
Concatenates a specified separator basic_string between each element of a specified object array,...
Definition basic_string.h:2178
virtual const_iterator cend() const
Returns an iterator to the element following the last element of the enumarable.
Definition enumerable_iterators.h:209
virtual const_iterator cbegin() const
Returns an iterator to the first element of the enumarable.
Definition enumerable_iterators.h:205
virtual const_iterator end() const
Returns an iterator to the element following the last element of the enumarable.
Definition enumerable_iterators.h:213
virtual const_iterator begin() const
Returns an iterator to the first element of the enumarable.
Definition enumerable_iterators.h:198
Supports a simple iteration over a generic collection.
Definition enumerator.h:31
Exposes the enumerator, which supports a simple iteration over a collection of a specified type.
Definition ienumerable.h:35
Supports a simple iteration over a generic collection.
Definition ienumerator.h:58
typename icollection< type_t >::iterator iterator
Represents the iterator of xtd::collections::generic::ienumerable value type.
Definition ilist.h:47
typename icollection< type_t >::const_iterator const_iterator
Represents the const iterator of xtd::collections::generic::ienumerable value type.
Definition ilist.h:49
Represents a collection of objects that can be individually accessed by index.
Definition ilist.h:41
void insert(size_type index, const type_t &value) override
Inserts an element into the xtd::collections::generic::list <type_t> at the specified index.
Definition list.h:713
bool is_read_only() const noexcept override
Gets a value indicating whether the xtd::collections::generic::icollection <type_t> is read-only.
Definition list.h:330
virtual pointer data() noexcept
Returns pointer to the underlying array serving as element storage.
Definition list.h:303
virtual const base_type & items() const noexcept
Returns the underlying base type items.
Definition list.h:335
virtual void swap(list &other) noexcept
Exchanges the contents and capacity of the container with those of other. Does not invoke any move,...
Definition list.h:862
void add(const type_t &item) override
Adds an object to the end of the xtd::collections::generic::list <type_t>.
Definition list.h:385
virtual void push_back(type_t &&value)
Appends the given element value to the end of the container.
Definition list.h:790
virtual reference at(size_type index)
Returns a reference to the element at specified location pos, with bounds checking.
Definition list.h:452
list get_range(size_type index, size_type count)
Creates a shallow copy of a range of elements in the source xtd::collections::generic::list <type_t>.
Definition list.h:618
list(base_type &&other)
Move constructor with specified base type list.
Definition list.h:179
const_iterator begin() const noexcept override
Returns an iterator to the first element of the enumarable.
Definition list.h:204
virtual const_reference at(size_type index) const
Returns a reference to the element at specified location pos, with bounds checking.
Definition list.h:460
bool equals(const object &obj) const noexcept override
Determines whether the specified object is equal to the current object.
Definition list.h:539
virtual const_reverse_iterator crend() const noexcept
Returns a reverse iterator to the element following the last element of the reversed vector....
Definition list.h:298
virtual size_type max_size() const noexcept
Returns the maximum number of elements the container is able to hold due to system or library impleme...
Definition list.h:342
virtual void copy_to(size_type index, xtd::array< type_t > &array, size_type array_index, size_type count) const
Copies the entire xtd::collections::generic::list <type_t> to a compatible one-dimensional array,...
Definition list.h:504
virtual reference front()
Returns a reference to the first element in the container.
Definition list.h:323
const value_type * const_pointer
Represents the const pointer of list value type.
Definition list.h:93
const xtd::object & sync_root() const noexcept override
Gets an object that can be used to synchronize access to the the xtd::collections::generic::icollecti...
Definition list.h:366
static constexpr size_type npos
This is a special value equal to the maximum value representable by the type size_type.
Definition list.h:110
virtual void trim_excess()
Sets the capacity to the actual number of elements in the xtd::collections::generic::list <type_t>,...
Definition list.h:898
virtual xtd::array< value_type > to_array() const noexcept
Copies the elements of the xtd::collections::generic::list <type_t> to a new array.
Definition list.h:874
list(std::initializer_list< type_t > items, const allocator_type &alloc=allocator_type())
Constructs the container with the contents of the specified initializer list, and allocator.
Definition list.h:172
const_iterator end() const noexcept override
Returns an iterator to the element following the last element of the enumarable.
Definition list.h:315
virtual void insert_range(size_type index, const xtd::collections::generic::ienumerable< type_t > &enumerable)
Inserts copy of elements from a collection into the xtd::collections::generic::list <type_t> at the s...
Definition list.h:727
void remove_at(size_type index) override
Removes the element at the specified index of the xtd::collections::generic::list <type_t>.
Definition list.h:808
void assign(size_type count, const type_t &value)
Replaces the contents with count copies of value value.
Definition list.h:415
virtual reverse_iterator rend() noexcept
Returns a reverse iterator to the element following the last element of the reversed vector....
Definition list.h:356
const_reference operator[](size_type index) const override
Returns a reference to the element at specified location index.
Definition list.h:929
const_iterator cbegin() const noexcept override
Returns an iterator to the first element of the enumarable.
Definition list.h:261
virtual void pop_back()
Removes the last element of the container.
Definition list.h:773
void assign(input_iterator_t first, input_iterator_t last)
Replaces the contents with copies of those in the range [first, last).
Definition list.h:425
typename base_type::reverse_iterator reverse_iterator
Represents the reverse iterator of list value type.
Definition list.h:99
list(list &&other, const allocator_type &alloc)
Move constructor with specified list, and allocator.
Definition list.h:183
void copy_to(xtd::array< type_t > &array, size_type array_index) const override
Copies the elements of the xtd::collections::generic::icollection <type_t> to an xtd::array,...
Definition list.h:488
virtual void copy_to(xtd::array< type_t > &array) const
Copies the entire xtd::collections::generic::list <type_t> to a compatible one-dimensional array.
Definition list.h:486
list(input_iterator_t first, input_iterator_t last, const allocator_type &alloc=allocator_type())
Constructs the container with the contents of the range [first, last).
Definition list.h:144
typename std::vector< typename std::conditional< std::is_same< bool, value_type >::value, xtd::byte, value_type >::type, allocator_type > base_type
Represents the list base type.
Definition list.h:81
virtual const_pointer data() const noexcept
Returns pointer to the underlying array serving as element storage.
Definition list.h:307
void clear() override
Removes all items from the xtd::collections::generic::icollection <type_t>.
Definition list.h:465
virtual base_type & items() noexcept
Returns the underlying base type items.
Definition list.h:338
virtual bool empty() const noexcept
Checks if the container has no elements, i.e. whether xtd::collections::generic::list::begin() == xtd...
Definition list.h:311
string to_string() const noexcept override
Returns a xtd::string that represents the current object.
Definition list.h:876
virtual const_reference front() const
Returns a reference to the first element in the container.
Definition list.h:327
virtual base_type & get_base_type() noexcept
Returns the underlying base type.
Definition list.h:573
size_type index_of(const type_t &value) const noexcept override
Determines the index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.h:627
reference emplace_back(args_t &&... args)
Appends a new element to the end of the container. The element is constructed through std::allocator_...
Definition list.h:534
typename xtd::collections::generic::helpers::allocator< typename std::conditional< std::is_same< bool, value_type >::value, xtd::byte, value_type >::type > allocator_type
Represents the list allocator type.
Definition list.h:79
bool is_synchronized() const noexcept override
Gets a value indicating whether access to the xtd::collections::generic::icollection <type_t> is sync...
Definition list.h:331
list(const list &list)
Default copy constructor with specified list.
Definition list.h:157
xtd::ptrdiff difference_type
Represents the list difference type (usually xtd::ptrdiff).
Definition list.h:85
list(const xtd::collections::generic::ienumerable< type_t > &collection, const allocator_type &alloc=allocator_type())
Initializes a new instance of the xtd::collections::generic::list <type_t> class that contains elemen...
Definition list.h:153
list() noexcept=default
Initializes a new instance of the xtd::collections::generic::list class that is empty.
virtual const_reference back() const
Returns a reference to the last element in the container.
Definition list.h:200
list(const base_type &list, const allocator_type &alloc)
Default copy constructor with specified base type list, and allocator.
Definition list.h:168
virtual void shrink_to_fit()
Requests the removal of unused capacity.
Definition list.h:858
list(const list &list, const allocator_type &alloc)
Default copy constructor with specified list, and allocator.
Definition list.h:164
bool is_fixed_size() const noexcept override
Gets a value indicating whether the xtd::collections::generic::ilist <type_t> has a fixed size.
Definition list.h:329
xtd::size size_type
Represents the list size type (usually xtd::size).
Definition list.h:83
typename xtd::collections::object_model::read_only_collection< value_type > read_only_collection
Represents the read only collection of of list.
Definition list.h:103
const value_type & const_reference
Represents the const reference of list value type.
Definition list.h:89
iterator end() noexcept override
Returns an iterator to the element following the last element of the enumarable.
Definition list.h:318
virtual size_type capacity() const noexcept
Gets the total number of elements the internal data structure can hold without resizing.
Definition list.h:231
virtual void assign(std::initializer_list< type_t > items)
Replaces the contents with the elements from the initializer list items.
Definition list.h:442
virtual const_reverse_iterator crbegin() const noexcept
Returns a reverse iterator to the first element of the reversed vector. It corresponds to the last el...
Definition list.h:293
virtual allocator_type get_allocator() const
Returns the allocator associated with the container.
Definition list.h:568
virtual void remove_range(size_type index, size_type count)
Removes a range of elements from the xtd::collections::generic::list <type_t>.
Definition list.h:823
size_type count() const noexcept override
Gets the number of elements contained in the xtd::collections::generic::list <type_t>.
Definition list.h:288
virtual void reserve(size_type new_cap)
Increase the capacity of the vector (the total number of elements that the vector can hold without re...
Definition list.h:834
list(size_type count, const type_t &value, const allocator_type &alloc=allocator_type())
Constructs the container with specified count copies of elements with specified value.
Definition list.h:134
list(list &&other)
Move constructor with specified list.
Definition list.h:176
list & operator=(const list &other)=default
Copy assignment operator. Replaces the contents with a copy of the contents of other.
typename base_type::const_reverse_iterator const_reverse_iterator
Represents the const reverse iterator of list value type.
Definition list.h:101
virtual const_reverse_iterator rend() const noexcept
Returns a reverse iterator to the element following the last element of the reversed vector....
Definition list.h:360
value_type & reference
Represents the reference of list value type.
Definition list.h:87
virtual void insert_range(size_type index, const std::initializer_list< type_t > &items)
Inserts copy of elements from a collection into the xtd::collections::generic::list <type_t> at the s...
Definition list.h:749
enumerator< value_type > get_enumerator() const noexcept override
Returns an enumerator that iterates through a collection.
Definition list.h:578
void add_range(const xtd::collections::generic::ienumerable< type_t > &enumerable)
Adds copy of elements from the specified collection to the end of the xtd::collections::generic::list...
Definition list.h:395
virtual void resize(size_type count, const value_type &value)
Resizes the container to contain count elements, does nothing if count == size(). @param count The ne...
Definition list.h:850
read_only_collection as_read_only() const noexcept
Returns a read-only xtd::collections::object_model::read_only_collection <type_t> wrapper for the cur...
Definition list.h:434
virtual reverse_iterator rbegin() noexcept
Returns a reverse iterator to the first element of the reversed vector. It corresponds to the last el...
Definition list.h:347
iterator begin() noexcept override
Returns an iterator to the first element of the enumarable.
Definition list.h:207
virtual void capacity(size_type value)
Sets the total number of elements the internal data structure can hold without resizing.
Definition list.h:254
virtual size_type size() const noexcept
Returns the number of elements in the container, i.e. std::distance(xtd::collections::generic::list::...
Definition list.h:364
virtual iterator insert(const_iterator pos, const type_t &value)
Inserts elements at the specified location in the container.
Definition list.h:660
virtual void resize(size_type count)
Resizes the container to contain count elements, does nothing if count == size(). @param count The ne...
Definition list.h:840
virtual size_type index_of(const type_t &value, size_type index) const
Determines the index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.h:637
list(const base_type &list)
Copy constructor with specified base type list.
Definition list.h:160
virtual const_reverse_iterator rbegin() const noexcept
Returns a reverse iterator to the first element of the reversed vector. It corresponds to the last el...
Definition list.h:351
list(base_type &&other, const allocator_type &alloc)
Move constructor with specified base tyoe list, and allocator.
Definition list.h:187
void add_range(std::initializer_list< type_t > il)
Adds copy of elements from the specified collection to the end of the xtd::collections::generic::list...
Definition list.h:405
value_type * pointer
Represents the pointer of list value type.
Definition list.h:91
virtual iterator erase(const_iterator first, const_iterator last)
Erases the specified elements from the container.
Definition list.h:561
virtual void push_back(const type_t &value)
Appends the given element value to the end of the container.
Definition list.h:782
virtual const base_type & get_base_type() const noexcept
Returns the underlying base type.
Definition list.h:576
const_iterator cend() const noexcept override
Returns an iterator to the element following the last element of the enumarable.
Definition list.h:265
virtual iterator insert(const_iterator pos, const std::initializer_list< type_t > &items)
Inserts elements at the specified location in the container.
Definition list.h:703
virtual iterator erase(const_iterator pos)
Erases the specified elements from the container.
Definition list.h:549
bool contains(const type_t &value) const noexcept override
Determines whether the xtd::collections::generic::icollection <type_t> contains a specific value.
Definition list.h:470
type_t value_type
Represents the list value type.
Definition list.h:77
virtual size_type index_of(const type_t &value, size_type index, size_type count) const
Determines the index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.h:645
iterator insert(const_iterator pos, input_iterator_t first, input_iterator_t last)
Inserts elements at the specified location in the container.
Definition list.h:693
iterator emplace(const_iterator pos, args_t &&... args)
Inserts a new element into the container directly before pos.
Definition list.h:524
bool remove(const type_t &item) override
Removes the first occurrence of a specific object from the xtd::collections::generic::icollection <ty...
Definition list.h:795
list(size_type count, const allocator_type &alloc=allocator_type())
Constructs the container with specified count default-inserted instances of type_t....
Definition list.h:138
typename xtd::collections::generic::ilist< type_t >::iterator iterator
Represents the iterator of list value type.
Definition list.h:95
virtual iterator insert(const_iterator pos, size_type count, const type_t &value)
Inserts elements at the specified location in the container.
Definition list.h:681
virtual iterator insert(const_iterator pos, const type_t &&value)
Inserts elements at the specified location in the container.
Definition list.h:670
typename xtd::collections::generic::ilist< type_t >::const_iterator const_iterator
Represents the const iterator of list value type.
Definition list.h:97
virtual reference back()
Returns a reference to the last element in the container.
Definition list.h:196
Represents a strongly typed list of objects that can be accessed by index. Provides methods to search...
Definition list.h:71
Provides the base class for a generic read-only collection.
Definition read_only_collection.h:38
Defines a generalized method that a value type or class implements to create a type-specific method f...
Definition iequatable.h:22
The exception that is thrown when an attempt is made to access an element of an array with an index t...
Definition index_out_of_range_exception.h:18
The exception that is thrown when a method call is invalid for the object's current state.
Definition invalid_operation_exception.h:18
Supports all classes in the xtd class hierarchy and provides low-level services to derived classes....
Definition object.h:42
Represents the version number of an assembly, operating system, or the xtd. This class cannot be inhe...
Definition version.h:114
static basic_string format(const basic_string< char > &fmt, args_t &&... args)
Writes the text representation of the specified arguments list, to string using the specified format ...
std::allocator< type_t > allocator
Represent an allocator alias.
Definition allocator.h:35
#define csf_
Provides information about the current stack frame.
Definition current_stack_frame.h:30
xtd::sptr< type_t > ptr
The xtd::ptr object is a shared pointer.
Definition ptr.h:27
size_t size
Represents a size of any object in bytes.
Definition size.h:23
intmax_t intptr
Represent a pointer or a handle.
Definition intptr.h:23
uint8_t byte
Represents a 8-bit unsigned integer.
Definition byte.h:23
std::ptrdiff_t ptrdiff
Represent the signed integer type of the result of subtracting two pointers.
Definition ptrdiff.h:23
std::type_info type
Stores information about a type.
Definition type.h:23
ptr< type_t > new_ptr(args_t &&... args)
The xtd::new_ptr operator creates a xtd::ptr object.
Definition new_ptr.h:23
@ other
The operating system is other.
@ c
The C key.
@ i
The I key.
@ insert
The INS (INSERT) key.
Contains xtd::collections::ilist alias.
std::vector< type_t > array
Definition __array_definition.h:18
The xtd namespace contains all fundamental classes to access Hardware, Os, System,...
Definition xtd_about_box.h:10
Contains xtd::collections::generic::params class.