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
use fj_interop::ext::ArrayExt;

use crate::{
    insert::Insert,
    objects::{HalfEdge, Objects},
    services::Service,
    storage::Handle,
};

use super::Reverse;

impl Reverse for Handle<HalfEdge> {
    fn reverse(self, objects: &mut Service<Objects>) -> Self {
        let vertices = {
            let [a, b] = self
                .boundary()
                .zip_ext(self.surface_vertices().map(Clone::clone));
            [b, a]
        };

        HalfEdge::new(
            self.curve().clone(),
            vertices,
            self.global_form().clone(),
        )
        .insert(objects)
    }
}