## Copyright (C) 2010 - 2019 Dirk Eddelbuettel and Romain Francois ## ## This file is part of Rcpp. ## ## Rcpp 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. ## ## Rcpp 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 Rcpp. If not, see <http://www.gnu.org/licenses/>. if (Sys.getenv("RunAllRcppTests") != "yes") exit_file("Set 'RunAllRcppTests' to 'yes' to run.") Rcpp::sourceCpp("cpp/wrap.cpp") # test.wrap.map.string.int <- function(){ expect_equal(map_string_int(), c( a = 200L, b = 100L, c = 300L), info = "wrap( map<string,int>) " ) # test.wrap.map.string.double <- function(){ expect_equal(map_string_double(), c( a = 200, b = 100, c = 300), info = "wrap( map<string,double>) " ) # test.wrap.map.string.bool <- function(){ expect_equal(map_string_bool(), c( a = FALSE, b = TRUE, c = TRUE ), info = "wrap( map<string,bool>) " ) # test.wrap.map.string.Rbyte <- function(){ expect_equal(map_string_Rbyte(), c( a = as.raw(1), b = as.raw(0), c = as.raw(2) ), info = "wrap( map<string,Rbyte>) " ) # test.wrap.map.string.string <- function(){ expect_equal(map_string_string(), c( a = "bar", b = "foo", c = "bling" ), info = "wrap( map<string,string>) " ) # test.wrap.map.string.generic <- function(){ expect_equal(map_string_generic(), list( a = c(1L, 2L, 2L), b = c(1L, 2L), c = c(1L,2L,2L,2L) ) , info = "wrap( map<string,vector<int>>) " ) # test.wrap.multimap.string.int <- function(){ expect_equal(multimap_string_int(), c( a = 200L, b = 100L, c = 300L), info = "wrap( multimap<string,int>) ") # test.wrap.multimap.string.double <- function(){ expect_equal(multimap_string_double(), c( a = 200, b = 100, c = 300), info = "wrap( multimap<string,double>) " ) # test.wrap.multimap.string.bool <- function(){ expect_equal(multimap_string_bool(), c( a = FALSE, b = TRUE, c = TRUE ), info = "wrap( multimap<string,bool>)") # test.wrap.multimap.string.Rbyte <- function(){ expect_equal(multimap_string_Rbyte(), c( a = as.raw(1), b = as.raw(0), c = as.raw(2) ), info = "wrap( multimap<string,Rbyte>) " ) # test.wrap.multimap.string.string <- function(){ expect_equal(multimap_string_string(), c( a = "bar", b = "foo", c = "bling" ), info = "wrap( multimap<string,string>) " ) # test.wrap.multimap.string.generic <- function(){ expect_equal(multimap_string_generic(), list( a = c(1L, 2L, 2L), b = c(1L, 2L), c = c(1L,2L,2L,2L) ) , info = "wrap( multimap<string,vector<int>>) " ) # test.nonnull.const.char <- function() { expect_equal(nonnull_const_char(), "foo", info = "null const char*") # test.wrap.unordered.map.string.int <- function(){ res <- unordered_map_string_int() expect_equal( res[["a"]], 200L, info = "wrap( tr1::unordered_map<string,int>) " ) expect_equal( res[["b"]], 100L, info = "wrap( tr1::unordered_map<string,int>) " ) expect_equal( res[["c"]], 300L, info = "wrap( tr1::unordered_map<string,int>) " ) # test.wrap.unordered.map.rcpp.string.int <- function(){ res <- unordered_map_rcpp_string_int(c("a", "b", "c")) expect_equal( res[["a"]], 200L, info = "wrap( tr1::unordered_map<Rcpp::String,int>) " ) expect_equal( res[["b"]], 100L, info = "wrap( tr1::unordered_map<Rcpp::String,int>) " ) expect_equal( res[["c"]], 300L, info = "wrap( tr1::unordered_map<Rcpp::String,int>) " ) # test.unordered.set.rcpp.string <- function(){ expect_equal(unordered_set_rcpp_string(c("a", "b", "c", "b")), c(FALSE, FALSE, FALSE, TRUE), info = "wrap( tr1::unordered_set<Rcpp::String>) " ) # test.wrap.unordered.map.string.double <- function(){ res <- unordered_map_string_double() expect_equal( res[["a"]], 200, info = "wrap( tr1::unordered_map<string,double>) " ) expect_equal( res[["b"]], 100, info = "wrap( tr1::unordered_map<string,double>) " ) expect_equal( res[["c"]], 300, info = "wrap( tr1::unordered_map<string,double>) " ) # test.wrap.unordered.map.string.bool <- function(){ res <- unordered_map_string_bool() expect_equal( res[["a"]], FALSE, info = "wrap( tr1::unordered_map<string,bool>) " ) expect_equal( res[["b"]], TRUE , info = "wrap( tr1::unordered_map<string,bool>) " ) expect_equal( res[["c"]], TRUE , info = "wrap( tr1::unordered_map<string,bool>) " ) # test.wrap.unordered.map.string.Rbyte <- function(){ res <- unordered_map_string_Rbyte() expect_equal( res[["a"]], as.raw(1), info = "wrap( tr1::unordered_map<string,Rbyte>) " ) expect_equal( res[["b"]], as.raw(0), info = "wrap( tr1::unordered_map<string,Rbyte>) " ) expect_equal( res[["c"]], as.raw(2), info = "wrap( tr1::unordered_map<string,Rbyte>) " ) # test.wrap.unordered.map.string.string <- function(){ res <- unordered_map_string_string() expect_equal( res[["a"]], "bar" , info = "wrap( tr1::unordered_map<string,string>) " ) expect_equal( res[["b"]], "foo" , info = "wrap( tr1::unordered_map<string,string>) " ) expect_equal( res[["c"]], "bling" , info = "wrap( tr1::unordered_map<string,string>) " ) # test.wrap.unordered.map.string.generic <- function(){ res <- unordered_map_string_generic() expect_equal( res[["a"]], c(1L,2L,2L) , info = "wrap( tr1::unordered_map<string,vector<int>>) " ) expect_equal( res[["b"]], c(1L,2L) , info = "wrap( tr1::unordered_map<string,vector<int>>) " ) expect_equal( res[["c"]], c(1L,2L,2L,2L) , info = "wrap( tr1::unordered_map<string,vector<int>>) " ) # test.wrap.map.int.double <- function(){ expect_equal(map_int_double(), c("-1" = 3, "0" = 2 ), info = "std::map<int,double>") # test.wrap.map.double.double <- function(){ expect_equal(map_double_double(), c("0" = 2, "1.2" = 3 ), info = "std::map<double,double>") # test.wrap.map.int.vector_double <- function(){ expect_equal(map_int_vector_double(), list("0" = c(1,2), "1" = c(2,3) ), info = "std::map<double, std::vector<double> >") # test.wrap.map.int.Foo <- function(){ expect_equal(sapply( map_int_Foo(), function(.) .$get() ), c("0" = 2, "1" = 3 ), info = "std::map<int, MODULE EXPOSED CLASS >") # test.wrap.vector.Foo <- function(){ expect_equal(sapply( vector_Foo(), function(.) .$get() ), c(2, 3), info = "std::vector< MODULE EXPOSED CLASS >") # test.wrap.custom.class <- function() { expect_equal(test_wrap_custom_class(), 42)