/usr/include/libwildmagic/Wm5CollisionGroup.inl 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 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 | // 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.0 (2010/01/01)
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
CollisionGroup<Mesh,Bound>::CollisionGroup ()
{
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
CollisionGroup<Mesh,Bound>::~CollisionGroup ()
{
typename std::vector<CollisionRecordPtr>::iterator rec = mRecords.begin();
typename std::vector<CollisionRecordPtr>::iterator end = mRecords.end();
for (/**/; rec != end; ++rec)
{
delete0(*rec);
}
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
bool CollisionGroup<Mesh,Bound>::Add (CollisionRecord<Mesh,Bound>* record)
{
typename std::vector<CollisionRecordPtr>::iterator rec = mRecords.begin();
typename std::vector<CollisionRecordPtr>::iterator end = mRecords.end();
for (/**/; rec != end; ++rec)
{
if (record == *rec)
{
return false;
}
}
mRecords.push_back(record);
return true;
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
bool CollisionGroup<Mesh,Bound>::Remove (CollisionRecord<Mesh,Bound>* record)
{
typename std::vector<CollisionRecordPtr>::iterator rec = mRecords.begin();
typename std::vector<CollisionRecordPtr>::iterator end = mRecords.end();
for (/**/; rec != end; ++rec)
{
if (record == *rec)
{
mRecords.erase(rec);
delete0(record);
return true;
}
}
return false;
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
void CollisionGroup<Mesh,Bound>::TestIntersection ()
{
// Objects are assumed to be stationary, compare all pairs.
const int numRecords = (int)mRecords.size();
for (int i0 = 0; i0 < numRecords; ++i0)
{
CollisionRecordPtr record0 = mRecords[i0];
for (int i1 = i0 + 1; i1 < numRecords; ++i1)
{
CollisionRecordPtr record1 = mRecords[i1];
record0->TestIntersection(*record1);
}
}
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
void CollisionGroup<Mesh,Bound>::FindIntersection ()
{
// Objects are assumed to be stationary, compare all pairs.
const int numRecords = (int)mRecords.size();
for (int i0 = 0; i0 < numRecords; ++i0)
{
CollisionRecordPtr record0 = mRecords[i0];
for (int i1 = i0 + 1; i1 < numRecords; ++i1)
{
CollisionRecordPtr record1 = mRecords[i1];
record0->FindIntersection(*record1);
}
}
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
void CollisionGroup<Mesh,Bound>::TestIntersection (float tmax)
{
// Objects are assumed to be moving, compare all pairs.
const int numRecords = (int)mRecords.size();
for (int i0 = 0; i0 < numRecords; i0++)
{
CollisionRecordPtr record0 = mRecords[i0];
for (int i1 = i0 + 1; i1 < numRecords; ++i1)
{
CollisionRecordPtr record1 = mRecords[i1];
if (record0->GetVelocity() || record1->GetVelocity())
{
record0->TestIntersection(tmax, *record1);
}
}
}
}
//----------------------------------------------------------------------------
template <class Mesh, class Bound>
void CollisionGroup<Mesh,Bound>::FindIntersection (float tmax)
{
// Objects are assumed to be moving, compare all pairs.
const int numRecords = (int)mRecords.size();
for (int i0 = 0; i0 < numRecords; ++i0)
{
CollisionRecordPtr record0 = mRecords[i0];
for (int i1 = i0 + 1; i1 < numRecords; ++i1)
{
CollisionRecordPtr record1 = mRecords[i1];
if (record0->GetVelocity() || record1->GetVelocity())
{
record0->FindIntersection(tmax, *record1);
}
}
}
}
//----------------------------------------------------------------------------
|