This file is indexed.

/usr/include/libwildmagic/Wm5StandardMesh.h is in libwildmagic-dev 5.13-1+b2.

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
112
113
114
115
116
117
118
119
120
121
122
// 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 WM5STANDARDMESH_H
#define WM5STANDARDMESH_H

#include "Wm5GraphicsLIB.h"
#include "Wm5VertexBufferAccessor.h"
#include "Wm5TriMesh.h"

namespace Wm5
{

class WM5_GRAPHICS_ITEM StandardMesh
{
public:
    // Standard meshes.  Each mesh is centered at (0,0,0) and has an up-axis
    // of (0,0,1).  The other axes forming the coordinate system are (1,0,0)
    // and (0,1,0).  An application may transform the meshes as necessary
    // by providing an input 'transform' to the constructor.  If a closed
    // mesh is to be visible to an observer outside the object, then set
    // 'inside' to 'false'; otherwise, set 'inside' to 'true' so that an
    // observer will see the mesh when inside the object.  Set 'isStatic'
    // to 'true' for a vertex buffer that has usage Buffer::BU_STATIC;
    // otherwise, 'isStatic' is 'false' and the vertex buffer has usage
    // Buffer::BU_DYNAMIC.

    // Construction and destruction.
    StandardMesh (VertexFormat* vformat, bool isStatic = true,
        bool inside = false, const Transform* transform = 0);

    ~StandardMesh ();

    // Access the transform for the mesh creator.
    void SetTransform (const Transform& transform);
    const Transform& GetTransform () const;

    // The comments for the various objects are for the case when the input
    // 'transform' is NULL (the identity transform).

    // The rectangle is in the plane z = 0 and is visible to an observer who
    // is on the side of the plane to which the normal (0,0,1) points.  It has
    // corners (-xExtent, -yExtent, 0), (+xExtent, -yExtent, 0),
    // (-xExtent, +yExtent, 0), and (+xExtent, +yExtent, 0).  The mesh has
    // xSamples vertices in the x-direction and ySamples vertices in the
    // y-direction for a total of xSamples*ySamples vertices.
    TriMesh* Rectangle (int xSamples, int ySamples, float xExtent,
        float yExtent);

    // The circular disk is in the plane z = 0 and is visible to an observer
    // who is on the side of the plane to which the normal (0,0,1) points.
    // It has center (0,0,0) and the specified 'radius'.  The mesh has its
    // first vertex at the center.  Samples are placed along rays whose
    // common origin is the center.  There are 'radialSamples' rays.  Along
    // each ray the mesh has 'shellSamples' vertices.
    TriMesh* Disk (int shellSamples, int radialSamples, float radius);

    // The box has center (0,0,0); unit-length axes (1,0,0), (0,1,0), and
    // (0,0,1); and extents (half-lengths) 'xExtent', 'yExtent', and
    // 'zExtent'.  The mesh has 8 vertices and 12 triangles.  For example,
    // the box corner in the first octant is (xExtent, yExtent, zExtent).
    TriMesh* Box (float xExtent, float yExtent, float zExtent);

    // The cylinder has center (0,0,0), the specified 'radius', and the
    // specified 'height'.  The cylinder axis is a line segment of the
    // form (0,0,0) + t*(0,0,1) for |t| <= height/2.  The cylinder wall
    // is implicitly defined by x^2+y^2 = radius^2.  If 'open' is 'true',
    // the cylinder end-disks are omitted; you have an open tube.  If
    // 'open' is 'false', the end-disks are included.  Each end-disk is
    // a regular polygon that is tessellated by including a vertex at
    // the center of the polygon and decomposing the polygon into triangles
    // that all share the center vertex and each triangle containing an
    // edge of the polygon.
    TriMesh* Cylinder (int axisSamples, int radialSamples, float radius,
        float height, bool open);

    // The sphere has center (0,0,0) and the specified 'radius'.  The north
    // pole is at (0,0,radius) and the south pole is at (0,0,-radius).  The
    // mesh has the topology of an open cylinder (which is also the topology
    // of a rectangle with wrap-around for one pair of parallel edges) and
    // is then stitched to the north and south poles.  The triangles are
    // unevenly distributed.  If you want a more even distribution, create
    // an icosahedron and subdivide it.
    TriMesh* Sphere (int zSamples, int radialSamples, float radius);

    // The torus has center (0,0,0).  If you observe the torus along the
    // line with direction (0,0,1), you will see an annulus.  The circle
    // that is the center of the annulus has radius 'outerRadius'.  The
    // distance from this circle to the boundaries of the annulus is the
    // 'inner radius'.
    TriMesh* Torus (int circleSamples, int radialSamples, float outerRadius,
        float innerRadius);

    // Platonic solids, all inscribed in a unit sphere centered at (0,0,0).
    TriMesh* Tetrahedron ();
    TriMesh* Hexahedron ();
    TriMesh* Octahedron ();
    TriMesh* Dodecahedron ();
    TriMesh* Icosahedron ();

private:
    void TransformData (VertexBufferAccessor& vba);
    void ReverseTriangleOrder (int numTriangles, int* indices);
    void CreatePlatonicNormals (VertexBufferAccessor& vba);
    void CreatePlatonicUVs (VertexBufferAccessor& vba);

    enum { MAX_UNITS = VertexFormat::AM_MAX_TCOORD_UNITS };
    VertexFormatPtr mVFormat;
    Transform mTransform;
    bool mIsStatic, mInside, mHasNormals;
    bool mHasTCoords[MAX_UNITS];
    Buffer::Usage mUsage;
};

}

#endif