1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
use crate::re_exports::String;

pub trait Logger {
  fn debug(&self, message: String);

  fn info(&self, message: String);

  fn warn(&self, message: String);

  fn error(&self, message: String);

  fn raw(&self, message: String);
}

#[derive(Debug, Clone, Copy, PartialEq, Eq)]
#[repr(u8)]
pub enum LogLevel {
  Debug = 4,
  Info = 3,
  Warn = 2,
  Error = 1,
  None = 0,
}

#[macro_export]
macro_rules! create_logger_from_logger {
  ( $logger:expr, $newlines:expr ) => {
    crate::macro_helpers::with_dollar_sign! {
      ( $escape:tt ) => {
        #[allow(unused_macros)]
        macro_rules! log {
          ( $level:ident, $arg:expr ) => {
            $logger.$level($arg.into());
          };
          ( $level:ident, $escape($arg:tt)* ) => {
            $logger.$level(match $newlines {
              true => format!("{}\n", format!($escape($arg)*)),
              false => format!($escape($arg)*)
            });
          };
          () => {
            $logger.raw("".into());
          };
        }
      }
    }
  };
}

pub use create_logger_from_logger;

#[cfg(feature = "default-logger")]
pub mod default;