xtd 1.0.0
Loading...
Searching...
No Matches
list.hpp
Go to the documentation of this file.
1
4#pragma once
6#include "helpers/equator.hpp"
7#include "helpers/lesser.hpp"
9#include "comparer.hpp"
10#include "ilist.hpp"
11#define __XTD_CORE_INTERNAL__
13#undef __XTD_CORE_INTERNAL__
15#include "../../action.hpp"
16#include "../../comparison.hpp"
17#include "../../converter.hpp"
18#include "../../intptr.hpp"
19#include "../../is.hpp"
20#include "../../object.hpp"
21#include "../../optional.hpp"
22#include "../../new_ptr.hpp"
23#include "../../predicate.hpp"
24#include "../../self.hpp"
25#include "../../string.hpp"
26
28namespace xtd {
30 namespace collections {
32 namespace generic {
79 template<typename type_t, typename allocator_t>
80 class list : public xtd::object, public xtd::collections::generic::ilist<type_t>, public xtd::iequatable<xtd::collections::generic::list<type_t, allocator_t >> {
81 public:
83
100 using const_pointer = const value_type*;
104
106
116 list() noexcept = default;
123 explicit list(size_type capacity) {self_.capacity(capacity);}
131 list(const xtd::collections::generic::ienumerable<type_t>& collection) requires std::copy_constructible<type_t> {add_range(collection);}
134 list(const list& list) requires std::copy_constructible<type_t> {*data_ = *list.data_;}
138 data_ = std::move(list.data_);
139 list.data_ = new_ptr<list_data>();
140 }
141
143 list(const base_type& list) requires std::copy_constructible<type_t> {data_->items = list;}
146 list(base_type&& list) {data_->items = std::move(list);}
149 list(std::initializer_list<type_t> items) requires std::copy_constructible<type_t> {add_range(items);}
153 template <std::input_iterator input_iterator_t>
154 list(input_iterator_t first, input_iterator_t last) requires std::copy_constructible<type_t> {
155 for (auto iterator = first; iterator != last; ++iterator)
156 add(*iterator);
157 }
158
159
161
185 [[nodiscard]] auto capacity() const noexcept -> size_type {return data_->items.capacity();}
209 auto capacity(size_type value) -> void {
212 if (value == capacity()) return;
213 if (value < capacity()) data_->items.shrink_to_fit();
214 data_->items.reserve(value);
215 }
216
238 [[nodiscard]] auto count() const noexcept -> size_type override {return data_->items.size();}
239
243 [[nodiscard]] auto data() noexcept -> pointer {return reinterpret_cast<pointer>(data_->items.data());}
247 [[nodiscard]] auto data() const noexcept -> const_pointer {return reinterpret_cast<const_pointer>(data_->items.data());}
248
251 [[nodiscard]] const auto& items() const noexcept {return data_->items;}
254 [[nodiscard]] auto& items() noexcept {return data_->items;}
256
258
273 auto add(const type_t& item) -> void override {
274 if constexpr (std::copy_constructible<type_t>) data_->items.push_back(item);
275 else xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "value_type is not copy constructible.");
276 }
277
290 auto add(type_t&& item) -> void {data_->items.push_back(std::forward<type_t>(item));}
291
300 auto add_range(const xtd::collections::generic::ienumerable<type_t>& enumerable) -> void requires std::copy_constructible<type_t> {insert_range(count(), enumerable);}
301
310 auto add_range(std::initializer_list<type_t> il) -> void requires std::copy_constructible<type_t> {insert_range(count(), il);}
311
313 template<typename enumerable_t>
314 auto add_range(const enumerable_t& enumerable) -> void requires std::copy_constructible<type_t> {insert_range(count(), enumerable);}
316
321 [[nodiscard]] auto as_read_only() const noexcept -> read_only_collection requires std::copy_constructible<type_t> {return read_only_collection {self_};}
322
336 [[nodiscard]] auto binary_search(const type_t& item) const noexcept -> xtd::usize {return binary_search(0, count(), item, xtd::collections::generic::comparer<type_t>::default_comparer);}
348 [[nodiscard]] auto binary_search(const type_t& item, const xtd::collections::generic::icomparer<type_t>& comparer) const noexcept -> xtd::usize {return binary_search(0, count(), item, comparer);}
363 [[nodiscard]] auto binary_search(xtd::usize index, xtd::usize count, const type_t& item, const xtd::collections::generic::icomparer<type_t>& comparer) const -> xtd::usize {
365 auto first = data_->items.begin();
366 auto last = data_->items.begin();
367 std::advance(first, index);
368 std::advance(last, index + count);
369 auto position = std::lower_bound(first, last, item, helpers::lesser<type_t> {comparer});
370
371 if (position != data_->items.end() && !comparer.compare(item, *position))
372 return std::distance(data_->items.begin(), position);
373 return ~std::distance(data_->items.begin(), position);
374 }
375
380 auto clear() -> void override {data_->items.clear();}
381
385 [[nodiscard]] auto contains(const type_t& value) const noexcept -> bool override {
386 return index_of(value) != npos;
387 }
388
396 template<typename output_t, typename converter_t>
397 [[nodiscard]] auto convert_all(converter_t converter) const -> list<output_t> {
398 auto result = list<output_t> {};
399 auto apply_converter = xtd::converter<output_t, const type_t&> {converter};
400 for (const auto& item : self_)
401 result.add(apply_converter(item));
402 return result;
403 }
404
414 auto copy_to(xtd::array<type_t>& array) const -> void requires std::copy_constructible<type_t> {copy_to(0, array, 0, count());}
422 auto copy_to(xtd::array<type_t>& array, size_type array_index) const -> void override {
423 if constexpr (std::copy_constructible<type_t>) copy_to(0, array, array_index, count());
424 else xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "value_type is not copy constructible.");
425 }
426
439 auto copy_to(size_type index, xtd::array<type_t>& array, size_type array_index, size_type count) const -> void requires std::copy_constructible<type_t> {
441 for (auto i = index; i < (index + count); ++i)
442 array[array_index++] = self_[i];
443 }
444
450 data_->items.reserve(capacity);
451 return self_.capacity();
452 }
453
460 [[nodiscard]] auto equals(const object& obj) const noexcept -> bool override {return is<list<value_type>>(obj) && equals(static_cast<const list<value_type>& > (obj));}
464 [[nodiscard]] auto equals(const list& obj) const noexcept -> bool override {
465 if (count() != obj.count()) return false;
466 for (size_type i = 0; i < count(); i++)
467 if (!helpers::equator<type_t> {}(self_[i], obj[i])) return false;
468 return true;
469 }
470
482 template<typename predicate_t>
483 [[nodiscard]] auto exists(predicate_t match) const -> bool {
484 return find_index(match) != npos;
485 }
486
498 template<typename predicate_t>
499 [[nodiscard]] auto find(predicate_t match) const -> optional<type_t> {
500 auto index = find_index(match);
501 if (index == npos) return nullopt;
502 return self_[index];
503 }
504
516 template<typename predicate_t>
517 [[nodiscard]] auto find_all(predicate_t match) const -> list {
519 auto result = list {};
520 for (const auto& item : self_)
521 if (predicate(item)) result.add(item);
522 return result;
523 }
524
530 template<typename predicate_t>
531 [[nodiscard]] auto find_index(predicate_t match) const -> xtd::usize {return find_index(0, count(), match);}
539 template<typename predicate_t>
540 [[nodiscard]] auto find_index(xtd::usize start_index, predicate_t match) const -> xtd::usize {return find_index(start_index, count() - start_index, match);}
549 template<typename predicate_t>
550 [[nodiscard]] auto find_index(xtd::usize start_index, xtd::usize count, predicate_t match) const -> xtd::usize {
553 for (auto index = start_index; index < start_index + count; ++index)
554 if (predicate(self_[index])) return index;
555 return npos;
556 }
557
569 template<typename predicate_t>
570 [[nodiscard]] auto find_last(predicate_t match) const -> optional<type_t> {
571 auto index = find_last_index(match);
572 if (index == npos) return nullopt;
573 return self_[index];
574 }
575
581 template<typename predicate_t>
582 [[nodiscard]] auto find_last_index(predicate_t match) const -> xtd::usize {return find_last_index(count() - 1, count(), match);}
590 template<typename predicate_t>
591 [[nodiscard]] auto find_last_index(xtd::usize start_index, predicate_t match) const -> xtd::usize {return find_last_index(start_index, start_index + 1, match);}
600 template<typename predicate_t>
601 [[nodiscard]] auto find_last_index(xtd::usize start_index, xtd::usize count, predicate_t match) const -> xtd::usize {
604 auto end_index = start_index + 1 - count;
605 for (auto index = start_index; ; --index) {
606 if (predicate(self_[index])) return index;
607 if (index == end_index) break;
608 }
609 return npos;
610 }
611
620 template<typename action_t>
621 auto for_each(action_t action) -> void {
622 auto apply_action = xtd::action<const type_t&> {action};
623 for (const auto& item : self_)
624 apply_action(item);
625 }
626
629 [[nodiscard]] enumerator<value_type> get_enumerator() const noexcept override {
630 struct list_enumerator : public ienumerator<value_type> {
631 explicit list_enumerator(const list& items, xtd::usize version) : items_(items), version_(version) {}
632
633 [[nodiscard]] const value_type& current() const override {
635 if (version_ != items_.data_->items.version()) xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "Collection was modified; enumeration operation may not execute.");
636 return items_[index_];
637 }
638
639 [[nodiscard]] bool move_next() override {
640 if (version_ != items_.data_->items.version()) xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "Collection was modified; enumeration operation may not execute.");
641 return ++index_ < items_.count();
642 }
643
644 void reset() override {
645 version_ = items_.data_->items.version();
646 index_ = list::npos;
647 }
648
649 private:
650 size_type index_ = list::npos;
651 const list& items_;
652 size_type version_ = 0;
653 };
654
655 return {new_ptr<list_enumerator>(self_, data_->items.version())};
656 }
657
670 [[nodiscard]] auto get_range(size_type index, size_type count) -> list {
672 return list<type_t> {data_->items.begin() + index, data_->items.begin() + index + count};
673 }
674
678 [[nodiscard]] auto index_of(const type_t& value) const noexcept -> size_type override {
679 if (count() == 0) return npos;
680 return index_of(value, 0, count());
681 }
682
687 [[nodiscard]] auto index_of(const type_t& value, size_type index) const -> size_type {return index_of(value, index, count() - index);}
694 [[nodiscard]] auto index_of(const type_t& value, size_type index, size_type count) const -> size_type {
695 return find_index(index, count, delegate_(const auto& n) {return helpers::equator<type_t> {}(n, value);});
696 }
697
703 auto insert(size_type index, const type_t& value) -> void override {
704 if constexpr (std::copy_constructible<type_t>) {
706 data_->items.insert(data_->items.begin() + index, value);
707 } else xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "value_type is not copy constructible.");
708 }
709
714 auto insert(size_type index, type_t&& value) -> void {
716 data_->items.insert(data_->items.begin() + index, std::forward<type_t>(value));
717 }
718
730
731 // If the collection is this instance, it must be copied to avoid an infinite loop.
732 if (static_cast<const void*>(&enumerable) == static_cast<const void*>(this)) {
734 return;
735 }
736
737 data_->items.insert(data_->items.begin() + index, enumerable.begin(), enumerable.end());
738 }
739
748 auto insert_range(size_type index, const std::initializer_list<type_t>& items) -> void {
750 data_->items.insert(data_->items.begin() + index, items.begin(), items.end());
751 }
752
754 template<typename collection_t>
755 auto insert_range(size_type index, const collection_t& items) -> void {
757
758 // If the collection is this instance, it must be copied to avoid an infinite loop.
759 if (static_cast<const void*>(&items) == static_cast<const void*>(this)) {
760 insert_range(index, list(items));
761 return;
762 }
763
764 data_->items.insert(data_->items.begin() + index, items.begin(), items.end());
765 }
767
771 [[nodiscard]] auto last_index_of(const type_t& value) const noexcept -> size_type {
772 if (count() == 0) return npos;
773 return last_index_of(value, count() - 1, count());
774 }
775
780 [[nodiscard]] auto last_index_of(const type_t& value, size_type index) const -> size_type {
781 return last_index_of(value, index, index + 1);
782 }
789 [[nodiscard]] auto last_index_of(const type_t& value, size_type index, size_type count) const -> size_type {
790 return find_last_index(index, count, delegate_(const auto& n) {return helpers::equator<type_t> {}(n, value);});
791 }
792
798 auto remove(const type_t& item) noexcept -> bool override {
799 auto index = index_of(item);
800 if (index == npos) return false;
801 remove_at(index);
802 return true;
803 }
804
816 template<typename predicate_t>
817 auto remove_all(predicate_t match) -> xtd::usize {
819 auto count = xtd::usize {0};
820 auto iterator = data_->items.begin();
821 while (iterator != data_->items.end())
822 if (!predicate(*iterator)) iterator++;
823 else {
824 iterator = data_->items.erase(iterator);
825 ++count;
826 }
827 return count;
828 }
829
833 auto remove_at(size_type index) -> void override {
835 data_->items.erase(data_->items.begin() + index);
836 }
837
846 auto remove_range(size_type index, size_type count) -> void {
848 data_->items.erase(data_->items.begin() + index, data_->items.begin() + index + count);
849 }
850
856 virtual auto resize(size_type count) -> void {
857 if constexpr (std::copy_constructible<type_t>) {
858 resize(count, value_type {});
859 } else xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "value_type is not copy constructible.");
860 }
867 virtual auto resize(size_type count, const value_type& value) -> void {
868 if constexpr (std::copy_constructible<type_t>) {
870 if (count == self_.count()) return;
871 data_->items.resize(count, value);
872 } else xtd::helpers::throw_helper::throws(xtd::helpers::exception_case::invalid_operation, "value_type is not copy constructible.");
873 }
874
881 auto reverse() -> list<type_t>& {return reverse(0, count());}
893 data_->items.increment_version();
894 std::reverse(data_->items.begin() + index, data_->items.begin() + index + count);
895 return self_;
896 }
897
903 [[nodiscard]] auto slice(size_type start, size_type length) const -> list<type_t> requires std::copy_constructible<type_t> {
905 return list<type_t> {data_->items.begin() + start, data_->items.begin() + start + length};
906 }
907
918
925 data_->items.increment_version();
926 std::sort(data_->items.begin(), data_->items.end(), [&](const type_t& x, const type_t& y) {return comparison(x, y) < 0;});
927 return self_;
928 }
929
938
949 data_->items.increment_version();
950 std::sort(data_->items.begin() + index, data_->items.begin() + index + count, helpers::lesser<type_t> {comparer});
951 return self_;
952 }
953
961 [[nodiscard]] auto to_array() const noexcept -> xtd::array<value_type> requires std::copy_constructible<type_t> {return count() ? xtd::array<value_type>(data_->items.begin(), data_->items.end()) : xtd::array<value_type> {};}
962
965 [[nodiscard]] auto to_string() const noexcept -> xtd::string override {return xtd::string::format("[{}]", xtd::string::join(", ", self_));}
966
987 auto trim_excess() -> void {data_->items.shrink_to_fit();}
988
1000 template<typename prediacate_t>
1001 [[nodiscard]] auto true_for_all(prediacate_t match) const -> bool {
1003 for (const auto& item : self_)
1004 if (!predicate(item)) return false;
1005 return true;
1006 }
1007
1008
1010
1015 auto operator =(const list& other) -> list& requires std::copy_constructible<type_t> = default;
1019 auto operator =(list&& other) noexcept -> list& {
1020 data_->items = std::move(other.data_->items);
1021 return self_;
1022 }
1023
1026 auto operator =(const std::initializer_list<type_t>& items) -> list& requires std::copy_constructible<type_t> {
1027 data_->items = items;
1028 return self_;
1029 }
1030
1035 auto operator [](size_type index) const -> const_reference override {
1037 return data_->items[index];
1038 }
1039
1043 auto operator [](size_type index) -> reference override {
1045 return data_->items[index];
1046 }
1047
1050 operator const_base_type& () const noexcept {return data_->items;}
1053 operator base_type& () noexcept {return data_->items;}
1055
1056 private:
1057 auto is_fixed_size() const noexcept -> bool override {return false;}
1058 auto is_read_only() const noexcept -> bool override {return false;}
1059 auto is_synchronized() const noexcept -> bool override {return false;}
1060 const xtd::object& sync_root() const noexcept override {return data_->sync_root;}
1061
1062 struct list_data {
1063 xtd::collections::generic::helpers::raw_array<value_type, allocator_t> items;
1064 xtd::object sync_root;
1065 };
1066
1068 };
1069
1071 // Deduction guides for xtd::collections::generic::list
1072 // {
1073 template<typename type_t>
1074 list(std::initializer_list<type_t>) -> list<type_t>;
1075
1076 template<typename type_t>
1078
1079 template<typename type_t>
1080 list(const ilist<type_t>&) -> list<type_t>;
1081
1082 template<typename type_t>
1083 list(const std::vector<type_t>&) -> list<type_t>;
1084
1085 template<typename type_t, typename allocator_t = helpers::allocator<type_t>>
1087
1088 template<typename type_t>
1089 list(std::vector<type_t>&&) -> list<type_t>;
1090
1091 template<typename type_t, typename allocator_t = helpers::allocator<type_t>>
1093
1094 template<typename input_iterator_t>
1095 list(input_iterator_t, input_iterator_t) -> list<std::iter_value_t<input_iterator_t>>;
1096 // }
1098 }
1099 }
1100}
1101
1104 template<typename enumerable_t, typename source_t>
1105 inline auto enumerable<enumerable_t, source_t>::to_list() const noexcept -> xtd::collections::generic::list<source_t> {
1106 return xtd::linq::enumerable::to_list(self());
1107 }
1108}
1109
1110namespace xtd::linq {
1111 template<typename source_t>
1112 inline auto enumerable::to_list(const xtd::collections::generic::ienumerable<source_t>& source) noexcept {
1113 auto result = xtd::collections::generic::list<source_t> {};
1114 result = xtd::collections::generic::list<source_t> {source};
1115 return result;
1116 }
1117}
Contains xtd::action delegate.
Contains xtd::collections::generic::helpers::allocator alias.
Provides methods for creating, manipulating, searching, and sorting arrays, thereby serving as the ba...
Definition array.hpp:64
virtual auto length() const noexcept -> size_type
Gets a size that represents the total number of elements in all the dimensions of the array.
Definition basic_array.hpp:122
static auto join(const basic_string &separator, const collection_t &values) noexcept -> basic_string
Definition basic_string.hpp:1258
Provides a base class for implementations of the xtd::collections::generic::icomparer <type_t> generi...
Definition comparer.hpp:33
auto compare(const first_argument_type &x, const second_argument_type &y) const -> result_type override
Compares two entities and returns a value indicating whether one is less than, equal to,...
Definition comparer.hpp:66
static const comparer< xtd::any_object > default_comparer
Definition comparer.hpp:50
auto to_list() const noexcept -> xtd::collections::generic::list< source_t >
Creates a xtd::collections::generic::list <type_t> from an xtd::collections::generic::ienumerable <ty...
internal_base_type base_type
Underlying vector type.
Definition raw_array.hpp:123
typename xtd::collections::generic::ienumerable< xtd::any_object >::value_type value_type
Definition icollection.hpp:51
Exposes a method that compares two objects.
Definition icomparer.hpp:30
Exposes the enumerator, which supports a simple iteration over a collection of a specified type.
Definition ienumerable.hpp:40
typename xtd::collections::generic::extensions::enumerable_iterators< xtd::any_object, xtd::collections::generic::ienumerable< xtd::any_object > >::iterator iterator
Definition ienumerable.hpp:48
Supports a simple iteration over a generic collection.
Definition ienumerator.hpp:58
Represents a collection of objects that can be individually accessed by index.
Definition ilist.hpp:43
static constexpr xtd::usize npos
Definition ilist.hpp:56
virtual auto is_fixed_size() const noexcept -> bool=0
Gets a value indicating whether the xtd::collections::generic::ilist <type_t> has a fixed size.
virtual auto is_synchronized() const noexcept -> bool=0
Gets a value indicating whether access to the xtd::collections::generic::icollection <type_t> is sync...
virtual auto count() const noexcept -> xtd::usize=0
Gets the number of elements contained in the xtd::collections::generic::icollection <type_t>.
virtual auto sync_root() const noexcept -> const xtd::object &=0
Gets an object that can be used to synchronize access to the the xtd::collections::generic::icollecti...
virtual auto is_read_only() const noexcept -> bool=0
Gets a value indicating whether the xtd::collections::generic::icollection <type_t> is read-only.
Represents a strongly typed list of objects that can be accessed by index. Provides methods to search...
Definition list.hpp:80
auto last_index_of(const type_t &value, size_type index, size_type count) const -> size_type
Determines the last index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.hpp:789
auto to_array() const noexcept -> xtd::array< value_type >
Copies the elements of the xtd::collections::generic::list <type_t> to a new array.
Definition list.hpp:961
auto count() const noexcept -> size_type override
Gets the number of elements contained in the xtd::collections::generic::list <type_t>.
Definition list.hpp:238
list(std::initializer_list< type_t > items)
Constructs the container with the contents of the specified initializer list, and allocator.
Definition list.hpp:149
auto operator=(const list &other) -> list &=default
Copy assignment operator. Replaces the contents with a copy of the contents of other.
auto index_of(const type_t &value) const noexcept -> size_type override
Determines the index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.hpp:678
auto equals(const object &obj) const noexcept -> bool override
Determines whether the specified object is equal to the current object.
Definition list.hpp:460
auto find_index(xtd::usize start_index, xtd::usize count, predicate_t match) const -> xtd::usize
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:550
auto sort(xtd::comparison< const type_t & > comparison) -> list< type_t > &
Sorts the elements in the entire xtd::collections::generic::list <type_t> using the specified xtd::co...
Definition list.hpp:924
auto operator[](size_type index) const -> const_reference override
Returns a reference to the element at specified location index.
Definition list.hpp:1035
auto insert(size_type index, const type_t &value) -> void override
Determines the index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.hpp:703
list(base_type &&list)
Move constructor with specified base type list.
Definition list.hpp:146
auto sort() -> list< type_t > &
Sorts the elements in the entire xtd::collections::generic::list <type_t> using the default comparer.
Definition list.hpp:917
auto find_last_index(xtd::usize start_index, xtd::usize count, predicate_t match) const -> xtd::usize
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:601
const value_type * const_pointer
Definition list.hpp:100
const base_type const_base_type
Definition list.hpp:90
auto last_index_of(const type_t &value) const noexcept -> size_type
Determines the last index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.hpp:771
auto sort(xtd::usize index, xtd::usize count, const xtd::collections::generic::icomparer< type_t > &comparer) -> list< type_t > &
Sorts the elements in a range of elements in xtd::collections::generic::list <type_t> using the speci...
Definition list.hpp:947
auto insert(size_type index, type_t &&value) -> void
Inserts an element into the xtd::collections::generic::list <type_t> at the specified index.
Definition list.hpp:714
auto remove_range(size_type index, size_type count) -> void
Removes a range of elements from the xtd::collections::generic::list <type_t>.
Definition list.hpp:846
auto index_of(const type_t &value, size_type index) const -> size_type
Determines the index of a specific item in the xtd::collections::generic::list <type_t>.
Definition list.hpp:687
auto ensure_capacity(xtd::usize capacity) -> xtd::usize
Ensures that the capacity of this list is at least the specified capacity. If the current capacity is...
Definition list.hpp:449
auto remove(const type_t &item) noexcept -> bool override
Removes the first occurrence of a specific object from the xtd::collections::generic::list <type_t>.
Definition list.hpp:798
auto to_string() const noexcept -> xtd::string override
Returns a xtd::string that represents the current object.
Definition list.hpp:965
auto slice(size_type start, size_type length) const -> list< type_t >
Creates a shallow copy of a range of elements in the source xtd::collections::generic::list <type_t>.
Definition list.hpp:903
auto add(const type_t &item) -> void override
Adds an object to the end of the xtd::collections::generic::list <type_t>.
Definition list.hpp:273
auto reverse() -> list< type_t > &
Resizes the container to contain count elements, does nothing if count == size(). @param count The ne...
Definition list.hpp:881
auto remove_all(predicate_t match) -> xtd::usize
Removes all the elements that match the conditions defined by the specified predicate.
Definition list.hpp:817
auto find_last(predicate_t match) const -> optional< type_t >
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:570
xtd::usize size_type
Definition list.hpp:92
auto find_last_index(xtd::usize start_index, predicate_t match) const -> xtd::usize
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:591
auto add_range(const xtd::collections::generic::ienumerable< type_t > &enumerable) -> void
Adds copy of elements from the specified collection to the end of the xtd::collections::generic::list...
Definition list.hpp:300
list() noexcept=default
Initializes a new instance of the xtd::collections::generic::list class that is empty.
list(const list &list)
Default copy constructor with specified list.
Definition list.hpp:134
auto & items() noexcept
Returns the underlying base type items.
Definition list.hpp:254
auto add_range(std::initializer_list< type_t > il) -> void
Adds copy of elements from the specified collection to the end of the xtd::collections::generic::list...
Definition list.hpp:310
const value_type & const_reference
Definition list.hpp:96
auto capacity(size_type value) -> void
Sets the total number of elements the internal data structure can hold without resizing.
Definition list.hpp:209
auto insert_range(size_type index, const std::initializer_list< type_t > &items) -> void
Inserts copy of elements from a collection into the xtd::collections::generic::list <type_t> at the s...
Definition list.hpp:748
auto for_each(action_t action) -> void
Performs the specified action on each element of the xtd::collections::generic::list <type_t>.
Definition list.hpp:621
list(const xtd::collections::generic::ienumerable< type_t > &collection)
Initializes a new instance of the xtd::collections::generic::list <type_t> class that contains elemen...
Definition list.hpp:131
auto contains(const type_t &value) const noexcept -> bool override
Determines whether an element is in the xtd::colllections::generic::list <type_t>.
Definition list.hpp:385
list(const base_type &list)
Copy constructor with specified base type list.
Definition list.hpp:143
typename ilist< xtd::any_object >::value_type value_type
Definition list.hpp:86
list(list &&list)
Move constructor with specified list.
Definition list.hpp:137
auto exists(predicate_t match) const -> bool
Determines whether the xtd::collections::generic::list <type_t> contains elements that match the cond...
Definition list.hpp:483
auto true_for_all(prediacate_t match) const -> bool
Determines whether every element in the xtd::collections::generic::list <type_t> matches the conditio...
Definition list.hpp:1001
value_type & reference
Definition list.hpp:94
auto copy_to(xtd::array< type_t > &array, size_type array_index) const -> void override
Copies the entire xtd::colllections::generic::list <type_t> to a compatible one-dimensional array,...
Definition list.hpp:422
enumerator< value_type > get_enumerator() const noexcept override
Returns an enumerator that iterates through the xtd::collections::generic::list <type_t>.
Definition list.hpp:629
auto get_range(size_type index, size_type count) -> list
Creates a shallow copy of a range of elements in the source xtd::collections::generic::list <type_t>.
Definition list.hpp:670
auto binary_search(xtd::usize index, xtd::usize count, const type_t &item, const xtd::collections::generic::icomparer< type_t > &comparer) const -> xtd::usize
Searches a range of elements in the sorted xtd::collections::generic::list <type_t> for an element us...
Definition list.hpp:363
auto copy_to(xtd::array< type_t > &array) const -> void
Copies the entire xtd::collections::generic::list <type_t> to a compatible one-dimensional array.
Definition list.hpp:414
typename xtd::collections::generic::helpers::raw_array< value_type >::base_type base_type
Definition list.hpp:88
auto binary_search(const type_t &item, const xtd::collections::generic::icomparer< type_t > &comparer) const noexcept -> xtd::usize
Searches the entire sorted xtd::collections::generic::list <type_t> for an element using the specifie...
Definition list.hpp:348
auto copy_to(size_type index, xtd::array< type_t > &array, size_type array_index, size_type count) const -> void
Copies the entire xtd::collections::generic::list <type_t> to a compatible one-dimensional array,...
Definition list.hpp:439
auto equals(const list &obj) const noexcept -> bool override
Indicates whether the current object is equal to another object of the same type.
Definition list.hpp:464
auto clear() -> void override
Removes all elements from the xtd::collections::generic::list <type_t>.
Definition list.hpp:380
auto capacity() const noexcept -> size_type
Definition list.hpp:185
auto data() const noexcept -> const_pointer
Returns pointer to the underlying array serving as element storage.
Definition list.hpp:247
auto find_last_index(predicate_t match) const -> xtd::usize
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:582
auto remove_at(size_type index) -> void override
Removes the element at the specified index of the xtd::collections::generic::list <type_t>.
Definition list.hpp:833
auto find_index(xtd::usize start_index, predicate_t match) const -> xtd::usize
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:540
value_type * pointer
Definition list.hpp:98
auto reverse(size_type index, size_type count) -> list< type_t > &
Reverses the order of the elements in the specified range.
Definition list.hpp:891
auto find_index(predicate_t match) const -> xtd::usize
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:531
auto find_all(predicate_t match) const -> list
Retrieves all the elements that match the conditions defined by the specified predicate.
Definition list.hpp:517
auto binary_search(const type_t &item) const noexcept -> xtd::usize
Searches the entire sorted xtd::collections::generic::list <type_t> for an element using the default ...
Definition list.hpp:336
const auto & items() const noexcept
Definition list.hpp:251
auto data() noexcept -> pointer
Returns pointer to the underlying array serving as element storage.
Definition list.hpp:243
xtd::collections::object_model::read_only_collection< value_type > read_only_collection
Definition list.hpp:102
auto find(predicate_t match) const -> optional< type_t >
Searches for an element that matches the conditions defined by the specified predicate,...
Definition list.hpp:499
auto insert_range(size_type index, const xtd::collections::generic::ienumerable< type_t > &enumerable) -> void
Inserts copy of elements from a collection into the xtd::collections::generic::list <type_t> at the s...
Definition list.hpp:728
auto convert_all(converter_t converter) const -> list< output_t >
Converts the elements in the current xtd::colllections::generic::list <type_t> to another type,...
Definition list.hpp:397
auto sort(const xtd::collections::generic::icomparer< type_t > &comparer) -> list< type_t > &
Sorts the elements in the entire xtd::collections::generic::list <type_t> using the specified compare...
Definition list.hpp:935
auto trim_excess() -> void
Sets the capacity to the actual number of elements in the xtd::collections::generic::list <type_t>,...
Definition list.hpp:987
list(input_iterator_t first, input_iterator_t last)
Constructs the container with the contents of the range [first, last).
Definition list.hpp:154
auto as_read_only() const noexcept -> read_only_collection
Returns a read-only xtd::collections::object_model::read_only_collection <type_t> wrapper for the cur...
Definition list.hpp:321
auto add(type_t &&item) -> void
Adds an object to the end of the xtd::collections::generic::list <type_t>.
Definition list.hpp:290
Provides the base class for a generic read-only collection.
Definition read_only_collection.hpp:39
static auto throws(xtd::helpers::exception_case exception_case, const source_location &location=source_location::current()) -> void
Throws an exption with specified exception case.
Defines a generalized method that a value type or class implements to create a type-specific method f...
Definition iequatable.hpp:23
static auto to_list(const ienumerable< source_t > &source) noexcept
Creates a xtd::collections::generic::list <type_t> from an xtd::collections::generic::ienumerable <ty...
Supports all classes in the xtd class hierarchy and provides low-level services to derived classes....
Definition object.hpp:45
Represents the version number of an assembly, operating system, or the xtd. This class cannot be inhe...
Definition version.hpp:115
Contains xtd::comparison delegate.
Definition enumerable.hpp:17
Contains xtd::converter alias.
Contains xtd::collections::generic::helpers::equator struct.
Contains xtd::collections::generic::comparer <type_t> class.
Contains xtd::collections::generic::ilist <type_t> interface.
xtd::delegate< int32(type_t x, type_t y)> comparison
Represents the method that compares two objects of the same type.
Definition comparison.hpp:33
xtd::delegate< output_t(input_t input)> converter
Represents a method that converts an object from one type to another type.
Definition converter.hpp:33
static auto format(const basic_string< char > &fmt, args_t &&... args) -> basic_string
@ index_out_of_range
The index is out of range.
Definition exception_case.hpp:61
@ out_of_memory
Out of memory.
Definition exception_case.hpp:87
@ argument_out_of_range
The argument is out of range.
Definition exception_case.hpp:35
@ invalid_operation
The operation is not valid.
Definition exception_case.hpp:65
#define self_
The self_ expression is a reference value expression whose value is the reference of the implicit obj...
Definition self.hpp:20
#define delegate_
The declaration of a delegate type is similar to a method signature. It has a return value and any nu...
Definition delegate.hpp:1018
xtd::sptr< type_t > ptr
The xtd::ptr object is a shared pointer.
Definition ptr.hpp:27
std::optional< type_t > optional
Represents the optional alias on std::optional.
Definition optional.hpp:26
std::size_t usize
Represents an unsigned size of any object in bytes.
Definition usize.hpp:22
constexpr null_opt nullopt
Represents a nullopt value. Used to indicate that an std::optional does not contain a value.
Definition nullopt.hpp:26
xtd::func< bool, type_t > predicate
Represents a delegate that defines a set of criteria and determines whether the specified object meet...
Definition predicate.hpp:16
auto is(xtd::any value) -> bool
Checks if the result of an expression is compatible with a given type.
Definition is.hpp:485
auto new_ptr(args_t &&... args) -> xtd::ptr< type_t >
The xtd::new_ptr operator creates a xtd::ptr object.
Definition new_ptr.hpp:24
@ other
The operating system is other.
Definition platform_id.hpp:60
@ y
The Y key.
Definition console_key.hpp:136
@ n
The N key.
Definition console_key.hpp:114
@ i
The I key.
Definition console_key.hpp:104
@ x
The X key.
Definition console_key.hpp:134
Contains xtd::intptr type.
Contains xtd::is method.
Contains xtd::collections::generic::helpers::lesser struct.
The xtd::extensions namespace contains interface extensions.
Definition collection_common.hpp:14
The xtd::collections::generic namespace contains interfaces and classes that define generic collectio...
Definition comparer.hpp:16
The xtd::collections namespace contains interfaces and classes that define various collections of obj...
Definition any_pair.hpp:10
Provides classes and interfaces that support queries that use Language-Integrated Query (LINQ).
Definition enumerable.hpp:50
The xtd namespace contains all fundamental classes to access Hardware, Os, System,...
Definition abstract_object.hpp:8
auto first() const -> read_only_span< type_t, count >
Obtains a subspan consisting of the first count elements of the sequence.
Definition read_only_span.hpp:249
xtd::usize size_type
Represents the read_only_span size type (usually xtd::usize).
Definition read_only_span.hpp:59
auto last() const -> read_only_span< type_t, count >
Obtains a subspan consisting of the last N elements of the sequence.
Definition read_only_span.hpp:274
constexpr auto length() const noexcept -> size_type
Returns the length of the current read_only_span.
Definition read_only_span.hpp:213
Contains xtd::new_ptr method.
Contains xtd::object class.
Contains xtd::optional type.
Contains xtd::predicate delegate.
Contains xtd::collections::generic::helpers::raw_array class.
Contains xtd::collections::object_model::read_only_collection class.
Contains self_ keyword.
Contains xtd::string alias.
Supports a simple iteration over a generic collection.
Definition enumerator.hpp:39
Implements a function object for performing comparisons. Unless specialised, invokes operator== on ty...
Definition equator.hpp:39
Implements a function object for compare data.
Definition lesser.hpp:39
Represents a value_type struct.
Definition value_type.hpp:34