deep_causality 0.13.5

Computational causality library. Provides causality graph, collections, context and causal reasoning.
Documentation
/*
 * SPDX-License-Identifier: MIT
 * Copyright (c) 2023 - 2026. The DeepCausality Authors and Contributors. All Rights Reserved.
 */

/// Trait for types that can be indexed.
///
/// Provides methods for:
///
/// - get_time_index(): Lookup a time index by key
/// - set_time_index(): Insert/update a key-index mapping
///
/// Maintains separate current and previous index maps.
///
/// get_time_index() and set_time_index() take a `current` arg to
/// specify to use the current or previous index map.
///
/// Allows indexing items by an usized integer key. Enables mapping
/// between item IDs and indices.
///
pub trait TimeIndexable {
    /// Gets the time index for the provided key from either the current or previous
    /// index map, depending on the value of `current`.
    ///
    /// # Parameters
    ///
    /// * `key` - The key to look up in the index map
    /// * `current` - Whether to check the current or previous index map
    ///
    /// # Returns
    ///
    /// Returns the index for the provided key if it exists, otherwise returns None.
    ///
    fn get_time_index(&self, key: &usize, current: bool) -> Option<&usize>;

    /// Sets the  time index for the provided key in either the current or previous
    /// index map, depending on the value of `current`.
    ///
    /// # Parameters
    ///
    /// * `key` - The key to insert into the index map
    /// * `index` - The index value to associate with the key
    /// * `current` - Whether to insert into the current or previous index map
    ///
    /// If the key already exists in the chosen index map, the existing value
    /// will be overwritten with the provided `index` value.
    ///
    fn set_time_index(&mut self, key: usize, index: usize, current: bool);
}