[Rcpp-devel] R.e. Debugging Rcpp packages with GDB
Dirk Eddelbuettel
edd at debian.org
Wed Jan 19 01:19:32 CET 2011
On 18 January 2011 at 15:52, Christian Gunning wrote:
| On Tue, Jan 18, 2011 at 2:46 PM,
| <rcpp-devel-request at lists.r-forge.r-project.org> wrote:
| >
| > Can people share any tricks they use to debug Rcpp packages? For example, can I "print" variables in a format that's a bit more high-level, like something that I would get if I sent them to "cout"?
| >
|
| It's not very sophisticated, but I find that much of the time adding
| Rf_PrintValue(xx) calls to code gives me as much info as I need. If
| it's a non-SEXP object like int, then Rf_PrintValue(wrap(my_int)).
|
| > If that's not entirely obvious from my question, I am not a GDB expert. :-) Basically, my workflow is: "attach to the R process", "set a breakpoint at the function entry point", "single-step and print variable values". I have used watches and conditional breakpoints in GUI debuggers, but not (yet) in gdb. Are there any Rcpp-specific gotchas to using those features with GDB?
|
| I have 2 related "simple questions" after reading through Chapters 1
| and 4 of "Writing R Extensions":
|
| My build/test chain is:
|
| R CMD INSTALL mypackage
| R --vanilla --debugger gdb
| run
| require(mypackage)
| <test in R>
| quit()
| <edit code>
| R CMD INSTALL mypackage
| run
| require(mypackage) ## reload package with edits
| <lather, rinse, repeat>
|
| 1) Is there a "best" way to reload the shared library after
| rebuilding it? dyn.unload() and dyn.load()?
I am partial to littler. Eg sometimes I just do
$ R CMD INSTALL foo && r -lfoo -e'someExpressionIWantToTest()'
Because the 'r' (littler) starts fresh sessions I do not need to worry about
unload. In other cases I use inline -- it depends.
| 2) Is there a simple way to include debugging symbols/keep values from
| getting optimized out when building with Rcpp?
You could always include -g and then strip what you don't need -- which is
what Debian and Ubuntu do to give you the *-dbg packages.
R sits on top of Makefile logic, and make is pretty powerful language. You
can (literally) do just about anything.... Setting CFGLAGS / CXXFLAGS or
their PKG_* variants is probably easiest.
Dirk
--
Dirk Eddelbuettel | edd at debian.org | http://dirk.eddelbuettel.com
More information about the Rcpp-devel
mailing list