This file is indexed.

/usr/include/ITK-4.5/itkQuadEdgeMeshBoundaryEdgesMeshFunction.hxx is in libinsighttoolkit4-dev 4.5.0-3.

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
/*=========================================================================
 *
 *  Copyright Insight Software Consortium
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0.txt
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 *=========================================================================*/
#ifndef __itkQuadEdgeMeshBoundaryEdgesMeshFunction_hxx
#define __itkQuadEdgeMeshBoundaryEdgesMeshFunction_hxx

#include "itkQuadEdgeMeshBoundaryEdgesMeshFunction.h"
#include "itkQuadEdgeMesh.h"  // Just to mark the dependence towards this class.

namespace itk
{
template< typename TMesh >
typename QuadEdgeMeshBoundaryEdgesMeshFunction< TMesh >::OutputType
QuadEdgeMeshBoundaryEdgesMeshFunction< TMesh >::Evaluate(const InputType & mesh)
const
{
  // Push on a list all the non internal edges:
  typedef typename MeshType::CellsContainerConstIterator
  CellsContainerConstIterator;
  std::set< QEPrimal* > boundaryList;

  CellsContainerConstIterator cellIterator = mesh.GetEdgeCells()->Begin();
  CellsContainerConstIterator cellEnd      = mesh.GetEdgeCells()->End();

  while( cellIterator != cellEnd )
    {
    if ( EdgeCellType * cell =
           dynamic_cast< EdgeCellType * >( cellIterator.Value() ) )
      {
      QEPrimal *edge = cell->GetQEGeom();
      if ( !edge->IsInternal() )
        {
        boundaryList.insert(edge);
        }
      }
    ++cellIterator;
    }

  OutputType ResultList = new EdgeListType;
  while ( !boundaryList.empty() )
    {
    // Pop the first edge of list and make sure it has no face
    // on it's left [because we want to follow the boundary with
    // GeometricalQuadEdge::Lnext()]:
    typename std::set< QEPrimal* >::iterator b = boundaryList.begin();
    QEPrimal *bdryEdge = *b;
    boundaryList.erase( b );
    if ( bdryEdge->IsLeftSet() )
      {
      bdryEdge = bdryEdge->GetSym();
      }
    if ( bdryEdge->IsLeftSet() )
      {
      itkWarningMacro("Entry edge has not face adjacency.");
      delete ResultList;
      return ( (OutputType)0 );
      }

    // Store this edge as representative of it's Lnext() ring i.e.
    // representative of the boundary:
    ResultList->push_back(bdryEdge);

    // Follow, with Lnext(), the boundary while removing edges
    // from boundary list:
    typename QEPrimal::IteratorGeom bIt   = bdryEdge->BeginGeomLnext();
    typename QEPrimal::IteratorGeom bEnd  = bdryEdge->EndGeomLnext();

    while( bIt != bEnd )
      {
      // Only one of the following will be effective (but we have
      // no way to know which one):
      b = boundaryList.find( bIt.Value() );

      if( b != boundaryList.end() )
        {
        boundaryList.erase( b );
        }

      b = boundaryList.find( bIt.Value()->GetSym() );

      if( b != boundaryList.end() )
        {
        boundaryList.erase( b );
        }

      ++bIt;
      }
    }

  return ResultList;
}
}

#endif