1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
// Copyright (c) 2020-2021 Thomas Kramer.
// SPDX-FileCopyrightText: 2022 Thomas Kramer
//
// SPDX-License-Identifier: AGPL-3.0-or-later
//! The type of a pin is specified by a signal direction.
/// Signal type for pins.
#[derive(Copy, Clone, Debug, Hash, PartialEq, Eq, Default)]
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
pub enum Direction {
/// No direction specified.
#[default]
None,
/// Data input.
Input,
/// Data output.
Output,
/// Input and output.
InOut,
/// Clock input.
Clock,
/// Power VDD.
Supply,
/// Power ground.
Ground,
}
impl Direction {
/// Check if this direction is 'input'.
pub fn is_input(&self) -> bool {
self == &Direction::Input
}
/// Check if this direction is 'output'.
pub fn is_output(&self) -> bool {
self == &Direction::Output
}
/// Check if this direciton is either 'Supply' or 'Ground'.
pub fn is_power(&self) -> bool {
matches!(self, Direction::Supply | Direction::Ground)
}
}