Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Cython debugging, put a break point

I am trying to use cython debugger to put in a break point:

Here is my code:

cython_file.pyx

cimport cython

def big_sum():
    cdef int a[10000]

    for i in range(10000):
        a[i] = i
    # <==================== I want to put a break here     
    cdef int my_sum
    my_sum = 0
    for i in range(1000):
        my_sum += a[i]
    return my_sum

python_file.py

from cython_file import big_sum

result = big_sum()
print result

setup.py

from distutils.core import setup
from distutils.extension import Extension
from Cython.Distutils import build_ext

setup(
    cmdclass = {'build_ext': build_ext},
    ext_modules = [Extension("cython_file",
                             ["cython_file.pyx"], pyrex_gdb=True,
                             extra_compile_args=["-g"], extra_link_args=["-g"])]
)

I was following this guide:

This is what I did in the ubuntu shell:

cython --gdb cython_file.pyx
python setup.py build_ext --inplace
cygdb

Now I am inside the debugger, and I should be able to put in a break point, but when i try:

(gdb) cy break cython_file.big_sum :8

I get this error:

Function "__pyx_pw_11cython_file_1big_sum" not defined.
Breakpoint 1 (__pyx_pw_11cython_file_1big_sum) pending.
No frame is currently selected.

How should I set the break point correctly?

Update: I still have a problem even when I use setup.py provided by Drew McInnis:

user@Ubuntu-K56CA:~/PythonStuff/CythonStuff/cython_debug_2$ cython --gdb cython_file.pyx
user@Ubuntu-K56CA:~/PythonStuff/CythonStuff/cython_debug_2$ python setup.py build_ext --inplace
/usr/lib/python2.7/distutils/dist.py:267: UserWarning: Unknown distribution option: 'extensions'
  warnings.warn(msg)
running build_ext
building 'cython_file' extension
gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -I/usr/include/python2.7 -c cython_file.c -o build/temp.linux-x86_64-2.7/cython_file.o
gcc -pthread -shared -Wl,-O1 -Wl,-Bsymbolic-functions -Wl,-Bsymbolic-functions -Wl,-z,relro build/temp.linux-x86_64-2.7/cython_file.o -o /home/user/PythonStuff/CythonStuff/cython_debug_2/cython_file.so
user@Ubuntu-K56CA:~/PythonStuff/CythonStuff/cython_debug_2$ cygdb .
GNU gdb (GDB) 7.5-ubuntu
Copyright (C) 2012 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-linux-gnu".
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
(gdb) cy run python_file.py
499500


(gdb) cy break cython_file.big_sum
Breakpoint 1 at 0x7ffff63e7780: file cython_file.c, line 649.
(gdb) cy run python_file.py
1    cimport cython

I notice that I get this warning:

user@Ubuntu-K56CA:~/PythonStuff/CythonStuff/cython_debug_2$ python setup.py build_ext --inplace

/usr/lib/python2.7/distutils/dist.py:267: UserWarning: Unknown distribution option: 'extensions

Could that be the problem?

I am using Cython version 0.19.1, Python 2.7.3, and ubuntu 12.10.

like image 453
Akavall Avatar asked Jan 09 '14 23:01

Akavall


Video Answer


1 Answers

I believe you are setting the breakpoint correctly. The cython_file.so shared library created by cython isn't loaded by the interpreter until the module is imported. So the pending gdb breakpoint is fine as gdb will set this breakpoint when cython_file.so is dynamically loaded.

UPDATE 1: I did modify the setup.py slightly from what was posted. I based my setup.py on these cython debugging instructions... the main difference being the use of cythonize:

setup.py

from distutils.core import setup
from distutils.extension import Extension
from Cython.Build import cythonize

setup(
    extensions = [Extension('cython_file', ["cython_file.pyx"])],
    ext_modules=cythonize(Extension("cython_file", ["cython_file.pyx"]),
                          gdb_debug=True)
)

UPDATE 3: For reference, here are the commands I used to get setup. They differ slightly from those posted in the question as I didn't add the --pyrex-gdb option when running setup.py:

$ ls
cython_file.pyx  python_file.py  setup.py
$ cython --gdb cython_file.pyx 
$ python setup.py build_ext --inplace

UPDATE 2: Here is my sample cygdb session using your files, first I let python_file.py run to completion and then I set the breakpoint and re-ran:

drew@ubuntu:~/stackoverflow/21033553-cython$ cygdb .

GNU gdb (Ubuntu/Linaro 7.4-2012.04-0ubuntu2.1) 7.4-2012.04
Copyright (C) 2012 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-linux-gnu".
For bug reporting instructions, please see:
<http://bugs.launchpad.net/gdb-linaro/>.
Install pygments for colorized source code.
Python was not compiled with debug symbols (or it was stripped). 
Some functionality may not work (properly).
(gdb) cy run python_file.py
499500

(gdb) cy break cython_file.big_sum
Breakpoint 1 at 0x7ffff5db0270: file cython_file.c, line 435.
No frame is currently selected.
(gdb) cy run python_file.py
3    def big_sum():
(gdb) cy break :10
Breakpoint 2 at 0x7ffff5db02a6: file cython_file.c, line 468.
(gdb) cy cont
11        for i in range(1000):
(gdb) cy list
     6        for i in range(10000):
     7            a[i] = i
     8        # <==================== I want to put a break here
     9        cdef int my_sum
    10        my_sum = 0
>   11        for i in range(1000):
    12            my_sum += a[i]
    13        return my_sum
    14    
like image 55
Drew MacInnis Avatar answered Sep 21 '22 06:09

Drew MacInnis