This file is indexed.

/usr/include/freefoam/finiteVolume/pointPatchInterpolation.H is in libfreefoam-dev 0.1.0+dfsg-1build1.

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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
/*---------------------------------------------------------------------------*\
  =========                 |
  \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
   \\    /   O peration     |
    \\  /    A nd           | Copyright (C) 1991-2010 OpenCFD Ltd.
     \\/     M anipulation  |
-------------------------------------------------------------------------------
License
    This file is part of OpenFOAM.

    OpenFOAM is free software: you can redistribute it and/or modify it
    under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    for more details.

    You should have received a copy of the GNU General Public License
    along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.

Class
    Foam::pointPatchInterpolation

Description
    Foam::pointPatchInterpolation

SourceFiles
    pointPatchInterpolation.C

\*---------------------------------------------------------------------------*/

#ifndef pointPatchInterpolation_H
#define pointPatchInterpolation_H

#include <OpenFOAM/primitivePatchInterpolation.H>
#include <OpenFOAM/PtrList.H>
#include <finiteVolume/volFieldsFwd.H>
#include <OpenFOAM/pointFieldsFwd.H>
#include <OpenFOAM/scalarList.H>
#include <OpenFOAM/className.H>

// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //

namespace Foam
{

// Forward declaration of classes
class fvMesh;
class pointMesh;

/*---------------------------------------------------------------------------*\
                       Class pointPatchInterpolation Declaration
\*---------------------------------------------------------------------------*/

class pointPatchInterpolation
{
    // Private data

        const fvMesh& fvMesh_;

        //- Primitive patch interpolators
        PtrList<primitivePatchInterpolation> patchInterpolators_;

        //- List of patch-patch edge points that require special treatement
        labelList patchPatchPoints_;

        //- Weights for patch-patch boundary points
        scalarListList patchPatchPointWeights_;

        labelList patchPatchPointConstraintPoints_;
        tensorField patchPatchPointConstraintTensors_;


    // Private member functions

        //- Construct addressing for patch-patch boundary points
        void makePatchPatchAddressing();

        //- Construct weights for patch-patch boundary points
        void makePatchPatchWeights();


        //- Disallow default bitwise copy construct
        pointPatchInterpolation(const pointPatchInterpolation&);

        //- Disallow default bitwise assignment
        void operator=(const pointPatchInterpolation&);


public:

    // Declare name of the class and its debug switch
    ClassName("pointPatchInterpolation");


    // Constructors

        //- Constructor given fvMesh and pointMesh.
        pointPatchInterpolation(const fvMesh&);


    // Destructor

        ~pointPatchInterpolation();


    // Member functions

        // Access

            const fvMesh& mesh() const
            {
                return fvMesh_;
            }


        // Edit

            //- Update mesh topology using the morph engine
            void updateMesh();

            //- Correct weighting factors for moving mesh.
            bool movePoints();


    // Interpolation functions

        template<class Type>
        void interpolate
        (
            const GeometricField<Type, fvPatchField, volMesh>&,
            GeometricField<Type, pointPatchField, pointMesh>&,
            bool overrideFixedValue
        ) const;

        template<class Type>
        void applyCornerConstraints
        (
            GeometricField<Type, pointPatchField, pointMesh>& pf
        ) const;
};


template<>
void pointPatchInterpolation::applyCornerConstraints<scalar>
(
    GeometricField<scalar, pointPatchField, pointMesh>& pf
) const;


// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //

} // End namespace Foam

// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //

#ifdef NoRepository
#   include <finiteVolume/pointPatchInterpolate.C>
#endif

// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //

#endif

// ************************ vim: set sw=4 sts=4 et: ************************ //