This file is indexed.

/usr/include/viennacl/range.hpp is in libviennacl-dev 1.5.2-2.

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
#ifndef VIENNACL_RANGE_HPP_
#define VIENNACL_RANGE_HPP_

/* =========================================================================
   Copyright (c) 2010-2014, Institute for Microelectronics,
                            Institute for Analysis and Scientific Computing,
                            TU Wien.
   Portions of this software are copyright by UChicago Argonne, LLC.

                            -----------------
                  ViennaCL - The Vienna Computing Library
                            -----------------

   Project Head:    Karl Rupp                   rupp@iue.tuwien.ac.at

   (A list of authors and contributors can be found in the PDF manual)

   License:         MIT (X11), see file LICENSE in the base directory
============================================================================= */

/** @file range.hpp
    @brief Implementation of a range object for use with proxy objects
*/

#include <vector>
#include <stddef.h>
#include <assert.h>
#include "viennacl/forwards.h"

namespace viennacl
{

  /** @brief A range class that refers to an interval [start, stop), where 'start' is included, and 'stop' is excluded.
   *
   * Similar to the boost::numeric::ublas::basic_range class.
   */
  template <typename SizeType /* see forwards.h for default argument*/,
            typename DistanceType /* see forwards.h for default argument*/>
  class basic_range
  {
    public:
      typedef SizeType             size_type;
      typedef DistanceType         difference_type;
      typedef size_type            value_type;
      typedef value_type           const_reference;
      typedef const_reference      reference;

      basic_range() : start_(0), size_(0) {}
      basic_range(size_type start_index, size_type stop_index) : start_(start_index), size_(stop_index - start_index)
      {
        assert(start_index <= stop_index);
      }


      size_type start() const { return start_; }
      size_type size() const { return size_; }

      const_reference operator()(size_type i) const
      {
        assert(i < size());
        return start_ + i;
      }
      const_reference operator[](size_type i) const { return operator()(i); }

      bool operator==(const basic_range & r) const { return (start_ == r.start_) && (size_ == r.size_); }
      bool operator!=(const basic_range & r) const { return !(*this == r); }

    private:
      size_type start_;
      size_type size_;
  };


}

#endif