kodik-rs 0.1.0

A Rust library for getting direct links to files from Kodik.
Documentation
use log::{Level, LevelFilter, Log, Metadata, Record};

pub const CYAN: &str = "\x1b[0;36m";
pub const GREEN_HIGH_INTENSITY_BOLD: &str = "\x1b[1;92m";
pub const CYAN_HIGH_INTENSITY_BOLD: &str = "\x1b[1;96m";
pub const YELLOW_BOLD: &str = "\x1b[1;33m";
pub const RED_BOLD: &str = "\x1b[1;31m";
pub const RESET: &str = "\x1b[0m";
const BLUE_BOLD: &str = "\x1b[1;34m";
const BOLD: &str = "\x1b[1m";
const DIM: &str = "\x1b[2m";

struct KodikLogger;

impl Log for KodikLogger {
    fn enabled(&self, metadata: &Metadata) -> bool {
        metadata.level() <= log::max_level()
    }

    fn log(&self, record: &Record) {
        if !self.enabled(record.metadata()) {
            return;
        }

        if !record.target().starts_with("kodik") {
            return;
        }

        match record.level() {
            Level::Error => eprintln!("{RED_BOLD}error:{RESET} {BOLD}{}{RESET}", record.args()),
            Level::Warn => eprintln!(
                "{YELLOW_BOLD}warning:{RESET} {BOLD}{}{RESET}",
                record.args()
            ),
            Level::Info => eprintln!("{BLUE_BOLD}::{RESET} {BOLD}{}{RESET}", record.args()),
            Level::Debug => eprintln!("  {BLUE_BOLD}->{RESET} {}", record.args()),
            Level::Trace => eprintln!("{DIM}{}{RESET}", record.args()),
        }
    }

    fn flush(&self) {}
}

static LOGGER: KodikLogger = KodikLogger;

pub fn setup_logging(level_filter: LevelFilter) {
    log::set_logger(&LOGGER).ok();
    log::set_max_level(level_filter);
}