This file is indexed.

/usr/lib/R/site-library/dplyr/include/dplyr/subset_visitor_impl.h is in r-cran-dplyr 0.7.4-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
#ifndef dplyr_subset_visitor_impl_H
#define dplyr_subset_visitor_impl_H

#include <dplyr/SubsetVectorVisitorImpl.h>
#include <dplyr/DataFrameSubsetVisitors.h>
#include <dplyr/DataFrameColumnSubsetVisitor.h>
#include <dplyr/MatrixColumnSubsetVectorVisitor.h>
#include <dplyr/bad.h>

namespace dplyr {

inline SubsetVectorVisitor* subset_visitor_matrix(SEXP vec);
inline SubsetVectorVisitor* subset_visitor_vector(SEXP vec);

inline SubsetVectorVisitor* subset_visitor(SEXP vec, const SymbolString& name) {
  try {
    if (Rf_isMatrix(vec)) {
      return subset_visitor_matrix(vec);
    }
    else {
      return subset_visitor_vector(vec);
    }
  }
  catch (const Rcpp::exception& e) {
    bad_col(name, e.what());
  }
}

inline SubsetVectorVisitor* subset_visitor_matrix(SEXP vec) {
  switch (TYPEOF(vec)) {
  case CPLXSXP:
    return new MatrixColumnSubsetVisitor<CPLXSXP>(vec);
  case INTSXP:
    return new MatrixColumnSubsetVisitor<INTSXP>(vec);
  case REALSXP:
    return new MatrixColumnSubsetVisitor<REALSXP>(vec);
  case LGLSXP:
    return new MatrixColumnSubsetVisitor<LGLSXP>(vec);
  case STRSXP:
    return new MatrixColumnSubsetVisitor<STRSXP>(vec);
  case VECSXP:
    return new MatrixColumnSubsetVisitor<VECSXP>(vec);
  default:
    break;
  }

  stop("unsupported matrix type %s", Rf_type2char(TYPEOF(vec)));
}

inline SubsetVectorVisitor* subset_visitor_vector(SEXP vec) {
  if (Rf_inherits(vec, "Date")) {
    return new DateSubsetVectorVisitor(vec);
  }

  switch (TYPEOF(vec)) {
  case CPLXSXP:
    return new SubsetVectorVisitorImpl<CPLXSXP>(vec);
  case INTSXP:
    if (Rf_inherits(vec, "factor"))
      return new SubsetFactorVisitor(vec);
    return new SubsetVectorVisitorImpl<INTSXP>(vec);
  case REALSXP:
    return new SubsetVectorVisitorImpl<REALSXP>(vec);
  case LGLSXP:
    return new SubsetVectorVisitorImpl<LGLSXP>(vec);
  case STRSXP:
    return new SubsetVectorVisitorImpl<STRSXP>(vec);

  case VECSXP: {
    if (Rf_inherits(vec, "data.frame")) {
      return new DataFrameColumnSubsetVisitor(vec);
    }
    if (Rf_inherits(vec, "POSIXlt")) {
      stop("POSIXlt not supported");
    }
    return new SubsetVectorVisitorImpl<VECSXP>(vec);
  }
  default:
    break;
  }

  // should not happen, safeguard against segfaults anyway
  stop("is of unsupported type %s", Rf_type2char(TYPEOF(vec)));
}

}

#endif