This file is indexed.

/usr/include/libwildmagic/Wm5ConvexPolyhedron3.h is in libwildmagic-dev 5.13-1.

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
// Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.0 (2010/01/01)

#ifndef WM5CONVEXPOLYHEDRON3_H
#define WM5CONVEXPOLYHEDRON3_H

#include "Wm5MathematicsLIB.h"
#include "Wm5Polyhedron3.h"

namespace Wm5
{

template <typename Real>
class ConvexPolyhedron3 : public Polyhedron3<Real>
{
public:
    // Construction and destruction.  The caller is responsible for ensuring
    // that the mesh represents a convex polyhedron.  The triangular faces
    // must be ordered counterclockwise when viewed from outside the mesh.
    //
    // Polyhedron3 objects typically share data from other sources.  The class
    // uses smart pointers (Pointer1) to share the input arrays.  If you
    // do not want the class to delete the arrays, use your own smart pointers
    // for the arrays.
    //
    // ConvexPolyhedron3 stores the planes associated with the faces; the
    // plane normals are inner pointing.  The planes may be supplied to the
    // constructor, in which case a smart pointer is used to share them.  If
    // they are not passed ('planes' is null), the class automatically
    // generates them.

    // The plane representation is Dot(N,X) = c.  The 'first' of the pair is
    // a unit-length normal N to the plane.  The 'second' of the pair is the
    // plane constant c.  X is any point on the plane.
    typedef typename std::pair<Vector3<Real>, Real> NCPlane;

    ConvexPolyhedron3 (int numVertices, Vector3<Real>* vertices,
        int numTriangles, int* indices, NCPlane* planes);

    ConvexPolyhedron3 (const ConvexPolyhedron3& polyhedron);
    virtual ~ConvexPolyhedron3 ();

    // Assignment.
    ConvexPolyhedron3& operator= (const ConvexPolyhedron3& polyhedron);

    // Read-only member access.
    const NCPlane* GetPlanes () const;
    const NCPlane& GetPlane (int i) const;

    // Allow vertex modification.  The caller must ensure that the polyhedron
    // remains convex.  After modifying as many vertices as you like, call
    // UpdatePlanes().  The modifications are all done via SetVertex, and the
    // planes are updated only for those triangles sharing the modified
    // vertices.
    virtual void SetVertex (int i, const Vector3<Real>& vertex);
    void UpdatePlanes ();

    // Test for convexity.  This function will iterate over the faces of the
    // polyhedron and verify for each face that the polyhedron vertices are
    // all on the nonnegative side of the facet plane.  A signed distance test
    // is used, so a vertex is on the wrong side of a plane (for convexity)
    // when its signed distance satisfies d < 0.  Numerical round-off errors
    // can generate incorrect convexity tests, so a small negative threshold
    // t may be passed to this function, in which case the distance test
    // becomes d < t < 0.
    bool IsConvex (Real threshold = (Real)0) const;

    // Point-in-polyhedron test, performed by which-side queries between the
    // point and the planes of the faces, an O(n) algorithm for n vertices.
    // This is not the optimal algorithm.  TODO:  Move the BSP-based algorithm
    // to this class.  It is an O(log n) algorithm.
    bool Contains (const Vector3<Real>& p, Real threshold = (Real)0)
        const;

protected:
    using Polyhedron3<Real>::mNumVertices;
    using Polyhedron3<Real>::mVertices;
    using Polyhedron3<Real>::mNumTriangles;
    using Polyhedron3<Real>::mNumIndices;
    using Polyhedron3<Real>::mIndices;

    // Support for efficient updating of facet planes.  The set stores the
    // indices for those triangles that share modified vertices.
    void UpdatePlane (int i, const Vector3<Real>& average);

    // The number of planes is the number of triangles.
    Pointer1<NCPlane> mPlanes;

    // The sharing triangles processed by UpdatePlane.
    std::set<int> mSharingTriangles;
};

#include "Wm5ConvexPolyhedron3.inl"

typedef ConvexPolyhedron3<float> ConvexPolyhedron3f;
typedef ConvexPolyhedron3<double> ConvexPolyhedron3d;

}

#endif