mirror of
https://github.com/hannobraun/Fornjot
synced 2025-02-02 05:15:54 +00:00
Lift fmt::Display
requirement of Operations
This commit is contained in:
parent
cb165bbd81
commit
ad2c7b4e9a
@ -1,8 +1,8 @@
|
||||
use std::{fmt, ops::Deref, rc::Rc};
|
||||
use std::{ops::Deref, rc::Rc};
|
||||
|
||||
use super::tri_mesh::TriMesh;
|
||||
|
||||
pub trait Operation: fmt::Display {
|
||||
pub trait Operation {
|
||||
fn label(&self) -> &'static str;
|
||||
fn tri_mesh(&self) -> TriMesh;
|
||||
fn children(&self) -> Vec<AnyOp>;
|
||||
@ -62,12 +62,6 @@ impl AnyOp {
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for AnyOp {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "{}", self.inner)
|
||||
}
|
||||
}
|
||||
|
||||
impl Operation for AnyOp {
|
||||
fn label(&self) -> &'static str {
|
||||
self.inner.label()
|
||||
|
@ -1,5 +1,3 @@
|
||||
use std::fmt;
|
||||
|
||||
use tuples::CombinRight;
|
||||
|
||||
use crate::storage::Store;
|
||||
@ -24,12 +22,6 @@ impl Shape {
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for Shape {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "shape")
|
||||
}
|
||||
}
|
||||
|
||||
impl Operation for Shape {
|
||||
fn label(&self) -> &'static str {
|
||||
"Shape"
|
||||
@ -77,12 +69,6 @@ impl Operation for OperationInSequence {
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for OperationInSequence {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
self.operation.fmt(f)
|
||||
}
|
||||
}
|
||||
|
||||
pub struct ShapeExtender<'r, NewOps, T> {
|
||||
store: &'r mut Store<T>,
|
||||
sequence: &'r mut Vec<OperationInSequence>,
|
||||
|
@ -1,5 +1,3 @@
|
||||
use std::fmt;
|
||||
|
||||
use crate::math::Point;
|
||||
|
||||
use super::{operation::AnyOp, Operation, TriMesh};
|
||||
@ -20,12 +18,6 @@ where
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for Triangle {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "triangle")
|
||||
}
|
||||
}
|
||||
|
||||
impl Operation for Triangle {
|
||||
fn label(&self) -> &'static str {
|
||||
"Triangle"
|
||||
|
@ -1,5 +1,3 @@
|
||||
use std::fmt;
|
||||
|
||||
use spade::Triangulation;
|
||||
|
||||
use crate::{
|
||||
@ -40,12 +38,6 @@ impl Face {
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for Face {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "face")
|
||||
}
|
||||
}
|
||||
|
||||
impl Operation for Face {
|
||||
fn label(&self) -> &'static str {
|
||||
"Face"
|
||||
|
@ -1,5 +1,3 @@
|
||||
use std::fmt;
|
||||
|
||||
use crate::{
|
||||
geometry::{AnyOp, Operation, TriMesh},
|
||||
math::Point,
|
||||
@ -21,13 +19,6 @@ where
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for Vertex {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
let [x, y, z] = self.point.coords.components.map(|s| s.value());
|
||||
write!(f, "vertex {x:.2}, {y:.2}, {z:.2}")
|
||||
}
|
||||
}
|
||||
|
||||
impl Operation for Vertex {
|
||||
fn label(&self) -> &'static str {
|
||||
"Vertex"
|
||||
|
@ -1,4 +1,4 @@
|
||||
use std::{fmt, iter};
|
||||
use std::iter;
|
||||
|
||||
use crate::geometry::{AnyOp, Operation, TriMesh};
|
||||
|
||||
@ -121,12 +121,6 @@ impl OperationView {
|
||||
}
|
||||
}
|
||||
|
||||
impl fmt::Display for OperationView {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "{}", self.operation)
|
||||
}
|
||||
}
|
||||
|
||||
impl Operation for OperationView {
|
||||
fn label(&self) -> &'static str {
|
||||
self.operation.label()
|
||||
|
Loading…
Reference in New Issue
Block a user