8#include <xtd/collections/generic/helpers/equator>
9#include <xtd/collections/generic/list>
12#include <xtd/argument_out_of_range_exception>
13#include <xtd/event_args>
14#include <xtd/event_handler>
18#include <xtd/size_object>
40 template<
class type_t,
class sorter_t = sorter_none>
50 template<
class ...args_t>
51 value_type(args_t&& ...args) : type_t(args...) {}
53 if (value.owner) owner = value.owner;
54 if (owner !=
nullptr && !owner->data_->inserting && !owner->data_->erasing) owner->
on_item_updated(pos,
static_cast<type_t&
>(
const_cast<value_type&
>(value)));
55 type_t::operator =(value);
59 if (value.owner) owner = value.owner;
60 if (owner !=
nullptr && !owner->data_->inserting && !owner->data_->erasing) owner->
on_item_updated(pos,
static_cast<type_t&
>(value));
61 type_t::operator =(value);
64 operator type_t() {
return self_;}
65 friend std::ostream& operator <<(std::ostream& os,
const value_type& value) {
return os << static_cast<const type_t&>(value);}
69 friend class arranged_element_collection;
71 arranged_element_collection* owner =
nullptr;
167 data_ = std::move(collection.data_);
183 template <std::input_iterator input_iterator_t>
185 for (
auto iterator =
first; iterator !=
last; ++iterator)
216 const auto&
items()
const {
return data_->items.items();}
219 auto&
items() {
return data_->items.items();}
223 virtual bool sorted() const noexcept {
return data_->sorted;}
227 if (data_->sorted == value)
return self_;
228 data_->sorted = value;
229 if (data_->sorted)
sort();
239 void add(
const type_t& item)
override {
240 data_->items.add(item);
241 size_t index = data_->items.count() - 1;
242 static_cast<value_type&
>(
self_[index]).owner =
this;
243 static_cast<value_type&
>(
self_[index]).pos = index;
245 if (data_->sorted)
sort();
249 virtual void add(type_t&& item) {
250 data_->items.add(item);
251 size_t index = data_->items.count() - 1;
252 static_cast<value_type&
>(
self_[index]).owner =
this;
253 static_cast<value_type&
>(
self_[index]).pos = index;
255 if (data_->sorted)
sort();
261 for (
const auto& item : collection)
266 virtual void add_range(
const std::vector<type_t>& collection) {
267 for (
const auto& item : collection)
272 virtual void add_range(
const std::initializer_list<type_t>& collection) {
273 for (
const auto& item : collection)
278 template<
class collection_t>
280 for (
auto& item : collection)
281 add(value_type(item));
285 template<
class collection_t>
287 for (
const auto& item : collection)
301 bool contains(
const type_t& item)
const noexcept override {
302 return data_->items.contains(item);
312 for (
const type_t& item :
self_) {
314 array[array_index +
i++] = item;
324 const type_t& current()
const override {
327 return items_[index_];
330 bool move_next()
override {
332 return ++index_ < items_.count();
335 void reset()
override {
336 version_ = items_.items().version();
354 data_->inserting =
true;
356 data_->inserting =
false;
357 static_cast<value_type&
>(
self_[index]).owner =
this;
358 static_cast<value_type&
>(
self_[index]).pos = index;
360 if (data_->sorted)
sort();
375 bool remove(
const type_t& item)
override {
376 if (
count() == 0)
return false;
390 data_->erasing =
true;
392 data_->erasing =
false;
435 data_->items[index].pos = index >
npos / 2 ?
count() - (
npos - index) : index;
436 data_->items[index].owner =
this;
437 return data_->items[index];
444 data_->items[index].pos = index >
npos / 2 ?
count() - (
npos - index) : index;
446 return data_->items[index];
493 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().max_size - Will be removed in version 0.4.0.")]]
504 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::operator [] - Will be removed in version 0.4.0.")]]
506 data_->items[pos].pos = pos;
507 data_->items[pos].owner =
this;
508 return data_->items.at(pos);
514 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::operator [] - Will be removed in version 0.4.0.")]]
520 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::operator [~1_z] - Will be removed in version 0.4.0.")]]
525 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::operator [~1_z] - Will be removed in version 0.4.0.")]]
531 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().crbegin - Will be removed in version 0.4.0.")]]
532 const_reverse_iterator
crbegin() const noexcept {
return data_->items.crbegin();}
536 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().crend - Will be removed in version 0.4.0.")]]
537 const_reverse_iterator
crend() const noexcept {
return data_->items.crend();}
542 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::operator [0] - Will be removed in version 0.4.0.")]]
547 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::operator [0] - Will be removed in version 0.4.0.")]]
553 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().get_allocator - Will be removed in version 0.4.0.")]]
560 template<
class ...args_t>
561 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::insert - Will be removed in version 0.4.0.")]]
563 auto index = pos -
items().begin();
564 data_->inserting =
true;
565 auto result = data_->
items.insert(pos, args...);
566 data_->inserting =
false;
567 self_[index].owner =
this;
568 self_[index].pos = index;
570 if (data_->sorted)
sort();
577 template<
class ...args_t>
578 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add - Will be removed in version 0.4.0.")]]
580 data_->items.emplace_back(args...);
581 size_t index = data_->items.size() - 1;
582 self_[index].owner =
this;
583 self_[index].pos = index;
585 if (data_->sorted)
sort();
591 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::remove_at - Will be removed in version 0.4.0.")]]
594 data_->erasing =
true;
595 auto result =
items().erase(pos);
596 data_->erasing =
false;
602 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::remove_at - Will be removed in version 0.4.0.")]]
605 data_->erasing =
true;
606 auto result =
items().erase(pos);
607 data_->erasing =
false;
615 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::remove_at - Will be removed in version 0.4.0.")]]
617 auto result =
items().end();
627 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::remove_at - Will be removed in version 0.4.0.")]]
629 auto result =
items().end();
639 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::remove_at - Will be removed in version 0.4.0.")]]
648 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::insert - Will be removed in version 0.4.0.")]]
650 auto index = pos -
items().begin();
651 data_->inserting =
true;
652 auto result =
items().insert(pos, value);
653 data_->inserting =
false;
654 self_[index].owner =
this;
655 self_[index].pos = index;
657 if (data_->sorted)
sort();
664 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::insert - Will be removed in version 0.4.0.")]]
666 auto index = pos -
items().begin();
667 data_->inserting =
true;
668 auto result =
items().insert(pos, value);
669 data_->inserting =
false;
670 self_[index].owner =
this;
671 self_[index].pos = index;
673 if (data_->sorted)
sort();
681 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::insert - Will be removed in version 0.4.0.")]]
688 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::remove(count() - 1) - Will be removed in version 0.4.0.")]]
696 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add - Will be removed in version 0.4.0.")]]
703 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add - Will be removed in version 0.4.0.")]]
705 add(std::move(item));
711 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add_range - Will be removed in version 0.4.0.")]]
718 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add_range - Will be removed in version 0.4.0.")]]
725 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add_range - Will be removed in version 0.4.0.")]]
732 template<
class collection_t>
733 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add_range - Will be removed in version 0.4.0.")]]
740 template<
class iterator_t>
741 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::add_range - Will be removed in version 0.4.0.")]]
749 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::to_array - Will be removed in version 0.4.0.")]]
755 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().rbegin - Will be removed in version 0.4.0.")]]
756 auto rbegin() noexcept {
return data_->items.rbegin();}
760 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().rbegin - Will be removed in version 0.4.0.")]]
761 auto rbegin() const noexcept {
return data_->items.rbegin();}
766 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().rend - Will be removed in version 0.4.0.")]]
767 auto rend() noexcept {
return data_->items.rend();}
771 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().rend - Will be removed in version 0.4.0.")]]
772 auto rend() const noexcept {
return data_->items.rend();}
776 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().reserve - Will be removed in version 0.4.0.")]]
781 [[deprecated(
"Replaced by xtd::forms::layout::arranged_element_collection::items().shrink_to_fit - Will be removed in version 0.4.0.")]]
806 bool is_read_only() const noexcept
override {
return false;}
807 bool is_synchronized() const noexcept
override {
return false;}
808 const xtd::object& sync_root() const noexcept
override {
return data_->sync_root;}
810 struct data_collection {
811 mutable xtd::collections::generic::list < value_type > items;
812 bool inserting =
false;
813 bool erasing =
false;
Provides methods for creating, manipulating, searching, and sorting arrays, thereby serving as the ba...
Definition array.hpp:64
virtual const base_type & items() const noexcept
Returns the underlying base type items.
Definition basic_array.hpp:113
static constexpr size_t max_value
Definition box_integer.hpp:67
Exposes the enumerator, which supports a simple iteration over a collection of a specified type.
Definition ienumerable.hpp:40
Supports a simple iteration over a generic collection.
Definition ienumerator.hpp:58
Represents a strongly typed list of objects that can be accessed by index. Provides methods to search...
Definition list.hpp:80
typename xtd::collections::generic::helpers::raw_array< value_type >::base_type base_type
Represents the list base type.
Definition list.hpp:88
const auto & items() const noexcept
Returns the underlying base type items.
Definition list.hpp:251
Provides the base class for a generic read-only collection.
Definition read_only_collection.hpp:38
static void throws(xtd::helpers::exception_case exception_case, const source_location &location=source_location::current())
Throws an exption with specified exception case.
Supports all classes in the xtd class hierarchy and provides low-level services to derived classes....
Definition object.hpp:44
object()=default
Create a new instance of the ultimate base class object.
Represents the version number of an assembly, operating system, or the xtd. This class cannot be inhe...
Definition version.hpp:115
@ index_out_of_range
The index is out of range.
Definition exception_case.hpp:61
@ 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
constexpr xtd::size npos
Represents a value that is not a valid position in a collection.
Definition npos.hpp:26
size_t size
Represents a size of any object in bytes.
Definition size.hpp:23
xtd::sptr< type_t > ptr
The xtd::ptr object is a shared pointer.
Definition ptr.hpp:27
ptr< type_t > new_ptr(args_t &&... args)
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
The xtd namespace contains all fundamental classes to access Hardware, Os, System,...
Definition abstract_object.hpp:8
const_iterator begin() const
Returns an iterator to the beginning.
Definition read_only_span.hpp:183
read_only_span< type_t, count > first() const
Obtains a subspan consisting of the first count elements of the sequence.
Definition read_only_span.hpp:282
read_only_span< type_t, count > last() const
Obtains a subspan consisting of the last N elements of the sequence.
Definition read_only_span.hpp:307
Contains xtd::forms::layout::sorter_none class.
Supports a simple iteration over a generic collection.
Definition enumerator.hpp:38
Implements a function object for performing comparisons. Unless specialised, invokes operator== on ty...
Definition equator.hpp:39
Contains xtd::helpers::throw_helper class.