// -*- mode: C++; c-indent-level: 4; c-basic-offset: 4; indent-tabs-mode: nil; -*- // // dates.cpp: Rcpp R/C++ interface class library -- Date + Datetime tests // // Copyright (C) 2010 - 2013 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 . #include using namespace Rcpp; // [[Rcpp::export]] Date ctor_sexp(SEXP d) { Date dt = Date(d); return dt; } // [[Rcpp::export]] SEXP ctor_mdy() { Date dt = Date(12,31,2005); return wrap(dt); } // [[Rcpp::export]] SEXP ctor_ymd() { Date dt = Date(2005,12,31); return wrap(dt); } // [[Rcpp::export]] SEXP ctor_int(int d) { Date dt = Date(d); return wrap(dt); } // [[Rcpp::export]] SEXP ctor_string(std::string x) { Date dt(x); return wrap(dt); } // [[Rcpp::export]] List operators() { Date d1 = Date(2005,12,31); Date d2 = d1 + 1; return List::create(Named("diff") = d1 - d2, Named("bigger") = d2 > d1, Named("smaller") = d2 < d1, Named("equal") = d2 == d1, Named("ge") = d2 >= d1, Named("le") = d2 <= d1, Named("ne") = d2 != d1); } // [[Rcpp::export]] List components() { Date d = Date(2005,12,31); return List::create(Named("day") = d.getDay(), Named("month") = d.getMonth(), Named("year") = d.getYear(), Named("weekday") = d.getWeekday(), Named("yearday") = d.getYearday()); } // [[Rcpp::export]] SEXP vector_Date() { std::vector v(2) ; v[0] = Date(2005,12,31) ; v[1] = Date(12,31,2005) ; return wrap( v ); } // [[Rcpp::export]] SEXP Datevector_wrap() { DateVector v(2) ; v[0] = Date(2005,12,31) ; v[1] = Date(12,31,2005) ; return wrap( v ); } // [[Rcpp::export]] SEXP Datevector_sexp() { DateVector v(2) ; v[0] = Date(2005,12,31) ; v[1] = Date(12,31,2005) ; return wrap( v ); } // [[Rcpp::export]] List Date_get_functions(Date x) { Date d = Date(x); return List::create(Named("year") = d.getYear(), Named("month") = d.getMonth(), Named("day") = d.getDay(), Named("wday") = d.getWeekday(), Named("yday") = d.getYearday()); } // [[Rcpp::export]] List Datetime_get_functions(Datetime x) { Datetime dt = Datetime(x); return List::create(Named("year") = dt.getYear(), Named("month") = dt.getMonth(), Named("day") = dt.getDay(), Named("wday") = dt.getWeekday(), Named("hour") = dt.getHours(), Named("minute") = dt.getMinutes(), Named("second") = dt.getSeconds(), Named("microsec") = dt.getMicroSeconds()); } // [[Rcpp::export]] List Datetime_operators() { Datetime d1 = Datetime(946774923.123456); Datetime d2 = d1 + 60*60; return List::create(Named("diff") = d1 - d2, Named("bigger") = d2 > d1, Named("smaller") = d2 < d1, Named("equal") = d2 == d1, Named("ge") = d2 >= d1, Named("le") = d2 <= d1, Named("ne") = d2 != d1); } // [[Rcpp::export]] SEXP Datetime_wrap() { Datetime dt = Datetime(981162123.123456); return wrap(dt); } // [[Rcpp::export]] SEXP Datetime_from_string(std::string x) { Datetime dt(x); return wrap(dt); } // [[Rcpp::export]] SEXP Datetime_ctor_sexp(Datetime d) { Datetime dt = Datetime(d); return wrap(dt); } // [[Rcpp::export]] SEXP DatetimeVector_ctor(DatetimeVector d) { DatetimeVector dt = DatetimeVector(d); return wrap(dt); }