Struct atoll::grid::RoutingGrid

source ·
pub struct RoutingGrid<L> {
    pub stack: LayerStack<L>,
    /* private fields */
}
Expand description

A fixed-size routing grid.

Does not store the state of track points in the grid. For that functionality, see RoutingState.

Fields§

§stack: LayerStack<L>

The layer stack.

Implementations§

source§

impl<L> RoutingGrid<L>

source

pub fn new(stack: LayerStack<L>, layers: Range<usize>) -> Self

Creates a new routing grid with the given properties.

source

pub fn layers(&self) -> Range<usize>

Returns the set of layers contained in this grid.

source

pub fn slice(&self) -> LayerSlice<'_, L>

The layer slice representing the layers used by this routing grid.

source§

impl<L: AtollLayer> RoutingGrid<L>

source

pub fn track_span(&self, layer: usize, track: i64) -> Span

Calculates the span of a particular track on the given layer.

source

pub fn tracks(&self, layer: usize) -> UniformTracks

The tracks on the given layer.

source

pub fn track_grid(&self, layer: usize) -> (UniformTracks, UniformTracks)

Returns the track grid for the given layer.

Returns a tuple containing the vertical going tracks followed by the horizontal going tracks. In other words, the first element of the tuple is indexed by an x-coordinate, and the second element of the tuple is indexed by a y-coordinate.

source

pub fn track(&self, layer: usize, track: i64, start: i64, end: i64) -> Rect

Calculates the bounds of a particular track on the given layer.

The start and end coordinates are with respect to tracks on the grid defining layer.

source

pub fn track_point(&self, layer: usize, track: i64, cross_track: i64) -> Point

Returns the physical coordinates of the grid point defined by the given track and cross_track on layer layer, where track is the track on layer and cross_track is a perpendicular track.

source

pub fn xy_track_point(&self, layer: usize, x_track: i64, y_track: i64) -> Point

Returns the physical coordinates of the grid point defined by the given x_track and y_track on layer layer.

source

pub fn point_to_grid( &self, p: Point, layer: usize, round_x: RoundingMode, round_y: RoundingMode ) -> Point

Rounds the given point to the routing grid, returning a point in track coordinates on the given layer.

source

pub fn shrink_to_grid(&self, rect: Rect, layer: usize) -> Option<Rect>

Rounds the given point to the routing grid, returning a point in track coordinates on the given layer.

Rounds in the direction that makes the rectangle smaller. If the resulting rectangle contains no track points, returns None.

source

pub fn expand_to_grid(&self, rect: Rect, layer: usize) -> Rect

Rounds the given point to the routing grid, returning a point in track coordinates on the given layer.

Rounds in the direction that makes the rectangle larger.

Trait Implementations§

source§

impl<L: Clone> Clone for RoutingGrid<L>

source§

fn clone(&self) -> RoutingGrid<L>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<L: Debug> Debug for RoutingGrid<L>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de, L> Deserialize<'de> for RoutingGrid<L>
where L: Deserialize<'de>,

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl<L: Hash> Hash for RoutingGrid<L>

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<L: PartialEq> PartialEq for RoutingGrid<L>

source§

fn eq(&self, other: &RoutingGrid<L>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<L> Serialize for RoutingGrid<L>
where L: Serialize,

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<L: Eq> Eq for RoutingGrid<L>

source§

impl<L> StructuralPartialEq for RoutingGrid<L>

Auto Trait Implementations§

§

impl<L> RefUnwindSafe for RoutingGrid<L>
where L: RefUnwindSafe,

§

impl<L> Send for RoutingGrid<L>
where L: Send,

§

impl<L> Sync for RoutingGrid<L>
where L: Sync,

§

impl<L> Unpin for RoutingGrid<L>
where L: Unpin,

§

impl<L> UnwindSafe for RoutingGrid<L>
where L: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T, U> CustomHardwareType<Flipped<T>> for U

source§

fn from_layout_type(other: &Flipped<T>) -> U

Creates this layout type from another layout type.
source§

impl<T, U> CustomHardwareType<InOut<T>> for U

source§

fn from_layout_type(other: &InOut<T>) -> U

Creates this layout type from another layout type.
source§

impl<T, U> CustomHardwareType<Input<T>> for U

source§

fn from_layout_type(other: &Input<T>) -> U

Creates this layout type from another layout type.
source§

impl<T, U> CustomHardwareType<Output<T>> for U

source§

fn from_layout_type(other: &Output<T>) -> U

Creates this layout type from another layout type.
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
source§

impl<T> Connect<&T> for T

source§

impl<T> Connect<T> for T

source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

source§

impl<T> Primitive for T
where T: Clone + Send + Sync + Any,

source§

impl<T> Primitive for T