joat_logger/
logger.rs

1// Copyright (c) 2023 Richard Cook
2//
3// Permission is hereby granted, free of charge, to any person obtaining
4// a copy of this software and associated documentation files (the
5// "Software"), to deal in the Software without restriction, including
6// without limitation the rights to use, copy, modify, merge, publish,
7// distribute, sublicense, and/or sell copies of the Software, and to
8// permit persons to whom the Software is furnished to do so, subject to
9// the following conditions:
10//
11// The above copyright notice and this permission notice shall be
12// included in all copies or substantial portions of the Software.
13//
14// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21//
22use crate::state::State;
23use log::{Log, Metadata, Record};
24use std::sync::Arc;
25
26pub(crate) struct Logger {
27    state: Arc<State>,
28}
29
30impl Logger {
31    pub(crate) fn new(state: Arc<State>) -> Self {
32        Self { state }
33    }
34}
35
36impl Log for Logger {
37    fn enabled(&self, _metadata: &Metadata) -> bool {
38        true
39    }
40
41    fn flush(&self) {}
42
43    fn log(&self, record: &Record) {
44        self.state
45            .print(&format!("{} - {}", record.level(), record.args()))
46    }
47}