#logging #basic #stdout #init

smlog

A very basic stdout logging implementation

3 releases

0.1.4 Nov 19, 2024
0.1.3 Nov 19, 2024
0.1.2 Nov 19, 2024
0.1.1 Nov 19, 2024
0.1.0 Nov 19, 2024

#20 in #init

Download history 209/week @ 2024-11-13 194/week @ 2024-11-20 303/week @ 2024-11-27 183/week @ 2024-12-04 320/week @ 2024-12-11 235/week @ 2024-12-18 4/week @ 2024-12-25 35/week @ 2025-01-01 32/week @ 2025-01-08

312 downloads per month
Used in rawbit

MIT license

5KB

smlog: a lightweight and very basic stdout logging implementation

Useful for basic human-readable logging, and not much else

Rather than other logging implementations, this logger is extremely opinionated for the sake of simplicity. The lack of choice means that you should be able to call smlog::Log::init(...) once in main and immediately start logging using log's logging macros, without adding a significant amount of bloat to your project.

Log formatting

Your log statements will look extremely basic:

  • info!(...) prints info: ...
  • warn!(...) prints warning: ...
  • error!(...) prints error: ...
  • debug!(...) prints debug: ...
  • trace!(...) prints trace: ...

but sometimes, that's all you really need.

Examples:

Basic logging

use smlog::{log::{info, error}, Log, LevelFilter};

fn main() {
    Log::init(LevelFilter::Info);

    info!("Hello, world!");
    // Outputs `info: Hello, world!`

    error!("Goodbye, world!");
    // Outputs `error: Goodbye, world!`
}

Dependencies

~87KB