20240326
This commit is contained in:
@@ -1,63 +0,0 @@
|
||||
using anbs_cp.Interfaces;
|
||||
|
||||
namespace anbs_cp.Classes;
|
||||
|
||||
/// <summary>
|
||||
/// Класс ошибки
|
||||
/// </summary>
|
||||
public sealed class ActionError: IActionError
|
||||
{
|
||||
/// <summary>
|
||||
/// Критичность ошибки:
|
||||
/// при некритичных ошибках продолжение выполнения операции возможно,
|
||||
/// а при критичных -- нет
|
||||
/// </summary>
|
||||
public bool IsCritical { get; init; }
|
||||
|
||||
/// <summary>
|
||||
/// Объект ошибки
|
||||
/// </summary>
|
||||
public object Object { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Сообщение об ошибке
|
||||
/// </summary>
|
||||
public string Message { get; set; }
|
||||
|
||||
#region Конструкторы
|
||||
/// <summary>
|
||||
/// Конструктор по умолчанию
|
||||
/// </summary>
|
||||
public ActionError ()
|
||||
{
|
||||
IsCritical = true;
|
||||
Object = "Not Implemented";
|
||||
Message = "Not Implemented";
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор с 2 параметрами
|
||||
/// </summary>
|
||||
/// <param name="message">Сообщение</param>
|
||||
/// <param name="isCritical">Критичность ошибки</param>
|
||||
public ActionError (string message, bool isCritical = true)
|
||||
{
|
||||
IsCritical = isCritical;
|
||||
Object = "";
|
||||
Message = message;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор с 3 параметрами
|
||||
/// </summary>
|
||||
/// <param name="eObject">Объект ошибки</param>
|
||||
/// <param name="message">Сообщение</param>
|
||||
/// <param name="isCritical">Критичность ошибки</param>
|
||||
public ActionError (object eObject, string message, bool isCritical = true)
|
||||
{
|
||||
IsCritical = isCritical;
|
||||
Object = eObject;
|
||||
Message = message;
|
||||
}
|
||||
#endregion
|
||||
}
|
@@ -1,49 +0,0 @@
|
||||
using anbs_cp.Interfaces;
|
||||
|
||||
namespace anbs_cp.Classes;
|
||||
|
||||
/// <summary>
|
||||
/// Класс предупреждения
|
||||
/// </summary>
|
||||
public sealed class ActionInfo: IActionInfo
|
||||
{
|
||||
#region Конструкторы
|
||||
/// <summary>
|
||||
/// Конструктор по умолчанию
|
||||
/// </summary>
|
||||
public ActionInfo ()
|
||||
{
|
||||
IsStatusInfo = false;
|
||||
Object = string.Empty;
|
||||
Message = string.Empty;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор
|
||||
/// </summary>
|
||||
/// <param name="eObject">Объект</param>
|
||||
/// <param name="message">Сообщение</param>
|
||||
/// <param name="isStatus">Является статусной информацией?</param>
|
||||
public ActionInfo (string eObject, string message, bool isStatus = false)
|
||||
{
|
||||
IsStatusInfo = isStatus;
|
||||
Object = eObject;
|
||||
Message = message;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region Реализация интерфейса
|
||||
/// <summary>
|
||||
/// Объект
|
||||
/// </summary>
|
||||
public object Object { get; set; }
|
||||
/// <summary>
|
||||
/// Сообщение
|
||||
/// </summary>
|
||||
public string Message { get; set; }
|
||||
/// <summary>
|
||||
/// Статусная информация (например, начало работы)
|
||||
/// </summary>
|
||||
public bool IsStatusInfo { get; init; }
|
||||
#endregion
|
||||
}
|
@@ -1,10 +1,16 @@
|
||||
using anbs_cp.Interfaces;
|
||||
// ReSharper disable MemberCanBePrivate.Global
|
||||
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
||||
using anbs_cp.Enums;
|
||||
using anbs_cp.Interfaces;
|
||||
|
||||
namespace anbs_cp.Classes;
|
||||
|
||||
/*
|
||||
История версий
|
||||
|
||||
Обновлено 2024.03.26
|
||||
* Все интерфейсы объеденены в один IActionStateMessage
|
||||
|
||||
Обновлено 2023.12.10
|
||||
* Заменены классы Action* на соответствующие интерфейсы
|
||||
* Класс ActionState теперь наследует интерфейс IActionState, позволяющий добавлять состояния (ошибки, предупреждения и информацию)
|
||||
@@ -50,17 +56,17 @@ public class ActionState<T>: IActionState
|
||||
/// <summary>
|
||||
/// Список информации
|
||||
/// </summary>
|
||||
public List<IActionInfo> Info { get; }
|
||||
public List<IActionStateMessage> Info { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Список предупреждений
|
||||
/// </summary>
|
||||
public List<IActionWarning> Warnings { get; }
|
||||
public List<IActionStateMessage> Warnings { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Список ошибок
|
||||
/// </summary>
|
||||
public List<IActionError> Errors { get; }
|
||||
public List<IActionStateMessage> Errors { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Значение
|
||||
@@ -115,13 +121,13 @@ public class ActionState<T>: IActionState
|
||||
/// <param name="error">Ошибка</param>
|
||||
// ReSharper disable once MemberCanBeMadeStatic.Global
|
||||
// ReSharper disable once FunctionRecursiveOnAllPaths
|
||||
public void AddError (IActionError error) => Errors.Add(error);
|
||||
public void AddError (IActionStateMessage error) => Errors.Add(error);
|
||||
|
||||
/// <summary>
|
||||
/// Добавляет ошибки в список
|
||||
/// </summary>
|
||||
/// <param name="errors">Список ошибок</param>
|
||||
public void AddErrors (IEnumerable<IActionError> errors) => Errors.AddRange(errors);
|
||||
public void AddErrors (IEnumerable<IActionStateMessage> errors) => Errors.AddRange(errors);
|
||||
|
||||
/// <summary>
|
||||
/// Добавление ошибки
|
||||
@@ -130,7 +136,7 @@ public class ActionState<T>: IActionState
|
||||
public void AddError (bool critical = true)
|
||||
{
|
||||
//Создаю ошибку
|
||||
ActionError error = new("", critical);
|
||||
ActionStateMessage error = new("", critical);
|
||||
|
||||
//Добавляю ошибку
|
||||
AddError(error);
|
||||
@@ -144,7 +150,7 @@ public class ActionState<T>: IActionState
|
||||
public void AddError (string message, bool critical = true)
|
||||
{
|
||||
//Создаю ошибку
|
||||
ActionError error = new(message, critical);
|
||||
ActionStateMessage error = new(message, critical);
|
||||
|
||||
//Добавляю ошибку
|
||||
AddError(error);
|
||||
@@ -159,7 +165,7 @@ public class ActionState<T>: IActionState
|
||||
public void AddError (string errorObject, string message, bool critical = true)
|
||||
{
|
||||
//Создаю ошибку
|
||||
ActionError error = new(errorObject, message, critical);
|
||||
ActionStateMessage error = new(errorObject, message, critical);
|
||||
|
||||
//Добавляю ошибку
|
||||
AddError(error);
|
||||
@@ -171,13 +177,13 @@ public class ActionState<T>: IActionState
|
||||
/// Добавление предупреждения
|
||||
/// </summary>
|
||||
/// <param name="warning">Предупреждение</param>
|
||||
public void AddWarning (IActionWarning warning) => Warnings.Add(warning);
|
||||
public void AddWarning (IActionStateMessage warning) => Warnings.Add(warning);
|
||||
|
||||
/// <summary>
|
||||
/// Добавление предупреждений
|
||||
/// </summary>
|
||||
/// <param name="warnings">Список предупреждений</param>
|
||||
public void AddWarnings (IEnumerable<IActionWarning> warnings) => Warnings.AddRange(warnings);
|
||||
public void AddWarnings (IEnumerable<IActionStateMessage> warnings) => Warnings.AddRange(warnings);
|
||||
|
||||
/// <summary>
|
||||
/// Добавление предупреждение
|
||||
@@ -187,7 +193,7 @@ public class ActionState<T>: IActionState
|
||||
public void AddWarning (string message, string warningObject = "")
|
||||
{
|
||||
//Создаю предупреждение
|
||||
ActionWarning warning = new(warningObject, message);
|
||||
ActionStateMessage warning = new(warningObject, message);
|
||||
|
||||
//Добавляю предупреждение
|
||||
AddWarning(warning);
|
||||
@@ -199,13 +205,13 @@ public class ActionState<T>: IActionState
|
||||
/// Добавление информации
|
||||
/// </summary>
|
||||
/// <param name="info">Информация</param>
|
||||
public void AddInfo (IActionInfo info) => Info.Add(info);
|
||||
public void AddInfo (IActionStateMessage info) => Info.Add(info);
|
||||
|
||||
/// <summary>
|
||||
/// Добавление информации
|
||||
/// </summary>
|
||||
/// <param name="infos">Список информации</param>
|
||||
public void AddInfos (IEnumerable<IActionInfo> infos) => Info.AddRange(infos);
|
||||
public void AddInfos (IEnumerable<IActionStateMessage> infos) => Info.AddRange(infos);
|
||||
|
||||
/// <summary>
|
||||
/// Добавление информации
|
||||
@@ -215,7 +221,7 @@ public class ActionState<T>: IActionState
|
||||
public void AddInfo (string message, string infoObject = "")
|
||||
{
|
||||
//Создаю информацию
|
||||
ActionInfo info = new(infoObject, message);
|
||||
ActionStateMessage info = new(infoObject, message);
|
||||
|
||||
//Добавляю информацию
|
||||
AddInfo(info);
|
||||
@@ -224,50 +230,46 @@ public class ActionState<T>: IActionState
|
||||
|
||||
#region Печать
|
||||
/// <summary>
|
||||
/// Печать списка ошибок
|
||||
/// Печать сообщений
|
||||
/// </summary>
|
||||
/// <param name="formatList">Формат списка</param>
|
||||
/// <param name="formatItem">Формат элемента списка</param>
|
||||
/// <returns>Список ошибок в текстовой форме</returns>
|
||||
public string PrintErrorList (string formatList, string formatItem)
|
||||
/// <param name="area">Область печати</param>
|
||||
/// <param name="formatList">Оформление всей области</param>
|
||||
/// <param name="formatItem">Оформление элемента</param>
|
||||
/// <returns>Текстовое представление выбранных списокв</returns>
|
||||
/// <exception cref="ArgumentOutOfRangeException">Ошибка при неизвестной области</exception>
|
||||
public string PrintMessage (EActionStatePrintArea area, string formatList, string formatItem)
|
||||
{
|
||||
// Создаю список
|
||||
List<IActionStateMessage> list = [];
|
||||
|
||||
// Выбираю списки по областям
|
||||
switch (area)
|
||||
{
|
||||
case EActionStatePrintArea.All:
|
||||
list.AddRange(Errors);
|
||||
list.AddRange(Warnings);
|
||||
list.AddRange(Info);
|
||||
break;
|
||||
case EActionStatePrintArea.ErrorsAndWarnings:
|
||||
list.AddRange(Errors);
|
||||
list.AddRange(Warnings);
|
||||
break;
|
||||
case EActionStatePrintArea.ErrorsOnly:
|
||||
list.AddRange(Errors);
|
||||
break;
|
||||
case EActionStatePrintArea.WarningsOnly:
|
||||
list.AddRange(Warnings);
|
||||
break;
|
||||
case EActionStatePrintArea.InfosOnly:
|
||||
list.AddRange(Info);
|
||||
break;
|
||||
default:
|
||||
throw new ArgumentOutOfRangeException(nameof(area), area, null);
|
||||
}
|
||||
|
||||
// Создаю элементы
|
||||
string elements =
|
||||
#pragma warning disable CS8625
|
||||
Errors.Aggregate<IActionError, string>(null, (current, error) => current + error.PrintMessage(formatItem));
|
||||
#pragma warning restore CS8625
|
||||
|
||||
return string.Format(formatList, elements);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Печать списка предупреждений
|
||||
/// </summary>
|
||||
/// <param name="formatList">Формат списка</param>
|
||||
/// <param name="formatItem">Формат элемента списка</param>
|
||||
/// <returns>Список предупреждений в текстовой форме</returns>
|
||||
public string PrintWarningList (string formatList, string formatItem)
|
||||
{
|
||||
string elements =
|
||||
#pragma warning disable CS8625
|
||||
Warnings.Aggregate<IActionWarning, string>(null,
|
||||
#pragma warning restore CS8625
|
||||
(current, warning) => current + warning.PrintMessage(formatItem));
|
||||
|
||||
return string.Format(formatList, elements);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Печать списка информации
|
||||
/// </summary>
|
||||
/// <param name="formatList">Формат списка</param>
|
||||
/// <param name="formatItem">Формат элемента списка</param>
|
||||
/// <returns>Список информации в текстовой форме</returns>
|
||||
public string PrintInfoList (string formatList, string formatItem)
|
||||
{
|
||||
string elements =
|
||||
#pragma warning disable CS8625
|
||||
Info.Aggregate<IActionInfo, string>(null, (current, info) => current + info.PrintMessage(formatItem));
|
||||
#pragma warning restore CS8625
|
||||
list.Aggregate(string.Empty, (current, item) => current + item.PrintMessage(formatItem));
|
||||
|
||||
return string.Format(formatList, elements);
|
||||
}
|
||||
@@ -288,7 +290,7 @@ public class ActionState<T>: IActionState
|
||||
/// <param name="ignoreInformWarning">Игнорировать информационные предупреждения</param>
|
||||
/// <returns>Наличие предупреждений</returns>
|
||||
public bool HasWarnings (bool ignoreInformWarning = false) => ignoreInformWarning
|
||||
? Warnings.Any(static warning => !warning.IsInformWarning)
|
||||
? Warnings.Any(static warning => warning.IsCritical)
|
||||
: Warnings.Any();
|
||||
|
||||
/// <summary>
|
||||
@@ -296,7 +298,7 @@ public class ActionState<T>: IActionState
|
||||
/// </summary>
|
||||
/// <param name="ignoreStatus">Игнорировать статусные сообщения</param>
|
||||
/// <returns>Наличие сообщений</returns>
|
||||
public bool HasInfo (bool ignoreStatus) => ignoreStatus ? Info.Any(static info => !info.IsStatusInfo) : Info.Any();
|
||||
public bool HasInfo (bool ignoreStatus) => ignoreStatus ? Info.Any(static info => info.IsCritical) : Info.Any();
|
||||
|
||||
/// <summary>
|
||||
/// Успешно ли завершилось
|
||||
@@ -320,7 +322,7 @@ public class ActionState<T>: IActionState
|
||||
/// <param name="ignoreInformWarning">Игнорировать информационные предупреждения</param>
|
||||
/// <returns>Количество предупреждений</returns>
|
||||
public int WarningsCount (bool ignoreInformWarning = false) => ignoreInformWarning
|
||||
? Warnings.Count(static warning => !warning.IsInformWarning)
|
||||
? Warnings.Count(static warning => warning.IsCritical)
|
||||
: Warnings.Count;
|
||||
|
||||
/// <summary>
|
||||
@@ -328,7 +330,9 @@ public class ActionState<T>: IActionState
|
||||
/// </summary>
|
||||
/// <param name="ignoreStatus">Игнорировать статусные сообщения</param>
|
||||
/// <returns>Количество информационных сообщений</returns>
|
||||
public int InfoCount (bool ignoreStatus) => ignoreStatus ? Info.Count(static info => !info.IsStatusInfo) : Info.Count;
|
||||
public int InfoCount (bool ignoreStatus) => ignoreStatus
|
||||
? Info.Count(static info => info.IsCritical)
|
||||
: Info.Count;
|
||||
#endregion
|
||||
|
||||
#region Добавление другого состояния
|
||||
|
71
anbs_cp/Classes/ActionStateMessage.cs
Normal file
71
anbs_cp/Classes/ActionStateMessage.cs
Normal file
@@ -0,0 +1,71 @@
|
||||
using anbs_cp.Interfaces;
|
||||
|
||||
namespace anbs_cp.Classes;
|
||||
|
||||
/// <inheritdoc />
|
||||
public sealed class ActionStateMessage: IActionStateMessage
|
||||
{
|
||||
/// <inheritdoc />
|
||||
public bool IsCritical { get; set; }
|
||||
|
||||
/// <inheritdoc />
|
||||
public object Object { get; set; }
|
||||
|
||||
/// <inheritdoc />
|
||||
public string Message { get; set; }
|
||||
|
||||
#region Конструкторы
|
||||
/// <summary>
|
||||
/// Конструктор по умолчанию
|
||||
/// </summary>
|
||||
// ReSharper disable once MemberCanBePrivate.Global
|
||||
public ActionStateMessage ()
|
||||
{
|
||||
IsCritical = true;
|
||||
Object = "Not Implemented";
|
||||
Message = "Not Implemented";
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор с 2 параметрами
|
||||
/// </summary>
|
||||
/// <param name="message">Сообщение</param>
|
||||
/// <param name="isCritical">Критичность сообщения</param>
|
||||
public ActionStateMessage (string message, bool isCritical = true)
|
||||
{
|
||||
IsCritical = isCritical;
|
||||
Object = "";
|
||||
Message = message;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор с 3 параметрами
|
||||
/// </summary>
|
||||
/// <param name="eObject">Объект сообщения</param>
|
||||
/// <param name="message">Сообщение</param>
|
||||
/// <param name="isCritical">Критичность сообщения</param>
|
||||
public ActionStateMessage (object eObject, string message, bool isCritical = true)
|
||||
{
|
||||
IsCritical = isCritical;
|
||||
Object = eObject;
|
||||
Message = message;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region Реализация интерфейса ISerializable
|
||||
/// <inheritdoc />
|
||||
public string Serialize () => new SysTextSerializer().Serialize(this);
|
||||
|
||||
/// <inheritdoc />
|
||||
public void Deserialize (string json)
|
||||
{
|
||||
// Десериализую строку
|
||||
ActionStateMessage item = new SysTextSerializer().Deserialize<ActionStateMessage>(json) ?? new();
|
||||
|
||||
// Передаю параметры
|
||||
IsCritical = item.IsCritical;
|
||||
Object = item.Object;
|
||||
Message = item.Message;
|
||||
}
|
||||
#endregion
|
||||
}
|
@@ -1,49 +0,0 @@
|
||||
using anbs_cp.Interfaces;
|
||||
|
||||
namespace anbs_cp.Classes;
|
||||
|
||||
/// <summary>
|
||||
/// Класс предупреждения
|
||||
/// </summary>
|
||||
public sealed class ActionWarning: IActionWarning
|
||||
{
|
||||
#region Конструкторы
|
||||
/// <summary>
|
||||
/// Конструктор по умолчанию
|
||||
/// </summary>
|
||||
public ActionWarning ()
|
||||
{
|
||||
IsInformWarning = false;
|
||||
Object = string.Empty;
|
||||
Message = string.Empty;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор
|
||||
/// </summary>
|
||||
/// <param name="eObject">Объект</param>
|
||||
/// <param name="message">Сообщение</param>
|
||||
/// <param name="isInform">Является ли информирующим предупреждением</param>
|
||||
public ActionWarning (string eObject, string message, bool isInform = false)
|
||||
{
|
||||
IsInformWarning = isInform;
|
||||
Object = eObject;
|
||||
Message = message;
|
||||
}
|
||||
#endregion
|
||||
|
||||
#region Реализация интерфейса
|
||||
/// <summary>
|
||||
/// Объект
|
||||
/// </summary>
|
||||
public object Object { get; set; }
|
||||
/// <summary>
|
||||
/// Сообщение
|
||||
/// </summary>
|
||||
public string Message { get; set; }
|
||||
/// <summary>
|
||||
/// Информирующее предупреждение возникает для предупреждения ВОЗМОЖНОЙ ошибки в дальнейшей эксплуатации и не влияет на текущую операцию.
|
||||
/// </summary>
|
||||
public bool IsInformWarning { get; init; }
|
||||
#endregion
|
||||
}
|
@@ -19,7 +19,7 @@ public sealed class ConsoleParamsParser (IEnumerable<string> consoleParams)
|
||||
private static KeyValueList<string, string?> ParseConsoleParams (IEnumerable<string> paramsList)
|
||||
{
|
||||
//Создаю список параметров
|
||||
KeyValueList<string, string?> result = new();
|
||||
KeyValueList<string, string?> result = [];
|
||||
|
||||
//Заполняю его
|
||||
foreach (string consoleParam in paramsList)
|
||||
@@ -61,6 +61,6 @@ public sealed class ConsoleParamsParser (IEnumerable<string> consoleParams)
|
||||
/// Получает список всех параметров
|
||||
/// </summary>
|
||||
/// <returns>Список всех параметров</returns>
|
||||
public List<string?> GetParamsList () =>
|
||||
_paramsList.Select(static keyValue => keyValue.Key?.ToLower()).ToList();
|
||||
public List<string> GetParamsList () =>
|
||||
_paramsList.Select(static keyValue => keyValue.Key.ToLower()).ToList();
|
||||
}
|
@@ -10,7 +10,7 @@ public static class FileExtension
|
||||
/// </summary>
|
||||
/// <param name="filename">Имя файла</param>
|
||||
/// <returns>MIME-тип файла</returns>
|
||||
public static string MIMEType (string filename) =>
|
||||
public static string MimeType (string filename) =>
|
||||
MimeTypes.GetMimeType(filename);
|
||||
|
||||
/// <summary>
|
||||
|
Reference in New Issue
Block a user