From be6dc557a3b819248b014992eb96c1cb21f8112b Mon Sep 17 00:00:00 2001 From: vnugent Date: Sun, 8 Jan 2023 14:44:01 -0500 Subject: Initial commit --- Utils/src/Logging/ILogProvider.cs | 79 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 Utils/src/Logging/ILogProvider.cs (limited to 'Utils/src/Logging/ILogProvider.cs') diff --git a/Utils/src/Logging/ILogProvider.cs b/Utils/src/Logging/ILogProvider.cs new file mode 100644 index 0000000..55dbd6f --- /dev/null +++ b/Utils/src/Logging/ILogProvider.cs @@ -0,0 +1,79 @@ +/* +* Copyright (c) 2022 Vaughn Nugent +* +* Library: VNLib +* Package: VNLib.Utils +* File: ILogProvider.cs +* +* ILogProvider.cs is part of VNLib.Utils which is part of the larger +* VNLib collection of libraries and utilities. +* +* VNLib.Utils is free software: you can redistribute it and/or modify +* it under the terms of the GNU General Public License as published +* by the Free Software Foundation, either version 2 of the License, +* or (at your option) any later version. +* +* VNLib.Utils is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +* General Public License for more details. +* +* You should have received a copy of the GNU General Public License +* along with VNLib.Utils. If not, see http://www.gnu.org/licenses/. +*/ + +using System; + +namespace VNLib.Utils.Logging +{ + /// + /// Self-contained logging interface that allows for applications events to be written to an + /// output source + /// + public interface ILogProvider + { + /// + /// Flushes any buffers to the output source + /// + abstract void Flush(); + + /// + /// Writes the string to the log with the specified priority log level + /// + /// The log priority level + /// The message to print + void Write(LogLevel level, string value); + /// + /// Writes the exception and optional string to the log with the specified priority log level + /// + /// The log priority level + /// An exception object to write + /// The message to print + void Write(LogLevel level, Exception exception, string value = ""); + /// + /// Writes the template string and params arguments to the log with the specified priority log level + /// + /// The log priority level + /// The log template string + /// Variable length array of objects to log with the specified templatre + void Write(LogLevel level, string value, params object?[] args); + /// + /// Writes the template string and params arguments to the log with the specified priority log level + /// + /// The log priority level + /// The log template string + /// Variable length array of objects to log with the specified templatre + void Write(LogLevel level, string value, params ValueType[] args); + + /// + /// Gets the underlying log source + /// + /// The underlying log source + object GetLogProvider(); + /// + /// Gets the underlying log source + /// + /// The underlying log source + public virtual T GetLogProvider() => (T)GetLogProvider(); + } +} -- cgit