Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cython
Commits
5188094b
Commit
5188094b
authored
Feb 20, 2015
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
document line tracing support
parent
11a2900a
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
32 additions
and
11 deletions
+32
-11
docs/src/reference/compilation.rst
docs/src/reference/compilation.rst
+8
-10
docs/src/tutorial/profiling_tutorial.rst
docs/src/tutorial/profiling_tutorial.rst
+24
-1
No files found.
docs/src/reference/compilation.rst
View file @
5188094b
...
@@ -348,19 +348,17 @@ Cython code. Here is the list of currently supported directives:
...
@@ -348,19 +348,17 @@ Cython code. Here is the list of currently supported directives:
calling conventions but disallow the use of keywords.
calling conventions but disallow the use of keywords.
``profile`` (True / False)
``profile`` (True / False)
Add
hooks for Python profilers into the compiled C code. Default
Write
hooks for Python profilers into the compiled C code. Default
is False.
is False.
``linetrace`` (True / False)
``linetrace`` (True / False)
Add line tracing hooks for Python profilers into the compiled C code.
Write line tracing hooks for Python profilers or coverage reporting
This also enables profiling. Default is False. Note that the
into the compiled C code. This also enables profiling. Default is
generated module will not actually use line tracing, unless you
False. Note that the generated module will not actually use line
additionally pass the C macro definition ``CYTHON_TRACE=1`` to the
tracing, unless you additionally pass the C macro definition
C compiler (e.g. using the distutils option ``define_macros``).
``CYTHON_TRACE=1`` to the C compiler (e.g. using the distutils option
``define_macros``). Define ``CYTHON_TRACE_NOGIL=1`` to also include
Note that this feature is currently EXPERIMENTAL. It will slow down
``nogil`` functions and sections.
your code, may not work at all for what you want to do with it, and
may even crash arbitrarily.
``infer_types`` (True / False)
``infer_types`` (True / False)
Infer types of untyped variables in function bodies. Default is
Infer types of untyped variables in function bodies. Default is
...
...
docs/src/tutorial/profiling_tutorial.rst
View file @
5188094b
...
@@ -38,7 +38,7 @@ from the cProfile module. This means you can just profile your Cython code
...
@@ -38,7 +38,7 @@ from the cProfile module. This means you can just profile your Cython code
together with your Python code using the same tools as for Python code alone.
together with your Python code using the same tools as for Python code alone.
Disabling profiling function wise
Disabling profiling function wise
---------------------------------
---------
---------------------------------
If your profiling is messed up because of the call overhead to some small
If your profiling is messed up because of the call overhead to some small
functions that you rather do not want to see in your profile - either because
functions that you rather do not want to see in your profile - either because
...
@@ -53,6 +53,29 @@ function only::
...
@@ -53,6 +53,29 @@ function only::
pass
pass
Enabling line tracing
---------------------
To get more detailed trace information (for tools that can make use of it),
you can enable line tracing::
# cython: linetrace=True
This will also enable profiling support, so the above ``profile=True`` option
is not needed. Line tracing is needed for coverage analysis, for example.
Note that even if line tracing is enabled via the compiler directive, it is
not used by default. As the runtime slowdown can be substantial, it must
additionally be compiled in by the C compiler by setting the C macro definition
``CYTHON_TRACE=1``. To include nogil functions in the trace, set
``CYTHON_TRACE_NOGIL=1`` (which enforces ``CYTHON_TRACE=1``). C macros can be
defined either in the extension definition of the ``setup.py`` script or by
setting the respective distutils options in the source file with the following
file header comment (if ``cythonize()`` is used for compilation)::
# distutils: define_macros=CYTHON_TRACE_NOGIL=1
.. _profiling_tutorial:
.. _profiling_tutorial:
Profiling Tutorial
Profiling Tutorial
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment