This file is indexed.

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

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
// 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.1 (2010/10/01)

#ifndef WM5BSPLINEVOLUME_H
#define WM5BSPLINEVOLUME_H

#include "Wm5MathematicsLIB.h"
#include "Wm5BSplineBasis.h"
#include "Wm5Vector3.h"

namespace Wm5
{

template <typename Real>
class WM5_MATHEMATICS_ITEM BSplineVolume
{
public:
    // Construction and destruction of an open uniform B-spline volume.  The
    // class will allocate space for the control points.  The caller is
    // responsible for setting the values with the member function
    // ControlPoint.

    BSplineVolume (int numUCtrlPoints, int numVCtrlPoints,
        int numWCtrlPoints, int uDegree, int vDegree, int wDegree);

    ~BSplineVolume ();

    int GetNumCtrlPoints (int dim) const;
    int GetDegree (int dim) const;

    // Control points may be changed at any time.  If any input index is
    // invalid, the returned point is a vector whose components are all
    // MAX_REAL.
    void SetControlPoint (int uIndex, int vIndex, int wIndex,
        const Vector3<Real>& ctrlPoint);
    Vector3<Real> GetControlPoint (int uIndex, int vIndex, int wIndex) const;

    // The spline is defined for 0 <= u <= 1, 0 <= v <= 1, and 0 <= w <= 1.
    // The input values should be in this domain.  Any inputs smaller than 0
    // are clamped to 0.  Any inputs larger than 1 are clamped to 1.
    Vector3<Real> GetPosition (Real u, Real v, Real w) const;
    Vector3<Real> GetDerivativeU (Real u, Real v, Real w) const;
    Vector3<Real> GetDerivativeV (Real u, Real v, Real w) const;
    Vector3<Real> GetDerivativeW (Real u, Real v, Real w) const;

    // for array indexing:  i = 0 for u, i = 1 for v, i = 2 for w
    Vector3<Real> GetPosition (Real pos[3]) const;
    Vector3<Real> GetDerivative (int i, Real pos[3]) const;

private:
    Vector3<Real>*** mCtrlPoint;  // ctrl[unum][vnum][wnum]
    BSplineBasis<Real> mBasis[3];
};

typedef BSplineVolume<float> BSplineVolumef;
typedef BSplineVolume<double> BSplineVolumed;

}

#endif