#include using namespace Rcpp; typedef ListOf NVList; // [[Rcpp::export]] NVList test_identity(NVList x) { return x; } template double sum_(const T& x) { return sum(x); } // [[Rcpp::export]] List test_lapply_sum(NVList x) { return lapply(x, sum_); } // [[Rcpp::export]] NumericVector test_sapply_sum(NVList x) { return sapply(x, sum_); } // [[Rcpp::export]] NVList test_assign(NVList x, NumericVector y, CharacterVector z) { x[1] = y; x[2] = 1; return x; } // [[Rcpp::export]] NVList test_assign_names(NVList x) { x["a"] = x["b"]; return x; } // [[Rcpp::export]] NumericVector test_add(NVList x) { return x[0] + x[1] + x[2]; } // [[Rcpp::export]] NumericVector test_add_subtract(NVList x) { return x[0] + x[1] - x[2]; } // [[Rcpp::export]] NumericVector test_mult(NVList x) { return x[0] * x[1] * x[2]; } typedef ListOf CVList; // [[Rcpp::export]] CVList test_char(CVList x) { x[0] = "apple"; return x; } // [[Rcpp::export]] NVList test_as_wrap(NVList x) { List y = as(x); NVList z = as(y); NumericVector k = x[0]; x[0] = z[1]; return z; } // [[Rcpp::export]] NumericVector test_add_NV(NVList x, NumericVector y) { return y + x[0]; } // [[Rcpp::export]] NVList test_binary_ops(NVList x) { return List::create( x[0] > x[1], x[0] < x[1], x[0] >= x[1], x[0] <= x[1] ); } #if defined(_WIN32) typedef int retval; #else typedef R_xlen_t retval; #endif // [[Rcpp::export]] retval test_sub_calls(NVList x) { retval sz = x[0].size() + x[1].size() + x[2].size(); return sz; } // [[Rcpp::export]] NumericVector test_nested_listof(ListOf< ListOf > x) { return x[0][0]; } // [[Rcpp::export]] ListOf test_return_IVList(List x) { return x; } // [[Rcpp::export]] CharacterVector listof_names(ListOf x) { return x.names(); } // [[Rcpp::export]] SEXP listof_attr_foo(ListOf x) { return x.attr("foo"); }