Struct Logger

Source
pub struct Logger { /* private fields */ }
Expand description

Configuration and state for logging USB device events.

The logger handles output formatting and can write to both console and log files simultaneously.

Implementations§

Source§

impl Logger

Source

pub fn new( output_json: bool, log_file_path: Option<&str>, colorful: bool, ) -> Result<Self, Box<dyn Error>>

Creates a new logger instance.

§Arguments
  • output_json - Whether to format output as JSON
  • log_file_path - Optional path to a log file
  • colorful - Whether to use coloured output (ignored for JSON mode)
§Errors

Returns an error if the log file cannot be created or opened.

§Examples
use usbwatch_rs::logger::Logger;

// Console-only logger with plain text and colours
let logger = Logger::new(false, None, true)?;

// JSON logger with file output
let logger = Logger::new(true, Some("usb-events.json"), true)?;
Source

pub fn log_device_event( &mut self, device_info: &UsbDeviceInfo, ) -> Result<(), Box<dyn Error>>

Logs a USB device event to console and file (if configured).

The output format depends on the output_json setting configured during logger creation.

§Arguments
  • device_info - Information about the USB device event
§Errors

Returns an error if JSON serialisation fails or file writing fails.

Auto Trait Implementations§

§

impl Freeze for Logger

§

impl RefUnwindSafe for Logger

§

impl Send for Logger

§

impl Sync for Logger

§

impl Unpin for Logger

§

impl UnwindSafe for Logger

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.