Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sschmid/sherlog
Flexible logging for C# and Unity
https://github.com/sschmid/sherlog
dotnet logger logging tcp unity
Last synced: 7 days ago
JSON representation
Flexible logging for C# and Unity
- Host: GitHub
- URL: https://github.com/sschmid/sherlog
- Owner: sschmid
- License: mit
- Created: 2013-12-11T11:17:50.000Z (about 11 years ago)
- Default Branch: main
- Last Pushed: 2023-05-17T20:58:54.000Z (over 1 year ago)
- Last Synced: 2025-01-13T05:04:34.534Z (14 days ago)
- Topics: dotnet, logger, logging, tcp, unity
- Language: C#
- Homepage:
- Size: 2.85 MB
- Stars: 192
- Watchers: 21
- Forks: 34
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
![Sherlog-Header](https://github.com/sschmid/Sherlog/raw/main/readme/Sherlog-Banner.png)
# Sherlog – Flexible logging for C# and Unity
Sherlog is a very light logging library with a clear focus on speed,
flexibility, and extensibility. It supports local and remote logging out of
the box so you can receive log messages from other devices over the air.[![CI](https://github.com/sschmid/Sherlog/actions/workflows/ci.yml/badge.svg)](https://github.com/sschmid/Sherlog/actions/workflows/ci.yml)
[![Coverage Status](https://coveralls.io/repos/github/sschmid/Sherlog/badge.svg)](https://coveralls.io/github/sschmid/Sherlog)
[![NuGet](https://img.shields.io/nuget/dt/Sherlog)](https://www.nuget.org/packages?q=Sherlog)
[![License: MIT](https://img.shields.io/github/license/sschmid/Sherlog)](https://github.com/sschmid/Sherlog/blob/main/LICENSE.md)
[![Twitter](https://img.shields.io/twitter/follow/s_schmid)][twitter-sschmid]# Install
| | NuGet | Unity Packages on [OpenUPM](https://openupm.com) |
|:-------------------|:-----------------------------------------------------------------------------------------------------------------|:---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sherlog | [![NuGet](https://img.shields.io/nuget/v/Sherlog)](https://www.nuget.org/packages/Sherlog) | [![openupm](https://img.shields.io/npm/v/com.sschmid.sherlog?label=com.sschmid.sherlog®istry_uri=https://package.openupm.com)](https://openupm.com/packages/com.sschmid.sherlog) |
| Sherlog.Appenders | [![NuGet](https://img.shields.io/nuget/v/Sherlog.Appenders)](https://www.nuget.org/packages/Sherlog.Appenders) | [![openupm](https://img.shields.io/npm/v/com.sschmid.sherlog.appenders?label=com.sschmid.sherlog.appenders®istry_uri=https://package.openupm.com)](https://openupm.com/packages/com.sschmid.sherlog.appenders) |
| Sherlog.Formatters | [![NuGet](https://img.shields.io/nuget/v/Sherlog.Formatters)](https://www.nuget.org/packages/Sherlog.Formatters) | [![openupm](https://img.shields.io/npm/v/com.sschmid.sherlog.formatters?label=com.sschmid.sherlog.formatters®istry_uri=https://package.openupm.com)](https://openupm.com/packages/com.sschmid.sherlog.formatters) |Automated Unity Package Releases: https://github.com/sschmid/com.sschmid.sherlog
# Quick Start
The SherlogSamples project contains samples for different use cases,
such as logging to the console, adding colors or timestamps,
and sending log messages via TCP to other devices.### See [SherlogSamples](https://github.com/sschmid/Sherlog/blob/main/samples/SherlogSamples/Program.cs)
```
dotnet run --project samples/SherlogSamples/SherlogSamples.csproj
```Run the SherlogServer project to receive the sample log messages
from SherlogSamples via a TCP connection.### See [SherlogServer](https://github.com/sschmid/Sherlog/blob/main/samples/SherlogServer/Program.cs)
```
dotnet run --project samples/SherlogServer/SherlogServer.csproj listen 12345
```![SherlogSamples](https://github.com/sschmid/Sherlog/raw/main/readme/SherlogSamples.png)
# Sherlog terminology
## LogLevel
There are 6 [log levels](https://github.com/sschmid/Sherlog/blob/main/src/Sherlog/src/LogLevel.cs)
matching the Sherlog log methods:```csharp
logger.Trace("This is a message using logger.Trace()");
logger.Debug("This is a message using logger.Debug()");
logger.Info("This is a message using logger.Info()");
logger.Warn("This is a message using logger.Warn()");
logger.Error("This is a message using logger.Error()");
logger.Fatal("This is a message using logger.Fatal()");
```You can set the log level per logger or globally for all existing and future loggers.
```csharp
Logger.GlobalLogLevel = LogLevel.Warn;
``````csharp
var logger = Logger.GetLogger("MyLogger");
logger.LogLevel = LogLevel.Debug;
```Only log methods that match or exceed the current log level will forward
messages to appenders.## Appenders
Sherlog's plugin architecture lets you add multiple different appenders
to handle log messages. An appender is a delegate method which contains
the logic for processing log messages. It might write a message to a file,
print it to the console or send it over the network via TCP.
You can easily write your own appenders. There are no limits!Sherlog comes with a handful of pre-made appenders and helper classes to get you started quickly:
### see [Sherlog.Appenders](https://github.com/sschmid/Sherlog/tree/main/src/Sherlog.Appenders/src)
## Formatters
Similar to appenders you can add formatters to decorate messages with additional
info like logger name, log level, timestamp, or color.### see [Sherlog.Formatters](https://github.com/sschmid/Sherlog/tree/main/src/Sherlog.Formatters/src)
# Maintainer(s)
[@sschmid on GitHub][github-sschmid] - [@s_schmid on Twitter][twitter-sschmid][github-sschmid]: https://github.com/sschmid "@sschmid"
[twitter-sschmid]: https://twitter.com/intent/follow?original_referer=https%3A%2F%2Fgithub.com%2Fsschmid%2FSherlog&screen_name=s_schmid&tw_p=followbutton "s_schmid on Twitter"