[Rd] readLines function with R >= 3.5.0

Jennifer Lyon jennifer@@@lyon @ending from gm@il@com
Wed Jun 20 00:45:23 CEST 2018


Hi Michael:

I can confirm Martin's comment. I tested my software with r-devel (r74914)
and it works, while with r-patched (r74914) it does not work (it hangs, as
it did in R 3.5.0). I apologize for it taking so long for me to test this,
but is there any chance this fix could make into R 3.5.1?

Thanks.

Jen.

On Wed, Jun 13, 2018 at 6:24 AM, Michael Lawrence <lawrence.michael using gene.com
> wrote:

> Are you sure it's not available in patched? It's definitely in the
> source since 6/1.
>
> Michael
>
>
> On Wed, Jun 13, 2018 at 2:19 AM, Martin Maechler
> <maechler using stat.math.ethz.ch> wrote:
> >>>>>> Michael Lawrence
> >>>>>>     on Tue, 12 Jun 2018 19:27:49 -0700 writes:
> >
> >     > Hi Jen, This was already resolved for R 3.5.1 by just
> >     > disabling buffering on terminal file connections like stdin.
> >
> > and before R 3.5.1 exists, *and*
> > as the change is also not yet available in R patched (!)
> > this means using a version of
> > "R-devel", e.g. for Windows available from
> >    https://cloud.r-project.org/bin/windows/base/rdevel.html
> >
> > Martin
> >
> >     > Sounds like you might want to be running a web service or
> >     > something instead though.
> >
> >     > Michael
> >
> >     > On Tue, Jun 12, 2018 at 4:46 PM, Jennifer Lyon
> >     > <jennifer.s.lyon using gmail.com> wrote:
> >     >> Hi:
> >     >>
> >     >> I have also just stumbled into this bug. Unfortunately, I
> >     >> can not change the data my program receives from
> >     >> stdin. My code runs in a larger system and stdin is sent
> >     >> to a Docker container running my R code. The protocol is
> >     >> I read a line, readLines("stdin", n=1), do some actions,
> >     >> send output on stdout, and wait for the next set of data.
> >     >> I don't have control over this protocol, so I can't use
> >     >> the ^D workaround.
> >     >>
> >     >> I am open for other workaround suggestions. The single
> >     >> line is actually JSON and can be quite large. If there
> >     >> isn't something else cleaner, I am going to try
> >     >> readChar() in a while loop looking for \n but I'm
> >     >> guessing that would likely be too slow.  I am open to
> >     >> other workaround solutions. For the moment I have
> >     >> reverted back to R 3.4.4.
> >     >>
> >     >> Thanks for any suggestions.
> >     >>
> >     >> Jen.
> >     >>
> >     >>
> >     >>>> >>>>> Martin Maechler >>>>> on Mon, 28 May 2018
> >     >>>> 10:28:01 +0200 writes:
> >     >>>>
> >     >>>> >>>>> Ralf Stubner >>>>> on Fri, 25 May 2018 19:18:58
> >     >>>> +0200 writes:
> >     >>>>
> >     >>>> >> Dear all, I would like to draw you attention to this
> >     >>>> >> question on SO:
> >     >>>> >>
> >     >> https://stackoverflow.com/questions/50372043/readlines-
> function-with-new-version-of-r
> >     >>>>
> >     >>>>
> >     >>>> >> Based on the OP's code I used the script
> >     >>>>
> >     >>>> >> #######################################
> >     >>>> >> create_matrix <- function() { >> cat("Write the
> >     >>>> numbers of vertices: ") >> user_input <-
> >     >>>> readLines("stdin", n=1) >> user_input <-
> >     >>>> as.numeric(user_input) >> print(user_input) >> } >>
> >     >>>> create_matrix()
> >     >>>> >> #######################################
> >     >>>>
> >     >>>> >> and called it with "R -f <filename>" from the
> >     >>>> command line.
> >     >>>>
> >     >>>> >> With 'R version 3.4.4 (2018-03-15) -- "Someone to
> >     >>>> Lean On"' the
> >     >> script
> >     >>>> >> prints the inputed number as expected. With both 'R
> >     >>>> version 3.5.0 >> (2018-04-23) -- "Joy in Playing"' and
> >     >>>> 'R Under development
> >     >> (unstable)
> >     >>>> >> (2018-05-19 r74746) -- "Unsuffered Consequences"'
> >     >>>> the script does
> >     >> not
> >     >>>> >> continue after inputing a number.
> >     >>>>
> >     >>>> > I can confirm.  > It "works" if you additionally (the
> >     >>>> [Enter], i.e., EOL) you also > "send" an EOF -- in Unix
> >     >>>> alikes via <Ctrl>-D
> >     >>>>
> >     >>>> > The same happens if you use 'Rscript <filename>'
> >     >>>>
> >     >>>> > I'm not the expert here, but am close to sure that we
> >     >>>> (R core) > did not intend this change, when fixing
> >     >>>> other somewhat subtle > bugs in Rscript / 'R -f'
> >     >>>>
> >     >>>> > Martin Maechler
> >     >>>>
> >     >>>> The same behavior in regular R , no need for a script
> >     >>>> etc.
> >     >>>>
> >     >>>> > str(readLines("stdin", n=1))
> >     >>>>
> >     >>>> then in addition to the input you need to "give" an EOF
> >     >>>> (Ctrl D) in R
> >     >>> = 3.5.0
> >     >>>>
> >     >>>> Interestingly, everything works fine if you use stdin()
> >     >>>> instead of "stdin" :
> >     >>>>
> >     >>>> > rr <- readLines(stdin(), n=1) foo > rr [1] "foo"
> >     >>>> >
> >     >>>> ----------
> >     >>>>
> >     >>>> So, for now use stdin() which is much clearer than the
> >     >>>> string "stdin" anyway
> >     >>>>
> >     >>>> Martin Maechler
> >     >>
> >     >> [[alternative HTML version deleted]]
> >     >>
> >     >> ______________________________________________
> >     >> R-devel using r-project.org mailing list
> >     >> https://stat.ethz.ch/mailman/listinfo/r-devel
> >
> >     > ______________________________________________
> >     > R-devel using r-project.org mailing list
> >     > https://stat.ethz.ch/mailman/listinfo/r-devel
>

	[[alternative HTML version deleted]]



More information about the R-devel mailing list