This file is indexed.

/usr/include/libwildmagic/Wm5CurveMesh.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
106
107
108
109
110
111
// 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 WM5CURVEMESH_H
#define WM5CURVEMESH_H

#include "Wm5GraphicsLIB.h"
#include "Wm5Polysegment.h"
#include "Wm5CurveSegment.h"
#include "Wm5FloatArray.h"

namespace Wm5
{

class WM5_GRAPHICS_ITEM CurveMesh : public Polysegment
{
    WM5_DECLARE_RTTI;
    WM5_DECLARE_NAMES;
    WM5_DECLARE_STREAM(CurveMesh);

public:
    // Construction and destruction.  The input 'vbuffer' has N >= 2 vertices
    // which are assumed to be ordered to form a continuous curve of N-1
    // curve segments.  The curve segments are stored in 'segments', an
    // array with N-1 elements.  CurveMesh assumes responsibility for deleting
    // this array, so it must be dynamically allocated.  The array 'params'
    // stores the parameter values for the curve segment endpoints.  This
    // array must have 2*(N-1) values.  Curve segment P[i] has domain
    // [params[2*i],params[2*i+1]].  Continuity requires that
    // P[i](params[2*i+1]) = P[i+1](params[2*(i+1)]).  The polysegment
    // produced by the subdivision is flagged as open.  If you want a closed
    // polysegment, you should make certain that the first endpoint of
    // P[0] matches the last endpoint of P[N-1].
    //
    // The parameter 'allowDynamicChange' should be set to 'true' when you
    // plan to dynamically modify the curve segments.  For example, you might
    // modify the control points in a Bezier curve segment.
    CurveMesh (VertexFormat* vformat, VertexBuffer* vbuffer,
        CurveSegmentPtr* segments, FloatArray* params,
        bool allowDynamicChange);

    virtual ~CurveMesh ();

    // Level of subdivision.  The 'level' value must be nonnegative.
    void SetLevel (int level);
    int GetLevel () const;

    // Call this function when one or more of your curve segments has
    // dynamically changed.
    void OnDynamicChange ();

    // Free up all memory used by the object, other than the Polysegment data.
    // The intent is that the curve mesh is in its final form.  Once this
    // function is called, SetLevel is ignored.
    void Lock ();
    bool IsLocked () const;

protected:
    VertexBufferPtr mOrigVBuffer;
    FloatArrayPtr mOrigParams;
    CurveSegmentPtr* mSegments;
    int mNumFullVertices, mNumSegments, mLevel;

private:
    // Support for subdivision of the mesh.
    class Edge
    {
    public:
        Edge ();

        // Curve for subdivision evaluations.
        CurveSegmentPtr Segment;

        // Indices for the vertices.
        int V[2];

        // Curve parameter values for the endpoints.
        float Param[2];
    };

    void Allocate (int& numTotalVertices, int& numTotalEdges, Edge*& edges);
    void Subdivide (int& numVertices, int& numEdges, Edge* edges);

    // Support for dynamic changes in the curve segments.
    class CurveInfo
    {
    public:
        friend class Memory;
        CurveInfo ();

        CurveSegmentPtr Segment;
        float Param;
    };

    void InitializeCurveInfo ();

    bool mAllowDynamicChange;
    CurveInfo* mCInfo;
};

WM5_REGISTER_STREAM(CurveMesh);
typedef Pointer0<CurveMesh> CurveMeshPtr;

}

#endif