/usr/include/SurgSim/DataStructures/MeshElement.h is in libopensurgsim-dev 0.7.0-6ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 | // This file is a part of the OpenSurgSim project.
// Copyright 2013, SimQuest Solutions Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef SURGSIM_DATASTRUCTURES_MESHELEMENT_H
#define SURGSIM_DATASTRUCTURES_MESHELEMENT_H
#include <array>
#include <memory>
namespace SurgSim
{
namespace DataStructures
{
/// Element structure for meshes. MeshElement combines Vertices to form the structure of a mesh and can store extra
/// per-element data.
///
/// MeshElement is to be used purely as a data structure and not provide implementation of algorithms.
/// For example, a physics FEM's elements are not subclasses of MeshElement if they provide code that is part of the FEM
/// algorithm, but they may used with a Mesh to store the structure of the FEM.
///
/// The extra Data is left up to the particular use of Mesh to specify. For example, for use collision detection,
/// a vertex may need a normal and adjacent triangle information, which could be stored in a struct.
///
/// If no extra Data is needed, a specialization exists for void, in which case the constructor takes no data.
///
/// \tparam N Number of vertices in the element
/// \tparam Data Type of extra data stored in the element (void for no data)
/// \sa Vertices
template <size_t N, class Data>
struct MeshElement
{
/// Constructor
/// \param verticesId IDs of the N element vertices
/// \param data Extra data to be stored with the element
MeshElement(const std::array<size_t, N>& verticesId, const Data& data) :
verticesId(verticesId),
data(data),
isValid(true)
{
}
/// Constructor where the Data is constructed by its default constructor.
/// \param verticesId IDs of the N element vertices
explicit MeshElement(const std::array<size_t, N>& verticesId) :
verticesId(verticesId),
isValid(true)
{
}
/// Copy constructor when the template data is a different type
/// In this case, no data will be copied
/// \tparam T type of data stored in the other MeshElement
/// \param other the MeshElement to copy from
template <class T>
explicit MeshElement(const MeshElement<N, T>& other) :
verticesId(other.verticesId),
isValid(other.isValid)
{
}
typedef std::array<size_t, N> IdType;
/// Element vertices.
IdType verticesId;
/// Extra element data.
Data data;
/// Is this a valid element
bool isValid;
/// Compare the element with another one (equality)
/// \param element The MeshElement to compare it to
/// \return True if the two MeshElements are equals, False otherwise
bool operator==(const MeshElement<N, Data>& element) const
{
return isValid == element.isValid && verticesId == element.verticesId && data == element.data;
}
/// Compare the element with another one (inequality)
/// \param element The MeshElement to compare it to
/// \return False if the two MeshElements are equals, True otherwise
bool operator!=(const MeshElement<N, Data>& element) const
{
return !((*this) == element);
}
};
}; // namespace DataStructures
}; // namespace SurgSim
#endif // SURGSIM_DATASTRUCTURES_MESHELEMENT_H
|