This file is indexed.

/usr/include/epix/hatching.h is in epix 1.2.14-1.

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
/* 
 * hatching.h -- ePiX hatched region data structures
 *
 * This file is part of ePiX, a C++ library for creating high-quality 
 * figures in LaTeX 
 *
 * Version 1.1.13
 * Last Change: August 29, 2007
 */

/* 
 * Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007
 * Andrew D. Hwang <rot 13 nujnat at zngupf dot ubylpebff dot rqh>
 * Department of Mathematics and Computer Science
 * College of the Holy Cross
 * Worcester, MA, 01610-2395, USA
 */

/*
 * ePiX 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 2 of the License, or
 * (at your option) any later version.
 *
 * ePiX 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 ePiX; if not, write to the Free Software Foundation, Inc.,
 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 */
#ifndef EPIX_HATCHING
#define EPIX_HATCHING

#include <list>
#include <vector>

#include "pairs.h"
#include "edge_data.h"

namespace ePiX {

  // edge, endpoint heights, orientation (+/-1 = up/down)
  class bd_edge {
  public:
    bd_edge(const edge2d&, double, double, int);

    pair tail() const;
    pair head() const;
    pair dir() const;

    double lo() const;
    double hi() const;

    int orient() const;

  private:
    edge2d m_edge;

    double m_lo;
    double m_hi;

    int m_orient;
  };

  // location where scan line crosses bd_edge
  class cut {
  public:
    cut(pair loc, int sign);

    pair loc() const;
    int sign() const;

  private:
    pair m_loc; // location
    int m_sign; // orientation
  };

  // ax + by + c = 0
  class scan_line {
  public:
    scan_line(const pair& t, const pair& h);

    void add_cut(const cut&);

    // store what we find in value
    void draw(std::vector<edge2d>& value) const;

  private:
    pair m_perp; // (a, b)
    double m_ht; // c

    std::list<cut> m_cuts;
  }; // end of class scan_line


  // ctor converts a list of edge2d into a (large) vector of scan lines
  class hatch_data {
  public:
    // components of hatch direction, scanline separation, polygon to fill
    hatch_data(double, double,
	       double sep, const std::list<edge2d>&);

    // angle, scanline separation, polygon to fill
    hatch_data(double th, double sep, const std::list<edge2d>&);

    std::vector<edge2d> data() const;

  private:
    std::list<bd_edge> m_edges;
    std::vector<scan_line> m_scans;

    // convert polygon to scan lines parallel to dir, common to both ctors
    void hatch_init(const pair& dir,
		    double sep,
		    std::list<edge2d> polygon);
  }; // end of class hatch_data

} // end of namespace

#endif /* EPIX_HATCHING */