This file is indexed.

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

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
// 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 WM5LIGHT_H
#define WM5LIGHT_H

#include "Wm5GraphicsLIB.h"
#include "Wm5Object.h"
#include "Wm5Float4.h"
#include "Wm5APoint.h"

namespace Wm5
{

class WM5_GRAPHICS_ITEM Light : public Object
{
    WM5_DECLARE_RTTI;
    WM5_DECLARE_NAMES;
    WM5_DECLARE_STREAM(Light);

public:
    enum WM5_GRAPHICS_ITEM Type
    {
        LT_AMBIENT,
        LT_DIRECTIONAL,
        LT_POINT,
        LT_SPOT,
        LT_QUANTITY
    };

    // Construction and destruction.
    Light (Type eType = LT_AMBIENT);
    virtual ~Light ();

    // The light type, currently only one of the classic types.  The default
    // value is LT_AMBIENT.
    inline void SetType (Type type);
    inline Type GetType () const;

    // The colors of the light.
    Float4 Ambient;   // default: (0,0,0,1)
    Float4 Diffuse;   // default: (0,0,0,1)
    Float4 Specular;  // default: (0,0,0,1)

    // Attenuation is typically specified as a modulator
    //     m = 1/(C + L*d + Q*d*d)
    // where C is the constant coefficient, L is the linear coefficient,
    // Q is the quadratic coefficient, and d is the distance from the light
    // position to the vertex position.  To allow for a linear adjustment of
    // intensity, the choice is to use instead
    //     m = I/(C + L*d + Q*d*d)
    // where I is an intensity factor.
    float Constant;   // default: 1
    float Linear;     // default: 0
    float Quadratic;  // default: 0
    float Intensity;  // default: 1

    // Parameters for spot lights.  The cone angle must be in radians and
    // should satisfy 0 < Angle <= pi.
    float Angle;     // default: pi
    float CosAngle;  // default: -1
    float SinAngle;  // default:  0
    float Exponent;  // default:  1

    // A helper function that lets you set mAngle and have mCosAngle and
    // mSinAngle computed for you.
    void SetAngle (float angle);

    // Although the standard directional and spot lights need only a direction
    // vector, to allow for new types of derived-class lights that would use
    // a full coordinate frame, Light provides storage for such a frame.  The
    // light frame is always in world coordinates.
    //   default position  P = (0,0,0)
    //   default direction D = (0,0,-1)
    //   default up        U = (0,1,0)
    //   default right     R = (1,0,0)
    // The set {D,U,R} must be a right-handed orthonormal set.  That is, each
    // vector is unit length, the vectors are mutually perpendicular, and
    // R = Cross(D,U).
    APoint Position;
    AVector DVector;
    AVector UVector;
    AVector RVector;

    // A helper function that lets you set the direction vector and computes
    // the up and right vectors automatically.
    void SetDirection (const AVector& direction);

protected:
    Type mType;
};

WM5_REGISTER_STREAM(Light);
typedef Pointer0<Light> LightPtr;
#include "Wm5Light.inl"

}

#endif