I am calling an R function from the R package e1071 which is interfaced with libsvm (a C program). This function is passing C (printf) warning messages to the R console. I know this because the warning messages are of the form (warning:…) whereas R warning messages are capitalized (i.e. Warning:…).
I’ve tried everything to get rid of these messages in R (sink, suppressWarnings, invisible) but nothing seems to work.
Any ideas?
Thanks!
The function uses stdio instead of
Rprintf/REprintforwarningwhich is why re-direction of the R output won’t work. The proper solution is to fix the calls inlibsvmto use R output instead.Hacking the stdio output is possible – you can re-direct the output to your own pipe and do what you want with it, but a) it’s a bit of work in C and b) it’s dangerous because you need to restore the standard behavior after you’re done with the function – even if it errors out and c) in may interact with R output if used on a shell.
If you want a really whacky, dirty yet quick solution, run your function in
collect(parallel(..., silent=TRUE))[[1]]frommulticore– it suppresses stdout (you can addmulticore:::closeStderr()if you want to suppress stderr as well).