Доделаны требования и удалены ненужные файлы

This commit is contained in:
easynickname1 2024-05-26 21:09:44 +04:00
parent 7f7e5253a3
commit 01275ea1dd

View File

@ -116,11 +116,12 @@ public class StorageCollection<T>
File.Delete(filename); File.Delete(filename);
} }
StringBuilder sb = new(); using (StreamWriter wr = new StreamWriter(filename))
{
sb.Append(_collectionKey); wr.Write(_collectionKey);
foreach (KeyValuePair<string, ICollectionGenericObjects<T>> value in _storages) foreach (KeyValuePair<string, ICollectionGenericObjects<T>> value in _storages)
{ {
StringBuilder sb = new StringBuilder();
sb.Append(Environment.NewLine); sb.Append(Environment.NewLine);
// Не сохраняем пустые коллекции // Не сохраняем пустые коллекции
if (value.Value.Count == 0) if (value.Value.Count == 0)
@ -146,11 +147,9 @@ public class StorageCollection<T>
sb.Append(data); sb.Append(data);
sb.Append(_separatorItems); sb.Append(_separatorItems);
} }
wr.Write(sb);
}
} }
using FileStream fs = new(filename, FileMode.Create);
byte[] info = new UTF8Encoding(true).GetBytes(sb.ToString());
fs.Write(info, 0, info.Length);
return true; return true;
} }
@ -166,31 +165,23 @@ public class StorageCollection<T>
return false; return false;
} }
string bufferTextFromFile = ""; using (StreamReader sr = new StreamReader(filename))
using (FileStream fs = new(filename, FileMode.Open))
{ {
byte[] b = new byte[fs.Length]; string str = sr.ReadLine();
UTF8Encoding temp = new(true); if (str == null || str.Length == 0)
while (fs.Read(b, 0, b.Length) > 0)
{
bufferTextFromFile += temp.GetString(b);
}
}
string[] strs = bufferTextFromFile.Split(new char[] { '\n', '\r' }, StringSplitOptions.RemoveEmptyEntries);
if (strs == null || strs.Length == 0)
{ {
return false; return false;
} }
if (!strs[0].Equals(_collectionKey)) if (!str.Equals(_collectionKey))
{ {
// Если нет такой записи, то это не те данные // Если нет такой записи, то это не те данные
return false; return false;
} }
_storages.Clear(); _storages.Clear();
foreach (string data in strs) string data = "";
while ((data = sr.ReadLine()) != null)
{ {
string[] record = data.Split(_separatorForKeyValue, StringSplitOptions.RemoveEmptyEntries); string[] record = data.Split(_separatorForKeyValue, StringSplitOptions.RemoveEmptyEntries);
if (record.Length != 4) if (record.Length != 4)
@ -221,7 +212,7 @@ public class StorageCollection<T>
_storages.Add(record[0], collection); _storages.Add(record[0], collection);
} }
}
return true; return true;
} }