dscale 0.7.1

A fast & deterministic simulation framework for benchmarking and testing distributed systems
Documentation
// DScale: deterministic distributed systems simulator
// Copyright (C) 2026  Konstantin Shprenger

// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU 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 General Public License for more details.

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

use std::cmp::Reverse;

use crate::{
    Jiffies, runners::scalable::lazy_heap::LazyRemoveBinHeap,
    services::process_access::IngestableEventBatch,
};

pub(crate) type TaskId = (Jiffies, usize);

// Sorting by arrival time, then by id
pub(super) type TaskIndex = LazyRemoveBinHeap<Reverse<TaskId>>;

#[derive(Debug)]
pub(crate) struct TaskResult {
    pub(crate) id: TaskId,
    pub(crate) pid: usize,
    pub(crate) invocation_time: Jiffies,
    pub(crate) events: IngestableEventBatch,
}