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 crate::{
    Pid,
    services::{Services, with_services},
};

impl Services {
    fn list_pool(&self, pool_name: &str) -> &[Pid] {
        self.topology.list_pool(pool_name)
    }
}

/// Returns a vector  of all process pids in the named pool.
pub fn list_pool(pool_name: &str) -> Vec<Pid> {
    // Can we do the same but without to_vec()?
    with_services(|services| services.list_pool(pool_name).to_vec())
}