Испраивл недочёты

This commit is contained in:
Максим Егоров 2024-08-29 21:57:17 +04:00
parent 62a2bf7716
commit 9010db3b24
2 changed files with 36 additions and 34 deletions

View File

@ -128,7 +128,7 @@ namespace Sailboat.Generics
/// Загрузка информации по лодкам в хранилище из файла /// Загрузка информации по лодкам в хранилище из файла
/// </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))
@ -136,50 +136,52 @@ namespace Sailboat.Generics
return false; return false;
} }
using (StreamReader bs = File.OpenText(filename)) string bufferTextFromFile = "";
using (FileStream fs = new(filename, FileMode.Open))
{ {
string str = bs.ReadLine(); byte[] b = new byte[fs.Length];
if (str == null || str.Length == 0) UTF8Encoding temp = new(true);
while (fs.Read(b, 0, b.Length) > 0)
{ {
return false; bufferTextFromFile += temp.GetString(b);
} }
if (!str.StartsWith("BoatStorage")) }
var strs = bufferTextFromFile.Split(new char[] { '\n', '\r' },
StringSplitOptions.RemoveEmptyEntries);
if (strs == null || strs.Length == 0)
{
return false;
}
if (!strs[0].StartsWith("BoatStorage"))
{
//если нет такой записи, то это не те данные
return false;
}
_boatStorages.Clear();
foreach (string data in strs)
{
string[] record = data.Split(_separatorForKeyValue, StringSplitOptions.RemoveEmptyEntries);
if (record.Length != 2)
{ {
return false; continue;
} }
BoatsGenericCollection<DrawingBoat, DrawingObjectBoat> collection = new(_pictureWidth, _pictureHeight);
_boatStorages.Clear(); string[] set = record[1].Split(_separatorRecords, StringSplitOptions.RemoveEmptyEntries);
string strs = ""; foreach (string elem in set)
while ((strs = bs.ReadLine()) != null)
{ {
if (strs == null) DrawingBoat? boat = elem?.CreateDrawingBoat(_separatorForObject, _pictureWidth, _pictureHeight);
if (boat != null)
{ {
return false; if (!(collection + boat))
}
string[] record = strs.Split(_separatorForKeyValue, StringSplitOptions.RemoveEmptyEntries);
if (record.Length != 2)
{
continue;
}
BoatsGenericCollection<DrawingBoat, DrawingObjectBoat> collection = new(_pictureWidth, _pictureHeight);
string[] set = record[1].Split(_separatorRecords, StringSplitOptions.RemoveEmptyEntries);
foreach (string elem in set)
{
DrawingBoat? boat = elem?.CreateDrawingBoat(_separatorForObject, _pictureWidth, _pictureHeight);
if (boat != null)
{ {
if (!(collection + boat)) return false;
{
return false;
}
} }
} }
_boatStorages.Add(record[0], collection);
} }
return true; _boatStorages.Add(record[0], collection);
} }
return true;
} }
} }
} }

View File

@ -40,7 +40,7 @@ namespace Sailboat.DrawingObjects
/// <summary> /// <summary>
/// Получение данных для сохранения в файл /// Получение данных для сохранения в файл
/// </summary> /// </summary>
/// <param name="drawningCar">Сохраняемый объект</param> /// <param name="drawningBoat">Сохраняемый объект</param>
/// <param name="separatorForObject">Разделитель даннных</param> /// <param name="separatorForObject">Разделитель даннных</param>
/// <returns>Строка с данными по объекту</returns> /// <returns>Строка с данными по объекту</returns>
public static string GetDataForSave(this DrawingBoat drawingBoat, char separatorForObject) public static string GetDataForSave(this DrawingBoat drawingBoat, char separatorForObject)