This file is indexed.

/usr/include/libwildmagic/Wm5Culler.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
// 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 WM5CULLER_H
#define WM5CULLER_H

#include "Wm5GraphicsLIB.h"
#include "Wm5Camera.h"
#include "Wm5Spatial.h"
#include "Wm5VisibleSet.h"

namespace Wm5
{

class WM5_GRAPHICS_ITEM Culler
{
public:
    // Construction and destruction.  Culling requires a camera model.  If the
    // camera is not passed to the constructor, you should set it using
    // SetCamera before calling ComputeVisibleSet.
    Culler (const Camera* camera = 0);
    virtual ~Culler ();

    // Access to the camera, frustum copy, and potentially visible set.
    inline void SetCamera (const Camera* camera);
    inline const Camera* GetCamera () const;
    void SetFrustum (const float* frustum);
    inline const float* GetFrustum () const;
    inline VisibleSet& GetVisibleSet ();

    // The base class behavior is to append the visible object to the end of
    // the visible set (stored as an array).  Derived classes may override
    // this behavior; for example, the array might be maintained as a sorted
    // array for minimizing render state changes or it might be/ maintained
    // as a unique list of objects for a portal system.
    virtual void Insert (Spatial* visible);

    // Access to the stack of world culling planes.  You may push and pop
    // planes to be used in addition to the view frustum planes.  PushPlane
    // requires the input plane to be in world coordinates.  See the comments
    // before data member mPlaneState about the bit system for enabling and
    // disabling planes during culling.
    enum { MAX_PLANE_QUANTITY = 32 };
    inline int GetPlaneQuantity () const;
    inline const HPlane* GetPlanes () const;
    inline void SetPlaneState (unsigned int planeState);
    inline unsigned int GetPlaneState () const;
    inline void PushPlane (const HPlane& plane);
    inline void PopPlane ();

    // Compare the object's world bound against the culling planes.  Only
    // Spatial calls this function.
    bool IsVisible (const Bound& bound);

    // Support for Portal::GetVisibleSet.
    bool IsVisible (int numVertices, const APoint* vertices,
        bool ignoreNearPlane);

    // Support for BspNode::GetVisibleSet.  Determine whether the view frustum
    // is fully on one side of a plane.  The "positive side" of the plane is
    // the half space to which the plane normal points.  The "negative side"
    // is the other half space.  The function returns +1 if the view frustum
    // is fully on the positive side of the plane, -1 if the view frustum is
    // fully on the negative side of the plane, or 0 if the view frustum
    // straddles the plane.  The input plane is in world coordinates and the
    // world camera coordinate system is used for the test.
    int WhichSide (const HPlane& plane) const;

    // This is the main function you should use for culling within a scene
    // graph.  Traverse the scene graph and construct the potentially visible
    // set relative to the world planes.
    void ComputeVisibleSet (Spatial* scene);

protected:
    // The input camera has information that might be needed during the
    // culling pass over the scene.
    const Camera* mCamera;

    // A copy of the view frustum for the input camera.  This allows various
    // subsystems to change the frustum parameters during culling (for
    // example, the portal system) without affecting the camera, whose initial
    // state is needed by the renderer.
    float mFrustum[Camera::VF_QUANTITY];

    // The world culling planes corresponding to the view frustum plus any
    // additional user-defined culling planes.  The member m_uiPlaneState
    // represents bit flags to store whether or not a plane is active in the
    // culling system.  A bit of 1 means the plane is active, otherwise the
    // plane is inactive.  An active plane is compared to bounding volumes,
    // whereas an inactive plane is not.  This supports an efficient culling
    // of a hierarchy.  For example, if a node's bounding volume is inside
    // the left plane of the view frustum, then the left plane is set to
    // inactive because the children of the node are automatically all inside
    // the left plane.
    int mPlaneQuantity;
    HPlane mPlane[MAX_PLANE_QUANTITY];
    unsigned int mPlaneState;

    // The potentially visible set for a call to GetVisibleSet.
    VisibleSet mVisibleSet;
};

#include "Wm5Culler.inl"

}

#endif