23#ifndef VCL_ALGORITHMS_MESH_UPDATE_FLAG_H
24#define VCL_ALGORITHMS_MESH_UPDATE_FLAG_H
26#include <vclib/algorithms/mesh/sort.h>
27#include <vclib/mesh/requirements.h>
44template<FaceMeshConcept MeshType>
45void updateBorder(MeshType& m)
47 using VertexType = MeshType::VertexType;
48 using FaceType = MeshType::FaceType;
50 for (FaceType& f : m.
faces())
51 f.unsetAllEdgesOnBorder();
53 if (m.faceNumber() == 0)
56 std::vector<MeshEdgeUtil<MeshType>> e = fillAndSortMeshEdgeUtilVector(m);
58 typename std::vector<MeshEdgeUtil<MeshType>>::iterator pe, ps;
62 if (pe == e.end() || *pe != *ps) {
64 ps->f->edgeOnBorder(ps->e) =
true;
70 }
while (pe != e.end());
constexpr detail::FacesView faces
A view that allows to iterate overt the Face elements of an object.
Definition face.h:52