Ask Your Question

What is your favorite way to debug sage code?

asked 2010-10-13 10:42:44 -0500

Philipp Schneider gravatar image

How do you debug sage code?

My favorite way do debug Python code is to use pdb in GUD emacs-mode.

I split the window into two buffers; in one I interact with pdb, in the other I see the code I'm debugging with the current line highlighted. When I step into a function which is defined in a different file, this window automatically shows the content of the new file.

Is it possible to use pdb and GUD with sage? Or is it possible to achieve this effect in a different way?

edit retag flag offensive close merge delete

1 answer

Sort by ยป oldest newest most voted

answered 2010-10-13 12:23:20 -0500

Mitesh Patel gravatar image

Here's one way to use Emacs' Grand Unified Debugger (GUD) with the Sage library:

  • Ensure sage is in the PATH.
  • cd SAGE_ROOT
  • cp local/lib/python/ .
  • Change the first line of to #!/usr/bin/env sage
  • Run emacs and type M-x pdb + <ENTER>
  • Use Run pdb (like this): ./ to debug


  • should contain a statement like from sage.all import *, in order to use Sage library code.
  • The code in should not require the Sage preparser. You'll need to use R = PolynomialRing(QQ, 'a,b,c'), for example, instead of R.<a,b,c> = QQ[].

I hope there's a better way! But with this approach, stepping into R = PolynomialRing(QQ, 'a,b,c') will make Emacs jump to the appropriate line of

edit flag offensive delete link more


Thanks. This is not a pretty solution, but it works. Also, instead of avoiding code that needs to be preparsed I can run sage -preparse foo.sage and then debug the resulting

Philipp Schneider gravatar imagePhilipp Schneider ( 2010-10-13 13:12:39 -0500 )edit

I sometimes use the trace() function in Sage for a quick debugging job.

mvngu gravatar imagemvngu ( 2010-10-13 13:48:12 -0500 )edit

Your Answer

Please start posting anonymously - your entry will be published after you log in or create a new account.

Add Answer

[hide preview]

Question Tools


Asked: 2010-10-13 10:42:44 -0500

Seen: 972 times

Last updated: Oct 13 '10