[Rd] readBin(what="character", n=overcount)->extra "" in result (PR#9363)

bill at insightful.com bill at insightful.com
Mon Nov 13 21:06:40 CET 2006


On Mon, 13 Nov 2006 bill at insightful.com wrote:

> When I use readBin() to read an unknown number
> of null-terminated strings from a file by supplying
> an overcount as the n= argument, it appends an empty
> string to the result.
>
> > tf<-tempfile()
> > strings<-c("One","Two","Three")
> > writeBin(strings, con=tf)
> > readBin(con=tf,what="character",n=100) # expect "One","Two","Three" only
> [1] "One"   "Two"   "Three" ""

I think the fix is to src/library/connections.c, where
m (the number of items read) is initialized to 1 instead
of 0.  It is later used to shorten the vector of read
objects:
    if(m < n) {
        PROTECT(ans = lengthgets(ans, m));
        UNPROTECT(1);
    }

*** connections.c-orig	2006-09-13 19:05:06.000000000 -0700
--- connections.c	2006-11-13 11:46:35.000000000 -0800
***************
*** 2740,2746 ****
      if(!strcmp(what, "character")) {
  	SEXP onechar;
  	PROTECT(ans = allocVector(STRSXP, n));
! 	for(i = 0, m = i+1; i < n; i++) {
  	    onechar = isRaw ? rawOneString(bytes, nbytes, &np)
  		: readOneString(con);
  	    if(onechar != R_NilValue) {
--- 2740,2746 ----
      if(!strcmp(what, "character")) {
  	SEXP onechar;
  	PROTECT(ans = allocVector(STRSXP, n));
! 	for(i = 0, m = 0; i < n; i++) {
  	    onechar = isRaw ? rawOneString(bytes, nbytes, &np)
  		: readOneString(con);
  	    if(onechar != R_NilValue) {



More information about the R-devel mailing list