using ProjectStormtrooper.Drawnings; using ProjectStormtrooper.Exceptions; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace ProjectStormtrooper.CollectionGenericObjects; /// /// Параметрический набор объектов /// /// Параметр: ограничение - ссылочный тип public class MassiveGenericObjects : ICollectionGenericObjects where T : class { /// /// Массив объекта, которые храним /// private T?[] _collection; public int Count => _collection.Length; public int MaxCount { get { return _collection.Length; } set { if (value > 0) { if (_collection.Length > 0) { Array.Resize(ref _collection, value); } else { _collection = new T?[value]; } } } } public CollectionType GetCollectionType => CollectionType.Massive; /// /// Конструктор /// public MassiveGenericObjects() { _collection = Array.Empty(); } public T? Get(int position) { // проверка позиции if (position >= _collection.Length || position < 0) throw new PositionOutOfCollectionException(position); if (_collection[position] == null) throw new ObjectNotFoundException(position); return _collection[position]; } public int Insert(T obj, IEqualityComparer? comparer = null) { if (comparer != null) { foreach(T? item in _collection) { if ((comparer as IEqualityComparer).Equals(obj as DrawningStormtrooperBase, item as DrawningStormtrooperBase)) throw new ObjectIsEqualException(); } } // TODO вставка в свободное место набора int index = 0; while ( index < _collection.Length) { if (_collection[index] == null) { _collection[index] = obj; return index; } index++; } throw new CollectionOverflowException(Count); } public int Insert(T obj, int position, IEqualityComparer? comparer = null) { // TODO проверка позиции // TODO проверка, что элемент массива по этой позиции пустой, если нет, то // ищется свободное место после этой позиции и идет вставка туда // если нет после, ищем до // TODO вставка if (comparer != null) { foreach (T? item in _collection) { if ((comparer as IEqualityComparer).Equals(obj as DrawningStormtrooperBase, item as DrawningStormtrooperBase)) throw new ObjectIsEqualException(); } } if (position >= _collection.Length || position < 0) throw new PositionOutOfCollectionException(position); if (_collection[position] == null) { _collection[position] = obj; return position; } int index = position + 1; while(index < _collection.Length) { if (_collection[index] == null) { _collection[index] = obj; return index; } index++; } index = position - 1; while ( index >= 0) { if (_collection[index] == null) { _collection[index] = obj; return index; } index--; } throw new CollectionOverflowException(Count); } public T? Remove(int position) { // TODO проверка позиции // TODO удаление объекта из массива, присвоив элементу массива значение null if (position >= _collection.Length || position < 0) throw new PositionOutOfCollectionException(position); if (_collection[position] == null) throw new ObjectNotFoundException(position); T temp = _collection[position]; _collection[position] = null; return temp; } public IEnumerable GetItems() { for (int i = 0; i < _collection.Length; ++i) { yield return _collection[i]; } } void ICollectionGenericObjects.CollectionSort(IComparer comparer) { Array.Sort(_collection, comparer); } }