R/with.R

Defines functions within.Message with.Message generateActiveBindings

Documented in within.Message with.Message

# S3 dispatch does not work for some reason

generateActiveBindings <- function(data){
	env <- new.env( parent = environment() )
	xp <- data@pointer
	names <- .Call(Message__fieldNames, xp)

	if( !is.null(names) && length(names) ){
		lapply( names, function(x ){
  		  makeActiveBinding( x, function(v){
  		    if( missing(v) ){
  		    	# get
  		      .Call(getMessageField, xp, x)
  		    } else {
  		    	# set
  		      .Call(setMessageField, xp, x, v)
  		    }
  		  }, env )
  		} )
  	}
  	env
}

with.Message <- function( data, expr, ...){
	envir <- generateActiveBindings(data)
  	eval( substitute( expr ), envir = envir )
}

within.Message <- function(data, expr, ... ){
	envir <- generateActiveBindings(data)
  	eval( substitute( expr ), envir = envir )
  	data
}
eddelbuettel/rprotobuf documentation built on March 27, 2024, 12:22 p.m.