|
Rcpp Version 0.9.10
|
00001 // -*- mode: C++; c-indent-level: 4; c-basic-offset: 4; indent-tabs-mode: nil; -*- 00002 // 00003 // SugarBlock.h: Rcpp R/C++ interface class library -- sugar functions 00004 // 00005 // Copyright (C) 2010 - 2011 Dirk Eddelbuettel and Romain Francois 00006 // 00007 // This file is part of Rcpp. 00008 // 00009 // Rcpp is free software: you can redistribute it and/or modify it 00010 // under the terms of the GNU General Public License as published by 00011 // the Free Software Foundation, either version 2 of the License, or 00012 // (at your option) any later version. 00013 // 00014 // Rcpp is distributed in the hope that it will be useful, but 00015 // WITHOUT ANY WARRANTY; without even the implied warranty of 00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00017 // GNU General Public License for more details. 00018 // 00019 // You should have received a copy of the GNU General Public License 00020 // along with Rcpp. If not, see <http://www.gnu.org/licenses/>. 00021 00022 #ifndef RCPP_SUGAR_BLOCK_1_H 00023 #define RCPP_SUGAR_BLOCK_1_H 00024 00025 namespace Rcpp{ 00026 namespace sugar{ 00027 00028 template <bool NA, typename OUT, typename U1, typename T1> 00029 class SugarBlock_1 : public Rcpp::VectorBase< Rcpp::traits::r_sexptype_traits<OUT>::rtype , NA, SugarBlock_1<NA,OUT,U1,T1> > { 00030 public: 00031 typedef OUT (*FunPtr)(U1) ; 00032 SugarBlock_1( FunPtr ptr_, const T1 & vec_) : ptr(ptr_), vec(vec_){} 00033 00034 inline OUT operator[]( int i) const { 00035 return ptr( vec[i] ) ; 00036 } 00037 inline int size() const { return vec.size() ; } 00038 00039 private: 00040 FunPtr ptr ; 00041 const T1& vec ; 00042 }; 00043 00044 } // sugar 00045 } // Rcpp 00046 00047 #define SB1_T VectorBase<REALSXP,NA,T> 00048 00049 #define SUGAR_BLOCK_1(__NAME__,__SYMBOL__) \ 00050 namespace Rcpp{ \ 00051 template <bool NA, typename T> \ 00052 inline sugar::SugarBlock_1<NA,double,double,SB1_T > \ 00053 __NAME__( \ 00054 const SB1_T& t \ 00055 ){ \ 00056 return sugar::SugarBlock_1<NA,double,double,SB1_T >( \ 00057 __SYMBOL__ , t \ 00058 ) ; \ 00059 } \ 00060 } 00061 00062 #endif