Устранение неполадок

This commit is contained in:
5_fG 2024-06-02 13:39:49 +04:00
parent 9c06d0a188
commit 786c0debb5

View File

@ -1,7 +1,5 @@
using ProjectExcavator.Drawnings; using ProjectExcavator.Drawnings;
using System.Collections.Generic;
using System.Text; using System.Text;
using System.Xml.Linq;
namespace ProjectExcavator.CollectionGenericObjects; namespace ProjectExcavator.CollectionGenericObjects;
@ -84,26 +82,27 @@ public class StorageCollection<T>
_storages.Remove(name); _storages.Remove(name);
} }
/// <summary> /// <summary>
/// Доступ к коллекции /// Доступ к коллекции
/// </summary> /// </summary>
/// <param name="name">Название коллекции</param> /// <param name="name">Название коллекции</param>
/// <returns></returns> /// <returns></returns>
public ICollectionGenericObjects<T>? this[string name] public ICollectionGenericObjects<T>? this[string name]
{ {
get get
{ {
if (name == null || !_storages.ContainsKey(name)) { return null; } if (name == null || !_storages.ContainsKey(name)) { return null; }
return _storages[name]; return _storages[name];
} }
} }
/// <summary> /// <summary>
/// Сохранение информации по автомобилям в хранилище в файл /// Сохранение информации по машинам в хранилище в файл
/// </summary> /// </summary>
/// <param name="filename">Путь и имя файла</param> /// <param name="filename">Путь и имя файла</param>
/// <returns>true - сохранение прошло успешно, false - ошибка при сохранении данных</returns> /// <returns>true - сохранение прошло успешно, false - ошибка при сохранении данных</returns>
public bool SaveData(string filename) public bool SaveData(string filename)
{ {
if (_storages.Count == 0) if (_storages.Count == 0)
@ -118,39 +117,9 @@ public class StorageCollection<T>
StringBuilder sb = new(); StringBuilder sb = new();
sb.Append(_collectionKey); using (StreamWriter fs = new StreamWriter(filename))
foreach (KeyValuePair<string, ICollectionGenericObjects<T>> value in _storages)
{ {
sb.Append(Environment.NewLine); fs.WriteLine(_collectionKey.ToString());
// не сохраняем пустые коллекции
if (value.Value.Count == 0)
{
continue;
}
sb.Append(value.Key);
sb.Append(_separatorForKeyValue);
sb.Append(value.Value.GetCollectionType);
sb.Append(_separatorForKeyValue);
sb.Append(value.Value.MaxCount);
sb.Append(_separatorForKeyValue);
foreach (T? item in value.Value.GetItems())
{
string data = item?.GetDataForSave() ?? string.Empty;
if (string.IsNullOrEmpty(data))
{
continue;
}
sb.Append(data);
sb.Append(_separatorItems);
}
}
using (StreamWriter fs = new StreamWriter(filename))
{
fs.WriteLine(_collectionKey.ToString());
foreach (KeyValuePair<string, ICollectionGenericObjects<T>> kvpair in _storages) foreach (KeyValuePair<string, ICollectionGenericObjects<T>> kvpair in _storages)
{ {
// не сохраняем пустые коллекции // не сохраняем пустые коллекции
@ -170,7 +139,7 @@ public class StorageCollection<T>
sb.Append(data); sb.Append(data);
sb.Append(_separatorItems); sb.Append(_separatorItems);
} }
fs.WriteLine(sb.ToString()); fs.WriteLine(sb.ToString());
sb.Clear(); sb.Clear();
} }
} }
@ -178,16 +147,17 @@ public class StorageCollection<T>
} }
/// <summary> /// <summary>
/// Загрузка информации по автомобилям в хранилище из файла /// Загрузка информации по машинам в хранилище из файла
/// </summary> /// </summary>
/// <param name="filename">Путь и имя файла</param> /// <param name="filename">Путь и имя файла</param>
/// <returns>true - загрузка прошла успешно, false - ошибка при загрузке данных</returns> /// <returns>true - загрузка прошла успешно, false - ошибка при загрузке данных</returns>
public bool LoadData(string filename) public bool LoadData(string filename)
{ {
if (!File.Exists(filename)) if (!File.Exists(filename))
{ {
return false; return false;
} }
using (StreamReader sr = new StreamReader(filename)) using (StreamReader sr = new StreamReader(filename))
{ {
string? str; string? str;
@ -223,6 +193,7 @@ public class StorageCollection<T>
_storages.Add(record[0], collection); _storages.Add(record[0], collection);
} }
} }
return true; return true;
} }