RotationManager

Struct RotationManager 

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

Manages log file rotation and retention.

Tracks file size and time, rotates files when thresholds are reached, and applies retention policies to clean up old files.

Implementations§

Source§

impl RotationManager

Source

pub fn new( base_path: PathBuf, policy: RotationPolicy, retention: Option<usize>, ) -> Self

Creates a new rotation manager.

§Arguments
  • base_path - Path to the log file
  • policy - Rotation policy (size, time, or both)
  • retention - Maximum number of rotated files to keep (None = unlimited)
Source

pub fn should_rotate(&mut self, additional_size: u64) -> bool

Checks if the log file should be rotated.

§Arguments
  • additional_size - Size of data about to be written
§Returns

true if rotation is needed, false otherwise

Source

pub fn rotate(&mut self) -> Result<PathBuf>

Rotates the log file by renaming it with a timestamp.

Creates a new file with the original name and applies retention policy.

§Returns

Path to the rotated file, or an error if rotation fails

Source

pub fn update_size(&mut self, size: u64)

Updates the current file size by adding the specified bytes.

§Arguments
  • size - Number of bytes to add to current size
Source

pub fn current_size(&self) -> u64

Returns the current file size in bytes.

Auto Trait Implementations§

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.