[Rd] Feature request: txtProgressBar with ability to write to arbitrary stream

Duncan Murdoch murdoch.duncan at gmail.com
Tue Mar 15 15:57:16 CET 2011


On 15/03/2011 8:46 AM, Matt Shotwell wrote:
> Here's a temporary fix; reassign 'cat' in the environment of
> 'txtProgressBar':
>
> tpbEnv<- new.env()
> assign("cat", function(...) cat(file=stderr(),...), tpbEnv)
> environment(txtProgressBar)<- tpbEnv

I would suggest renaming the function as well.  What's done above 
creates a new function called txtProgressBar, it doesn't modify the 
original one, so depending on scoping issues it may appear to only work 
sometimes.  But if you did

stderrProgressBar <- txtProgressBar
environment(stderrProgressBar) <- tpbEnv

you'll get clear messages if it is out of scope when you try to use it.

Duncan Murdoch

> Best,
> Matt
>
>
> On 03/15/2011 05:37 AM, Andreas Borg wrote:
> >  Hi all,
> >
> >  I use txtProgressBar to monitor progress of large computations. What I
> >  miss is the ability to redirect the progress bar to a stream other than
> >  stdout, specifically to the message stream. This would be useful for
> >  running Sweave scripts: When redirected to stderr, the bar could be
> >  visible even though console output is diverted to the output file (and
> >  there would be no cluttering of the generated latex).
> >
> >  I'd suggest the following changes to txtProgressBar:
> >  - a new argument 'file' (compare to 'cat') which defaults to stderr()
> >  (there might be reasons to use stdout(), but I believe a progress bar is
> >  mostly intended as a diagnostic tool and not for console output, which
> >  is printed or saved in some cases).
> >  - the calls to 'cat' that update the progress bar get 'file = file' as
> >  additional argument so that output is redirected as desired.
> >
> >  In case anyone from the core team is willing to incorparate this idea, I
> >  attached the patch file for the necessary changes below.
> >
> >  Best regards,
> >
> >  Andreas
> >
> >  3c3
> >  <  width = NA, title, label, style = 1)
> >  ---
> >   >  width = NA, title, label, style = 1, file=stderr())
> >  23c23
> >  <  cat(paste(rep.int(char, nb-.nb), collapse=""))
> >  ---
> >   >  cat(paste(rep.int(char, nb-.nb), collapse=""), file = file)
> >  27c27
> >  <  "\r", paste(rep.int(char, nb), collapse=""), sep = "")
> >  ---
> >   >  "\r", paste(rep.int(char, nb), collapse=""), sep = "", file = file)
> >  38c38
> >  <  cat("\r", paste(rep.int(char, nb), collapse=""), sep = "")
> >  ---
> >   >  cat("\r", paste(rep.int(char, nb), collapse=""), sep = "", file = file)
> >  42c42
> >  <  "\r", paste(rep.int(char, nb), collapse=""), sep = "")
> >  ---
> >   >  "\r", paste(rep.int(char, nb), collapse=""), sep = "", file = file)
> >  54c54
> >  <  cat(paste(c("\r |", rep.int(" ", nw*width+6)), collapse=""))
> >  ---
> >   >  cat(paste(c("\r |", rep.int(" ", nw*width+6)), collapse=""), file =
> >  file)
> >  59c59
> >  <  ), collapse=""))
> >  ---
> >   >  ), collapse=""), file = file)
> >  68c68
> >  <  cat("\n")
> >  ---
> >   >  cat("\n", file = file)
> >
>
>



More information about the R-devel mailing list