This file is indexed.

/usr/include/gmsh/SuperEl.h is in libgmsh-dev 2.8.3+dfsg-4ubuntu2.

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
// Copyright (C) 2013 ULg-UCL
//
// Permission is hereby granted, free of charge, to any person
// obtaining a copy of this software and associated documentation
// files (the "Software"), to deal in the Software without
// restriction, including without limitation the rights to use, copy,
// modify, merge, publish, distribute, and/or sell copies of the
// Software, and to permit persons to whom the Software is furnished
// to do so, provided that the above copyright notice(s) and this
// permission notice appear in all copies of the Software and that
// both the above copyright notice(s) and this permission notice
// appear in supporting documentation.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE
// COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR
// ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY
// DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
// WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
// ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
// OF THIS SOFTWARE.
//
// Please report all bugs and problems to the public mailing list
// <gmsh@geuz.org>.
//
// Contributor: Thomas Toulorge

#ifndef _SUPEREL_H_
#define _SUPEREL_H_

#include <string>
#include "MElement.h"



class SuperEl
{
public:

  SuperEl(MElement *badEl, double dist, int type, const std::vector<MVertex*> &baseVert,
          const std::vector<SVector3> &normals);
  ~SuperEl() { _superVert.clear(); delete _superEl, _superEl0; }

  bool isOK() const { return _superEl; }
  bool isPointIn(const SPoint3 p) const;
  bool straightToCurved(double *xyzS, double *xyzC) const;

  std::string printPOS();

  void printCoord() {
    std::cout << "DBGTT: superEl -> ";
    for(int i = 0; i < _superVert.size(); i++){
      std::cout << "v" << i << " = (" << _superVert[i]->x() << "," <<  _superVert[i]->y() << "," <<  _superVert[i]->z() << ")";
      if (i == _superVert.size()-1) std::cout << "\n"; else std::cout << ", ";
    }

  }

private:

  std::vector<MVertex*> _superVert;
  MElement *_superEl, *_superEl0;

  void createSuperElQuad(MElement *badEl, double dist, const std::vector<MVertex*> &baseVert,
                         const SVector3 &n0, const SVector3 &n1);
  void createSuperElPrism(MElement *badEl, double dist, const std::vector<MVertex*> &baseVert,
                          const SVector3 &n0, const SVector3 &n1, const SVector3 &n2);
  void createSuperElHex(MElement *badEl, double dist, const std::vector<MVertex*> &baseVert,
                        const SVector3 &n0, const SVector3 &n1, const SVector3 &n2, const SVector3 &n3);


};


#endif