[Rcpp-devel] [Rcpp-commits] r341 - in pkg: inst inst/unitTests src src/Rcpp
noreply at r-forge.r-project.org
noreply at r-forge.r-project.org
Mon Jan 11 15:14:09 CET 2010
Author: romain
Date: 2010-01-11 15:14:09 +0100 (Mon, 11 Jan 2010)
New Revision: 341
Modified:
pkg/inst/ChangeLog
pkg/inst/unitTests/runit.environments.R
pkg/src/Environment.cpp
pkg/src/Rcpp/Environment.h
Log:
+Environment::operator[]( const std::string )
Modified: pkg/inst/ChangeLog
===================================================================
--- pkg/inst/ChangeLog 2010-01-11 12:58:22 UTC (rev 340)
+++ pkg/inst/ChangeLog 2010-01-11 14:14:09 UTC (rev 341)
@@ -1,5 +1,12 @@
2010-01-10 Romain Francois <francoisromain at free.fr>
+ * src/Rcpp/Environment.h: operator[](string) for environment
+ allowing to get/set values of a binding in this environment.
+ The Environment::Binding class has been created to act as
+ a proxy.
+ * src/Environment.cpp: idem
+ * inst/unitTests/runit.environments.R: unit tests for the above
+
* src/Rcpp/Pairlist.h: operator[] for pairlist using proxies
* src/Pairlist.cpp : idem
* inst/unitTests/runit.Pairlist.R: new unit tests
Modified: pkg/inst/unitTests/runit.environments.R
===================================================================
--- pkg/inst/unitTests/runit.environments.R 2010-01-11 12:58:22 UTC (rev 340)
+++ pkg/inst/unitTests/runit.environments.R 2010-01-11 14:14:09 UTC (rev 341)
@@ -303,3 +303,24 @@
checkEquals( funx(e), emptyenv() , msg = "Environment::parent" )
}
+
+test.environment.square <- function(){
+
+ funx <- cfunction(signature( env = "environment" ), '
+ Environment e(env) ;
+ List out(3) ;
+ out[0] = e["x"] ;
+ e["y"] = 2 ;
+ out[1] = e["y"] ;
+ e["x"] = "foo";
+ out[2] = e["x"] ;
+ return out ;
+ ', Rcpp=TRUE, verbose=FALSE, includes = "using namespace Rcpp;" )
+
+ env <- new.env( )
+ env[["x"]] <- 10L
+ checkEquals( funx(env), list( 10L, 2L, "foo") )
+
+}
+
+
Modified: pkg/src/Environment.cpp
===================================================================
--- pkg/src/Environment.cpp 2010-01-11 12:58:22 UTC (rev 340)
+++ pkg/src/Environment.cpp 2010-01-11 14:14:09 UTC (rev 341)
@@ -23,6 +23,7 @@
#include <Rcpp/Evaluator.h>
#include <Rcpp/Symbol.h>
#include <Rcpp/Language.h>
+#include <Rcpp/wrap.h>
namespace Rcpp {
@@ -265,5 +266,56 @@
}
Environment::no_such_env::~no_such_env() throw() {}
+
+
+ Environment::Binding::Binding( Environment& env, const std::string& name):
+ env(env), name(name){}
+
+ bool Environment::Binding::active() const{
+ return env.bindingIsActive( name ) ;
+ }
+
+ bool Environment::Binding::exists() const{
+ return env.exists( name ) ;
+ }
+
+ bool Environment::Binding::locked() const{
+ return env.bindingIsLocked( name ) ;
+ }
+
+ void Environment::Binding::lock() {
+ env.lockBinding( name ) ;
+ }
+
+ void Environment::Binding::unlock() {
+ env.unlockBinding( name ) ;
+ }
+
+ Environment::Binding& Environment::Binding::operator=( SEXP rhs ){
+ env.assign( name, rhs ) ;
+ return *this ;
+ }
+
+ Environment::Binding& Environment::Binding::operator=( const Binding& rhs){
+ env.assign( name, rhs.env.get(rhs.name) ) ;
+ return *this ;
+ }
+
+ Environment::Binding::operator SEXP() const{
+ return env.get( name );
+ }
+
+ Environment::Binding::operator RObject() const{
+ return wrap( env.get( name ) );
+ }
+
+ const Environment::Binding Environment::operator[]( const std::string& name) const{
+ return Binding( const_cast<Environment&>(*this), name );
+ }
+
+ Environment::Binding Environment::operator[]( const std::string& name) {
+ return Binding( *this, name ) ;
+ }
+
} // namespace Rcpp
Modified: pkg/src/Rcpp/Environment.h
===================================================================
--- pkg/src/Rcpp/Environment.h 2010-01-11 12:58:22 UTC (rev 340)
+++ pkg/src/Rcpp/Environment.h 2010-01-11 14:14:09 UTC (rev 341)
@@ -120,6 +120,39 @@
std::string message ;
} ;
+ class Binding {
+ public:
+ Binding( Environment& env, const std::string& name) ;
+
+ bool active() const ;
+ bool locked() const ;
+ bool exists() const ;
+ void lock( ) ;
+ void unlock() ;
+
+ /* lvalue uses */
+ Binding& operator=(const Binding& rhs) ;
+ Binding& operator=(SEXP rhs) ;
+
+ template <typename T>
+ Binding& operator=(const T& rhs){
+ env.assign( name, wrap(rhs) ) ;
+ return *this ;
+ }
+
+ /* rvalue */
+ operator SEXP() const ;
+ operator RObject() const ;
+
+ private:
+ Environment& env ;
+ std::string name ;
+ } ;
+
+ const Binding operator[]( const std::string& name) const ;
+ Binding operator[](const std::string& name) ;
+ friend class Binding ;
+
/**
* wraps the given environment
*
_______________________________________________
Rcpp-commits mailing list
Rcpp-commits at lists.r-forge.r-project.org
https://lists.r-forge.r-project.org/cgi-bin/mailman/listinfo/rcpp-commits
More information about the Rcpp-devel
mailing list