Documentation
/*
==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--==--

Bi

Copyright (C) 2019, 2021-2022, 2024  Anonymous

There are several releases over multiple years,
they are listed as ranges, such as: "2021-2022".

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License
along with this program.  If not, see <https://www.gnu.org/licenses/>.

::--::--::--::--::--::--::--::--::--::--::--::--::--::--::--::--
*/

use {
    core::sync::atomic::AtomicUsize,
    std::sync::Arc,
    crate::ATOMIC_ORDERING,
};

/// # Counter
#[derive(Debug)]
pub (crate) struct Counter {
    size: usize,
    counter: Arc<AtomicUsize>,
}

impl Counter {

    /// # Makes new instance
    pub fn new(size: usize, counter: Arc<AtomicUsize>) -> Self {
        Self {
            size,
            counter,
        }
    }

}

impl Drop for Counter {

    fn drop(&mut self) {
        if self.counter.fetch_update(ATOMIC_ORDERING, ATOMIC_ORDERING, |c| Some(c.saturating_sub(self.size))).is_err() {
            // Ignore it
        }
    }

}