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
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
ae9a7c07
Commit
ae9a7c07
authored
Apr 10, 2011
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Plain Diff
merge
parents
3c612380
deaa7d0f
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
225 additions
and
108 deletions
+225
-108
Cython/Compiler/Buffer.py
Cython/Compiler/Buffer.py
+2
-2
Cython/Compiler/Code.py
Cython/Compiler/Code.py
+1
-1
Cython/Compiler/ExprNodes.py
Cython/Compiler/ExprNodes.py
+3
-3
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+1
-1
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+9
-5
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+1
-1
Cython/Includes/numpy.pxd
Cython/Includes/numpy.pxd
+3
-0
docs/src/reference/compilation.rst
docs/src/reference/compilation.rst
+205
-95
No files found.
Cython/Compiler/Buffer.py
View file @
ae9a7c07
...
@@ -967,7 +967,7 @@ static int __Pyx_BufFmt_ProcessTypeChunk(__Pyx_BufFmt_Context* ctx) {
...
@@ -967,7 +967,7 @@ static int __Pyx_BufFmt_ProcessTypeChunk(__Pyx_BufFmt_Context* ctx) {
if (ctx->fmt_offset != offset) {
if (ctx->fmt_offset != offset) {
PyErr_Format(PyExc_ValueError,
PyErr_Format(PyExc_ValueError,
"Buffer dtype mismatch; next field is at offset %"PY_FORMAT_SIZE_T"d "
"Buffer dtype mismatch; next field is at offset %"PY_FORMAT_SIZE_T"d "
"but %"PY_FORMAT_SIZE_T"d expected",
ctx->fmt_offset,
offset);
"but %"PY_FORMAT_SIZE_T"d expected",
(Py_ssize_t)ctx->fmt_offset, (Py_ssize_t)
offset);
return -1;
return -1;
}
}
...
@@ -1168,7 +1168,7 @@ static CYTHON_INLINE int __Pyx_GetBufferAndValidate(Py_buffer* buf, PyObject* ob
...
@@ -1168,7 +1168,7 @@ static CYTHON_INLINE int __Pyx_GetBufferAndValidate(Py_buffer* buf, PyObject* ob
"Item size of buffer (%"PY_FORMAT_SIZE_T"d byte%s) does not match size of '%s' (%"PY_FORMAT_SIZE_T"d byte%s)",
"Item size of buffer (%"PY_FORMAT_SIZE_T"d byte%s) does not match size of '%s' (%"PY_FORMAT_SIZE_T"d byte%s)",
buf->itemsize, (buf->itemsize > 1) ? "s" : "",
buf->itemsize, (buf->itemsize > 1) ? "s" : "",
dtype->name,
dtype->name,
dtype->size, (dtype->size > 1) ? "s" : "");
(Py_ssize_t)
dtype->size, (dtype->size > 1) ? "s" : "");
goto fail;
goto fail;
}
}
if (buf->suboffsets == NULL) buf->suboffsets = __Pyx_minusones;
if (buf->suboffsets == NULL) buf->suboffsets = __Pyx_minusones;
...
...
Cython/Compiler/Code.py
View file @
ae9a7c07
...
@@ -1374,7 +1374,7 @@ class CCodeWriter(object):
...
@@ -1374,7 +1374,7 @@ class CCodeWriter(object):
return
self
.
globalstate
.
lookup_filename
(
filename
)
return
self
.
globalstate
.
lookup_filename
(
filename
)
def
put_declare_refcount_context
(
self
):
def
put_declare_refcount_context
(
self
):
self
.
putln
(
'__Pyx_RefNannyDeclarations
;
'
)
self
.
putln
(
'__Pyx_RefNannyDeclarations'
)
def
put_setup_refcount_context
(
self
,
name
):
def
put_setup_refcount_context
(
self
,
name
):
self
.
putln
(
'__Pyx_RefNannySetupContext("%s");'
%
name
)
self
.
putln
(
'__Pyx_RefNannySetupContext("%s");'
%
name
)
...
...
Cython/Compiler/ExprNodes.py
View file @
ae9a7c07
...
@@ -7776,7 +7776,7 @@ static PyObject *__Pyx_FindPy2Metaclass(PyObject *bases) {
...
@@ -7776,7 +7776,7 @@ static PyObject *__Pyx_FindPy2Metaclass(PyObject *bases) {
#if PY_MAJOR_VERSION < 3
#if PY_MAJOR_VERSION < 3
if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
PyObject *base = PyTuple_GET_ITEM(bases, 0);
PyObject *base = PyTuple_GET_ITEM(bases, 0);
metaclass = PyObject_GetAttrString(base, "__class__");
metaclass = PyObject_GetAttrString(base,
(char *)
"__class__");
if (!metaclass) {
if (!metaclass) {
PyErr_Clear();
PyErr_Clear();
metaclass = (PyObject*) Py_TYPE(base);
metaclass = (PyObject*) Py_TYPE(base);
...
@@ -7854,7 +7854,7 @@ PyObject *__Pyx_Py3MetaclassPrepare(PyObject *metaclass, PyObject *bases, PyObje
...
@@ -7854,7 +7854,7 @@ PyObject *__Pyx_Py3MetaclassPrepare(PyObject *metaclass, PyObject *bases, PyObje
PyObject *ns;
PyObject *ns;
PyObject *str;
PyObject *str;
prep = PyObject_GetAttrString(metaclass, "__prepare__");
prep = PyObject_GetAttrString(metaclass,
(char *)
"__prepare__");
if (!prep) {
if (!prep) {
if (!PyErr_ExceptionMatches(PyExc_AttributeError))
if (!PyErr_ExceptionMatches(PyExc_AttributeError))
return NULL;
return NULL;
...
@@ -8560,7 +8560,7 @@ static PyObject *__Pyx_Generator_Throw(PyObject *self, PyObject *args, CYTHON_UN
...
@@ -8560,7 +8560,7 @@ static PyObject *__Pyx_Generator_Throw(PyObject *self, PyObject *args, CYTHON_UN
PyObject *tb = NULL;
PyObject *tb = NULL;
PyObject *val = NULL;
PyObject *val = NULL;
if (!PyArg_UnpackTuple(args, "throw", 1, 3, &typ, &val, &tb))
if (!PyArg_UnpackTuple(args,
(char *)
"throw", 1, 3, &typ, &val, &tb))
return NULL;
return NULL;
__Pyx_Raise(typ, val, tb);
__Pyx_Raise(typ, val, tb);
return __Pyx_Generator_SendEx(generator, NULL);
return __Pyx_Generator_SendEx(generator, NULL);
...
...
Cython/Compiler/ModuleNode.py
View file @
ae9a7c07
...
@@ -2758,7 +2758,7 @@ proto="""
...
@@ -2758,7 +2758,7 @@ proto="""
} __Pyx_RefNannyAPIStruct;
} __Pyx_RefNannyAPIStruct;
static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); /*proto*/
static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); /*proto*/
#define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL
#define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL
;
#define __Pyx_RefNannySetupContext(name)
\
#define __Pyx_RefNannySetupContext(name)
\
__pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__)
__pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__)
#define __Pyx_RefNannyFinishContext()
\
#define __Pyx_RefNannyFinishContext()
\
...
...
Cython/Compiler/Nodes.py
View file @
ae9a7c07
...
@@ -1623,20 +1623,24 @@ class FuncDefNode(StatNode, BlockNode):
...
@@ -1623,20 +1623,24 @@ class FuncDefNode(StatNode, BlockNode):
info
=
self
.
local_scope
.
arg_entries
[
1
].
cname
info
=
self
.
local_scope
.
arg_entries
[
1
].
cname
# Python 3.0 betas have a bug in memoryview which makes it call
# Python 3.0 betas have a bug in memoryview which makes it call
# getbuffer with a NULL parameter. For now we work around this;
# getbuffer with a NULL parameter. For now we work around this;
# the following
line
should be removed when this bug is fixed.
# the following
block
should be removed when this bug is fixed.
code
.
putln
(
"if (%s
== NULL) return 0;
"
%
info
)
code
.
putln
(
"if (%s
!= NULL) {
"
%
info
)
code
.
putln
(
"%s->obj = Py_None; __Pyx_INCREF(Py_None);"
%
info
)
code
.
putln
(
"%s->obj = Py_None; __Pyx_INCREF(Py_None);"
%
info
)
code
.
put_giveref
(
"%s->obj"
%
info
)
# Do not refnanny object within structs
code
.
put_giveref
(
"%s->obj"
%
info
)
# Do not refnanny object within structs
code
.
putln
(
"}"
)
def
getbuffer_error_cleanup
(
self
,
code
):
def
getbuffer_error_cleanup
(
self
,
code
):
info
=
self
.
local_scope
.
arg_entries
[
1
].
cname
info
=
self
.
local_scope
.
arg_entries
[
1
].
cname
code
.
putln
(
"if (%s != NULL && %s->obj != NULL) {"
%
(
info
,
info
))
code
.
put_gotref
(
"%s->obj"
%
info
)
code
.
put_gotref
(
"%s->obj"
%
info
)
code
.
putln
(
"__Pyx_DECREF(%s->obj); %s->obj = NULL;"
%
code
.
putln
(
"__Pyx_DECREF(%s->obj); %s->obj = NULL;"
(
info
,
info
))
%
(
info
,
info
))
code
.
putln
(
"}"
)
def
getbuffer_normal_cleanup
(
self
,
code
):
def
getbuffer_normal_cleanup
(
self
,
code
):
info
=
self
.
local_scope
.
arg_entries
[
1
].
cname
info
=
self
.
local_scope
.
arg_entries
[
1
].
cname
code
.
putln
(
"if (%s
->obj == Py_None) {"
%
info
)
code
.
putln
(
"if (%s
!= NULL && %s->obj == Py_None) {"
%
(
info
,
info
)
)
code
.
put_gotref
(
"Py_None"
)
code
.
put_gotref
(
"Py_None"
)
code
.
putln
(
"__Pyx_DECREF(Py_None); %s->obj = NULL;"
%
info
)
code
.
putln
(
"__Pyx_DECREF(Py_None); %s->obj = NULL;"
%
info
)
code
.
putln
(
"}"
)
code
.
putln
(
"}"
)
...
...
Cython/Compiler/Parsing.py
View file @
ae9a7c07
...
@@ -2794,7 +2794,7 @@ def p_code(s, level=None):
...
@@ -2794,7 +2794,7 @@ def p_code(s, level=None):
repr
(
s
.
sy
),
repr
(
s
.
systring
)))
repr
(
s
.
sy
),
repr
(
s
.
systring
)))
return
body
return
body
COMPILER_DIRECTIVE_COMMENT_RE
=
re
.
compile
(
r"^#\
s*cy
thon:\
s*((
\w|[.])+\
s*=.*)$
")
COMPILER_DIRECTIVE_COMMENT_RE
=
re
.
compile
(
r"^#\
s*cy
thon
\
s*
:
\s*((\
w|[.])+
\s*=.*)$"
)
def
p_compiler_directive_comments
(
s
):
def
p_compiler_directive_comments
(
s
):
result
=
{}
result
=
{}
...
...
Cython/Includes/numpy.pxd
View file @
ae9a7c07
...
@@ -190,6 +190,9 @@ cdef extern from "numpy/arrayobject.h":
...
@@ -190,6 +190,9 @@ cdef extern from "numpy/arrayobject.h":
# requirements, and does not yet fullfill the PEP.
# requirements, and does not yet fullfill the PEP.
# In particular strided access is always provided regardless
# In particular strided access is always provided regardless
# of flags
# of flags
if
info
==
NULL
:
return
cdef
int
copy_shape
,
i
,
ndim
cdef
int
copy_shape
,
i
,
ndim
cdef
int
endian_detector
=
1
cdef
int
endian_detector
=
1
cdef
bint
little_endian
=
((
<
char
*>&
endian_detector
)[
0
]
!=
0
)
cdef
bint
little_endian
=
((
<
char
*>&
endian_detector
)[
0
]
!=
0
)
...
...
docs/src/reference/compilation.rst
View file @
ae9a7c07
...
@@ -2,138 +2,248 @@
...
@@ -2,138 +2,248 @@
.. _compilation:
.. _compilation:
***********
=============
Compilation
Compilation
***********
=============
* Cython code, unlike Python, must be compiled.
Cython code, unlike Python, must be compiled. This happens in two stages:
* This happens in two stages:
* A ``.pyx`` file is compiles by Cython to a ``.c`` file.
* A ``.pyx`` file is compiles by Cython to a ``.c`` file.
* The ``.c`` file is compiled by a C comiler to a ``.so`` file (or a ``.pyd`` file on Windows)
* The following sub-sections describe several ways to build your extension modules.
* The ``.c`` file is compiled by a C compiler to a ``.so`` file (or a
``.pyd`` file on Windows)
.. note:: The ``-a`` option
* Using the Cython compiler with the ``-a`` option will produce a really nice HTML file of the Cython generated ``.c`` code.
The following sub-sections describe several ways to build your
* Double clicking on the highlighted sections will expand the code to reveal what Cython has actually generated for you.
extension modules, and how to pass directives to the Cython compiler.
* This is very useful for understanding, optimizing or debugging your module.
=====================
Compiling from the command line
From the Command Line
===============================
=====================
* Run the Cython compiler command with your options and list of ``.pyx`` files to generate::
Run the Cython compiler command with your options and list of ``.pyx``
files to generate. For example::
$ cython -a yourmod.pyx
$ cython -a yourmod.pyx
* This creates a ``yourmod.c`` file. (and the -a switch produces a generated html file)
This creates a ``yourmod.c`` file, and the -a switch produces a
* Compiling your ``.c`` files will vary depending on your operating system.
generated html file. Pass the ``-h`` flag for a complete list of
supported flags.
* Python documentation for writing extension modules should have some details for your system.
Compiling your ``.c`` files will vary depending on your operating
system. Python documentation for writing extension modules should
* Here we give an example on a Linux system::
have some details for your system. Here we give an example on a Linux
system::
$ gcc -shared -pthread -fPIC -fwrapv -O2 -Wall -fno-strict-aliasing -I/usr/include/python2.5 -o yourmod.so yourmod.c
$ gcc -shared -pthread -fPIC -fwrapv -O2 -Wall -fno-strict-aliasing -I/usr/include/python2.5 -o yourmod.so yourmod.c
* ``gcc`` will need to have paths to your included header files and paths to libraries you need to link with.
[``gcc`` will need to have paths to your included header files and
* A ``yourmod.so`` file is now in the same directory.
paths to libraries you need to link with]
* Your module, ``yourmod`` is available for you to import as you normally would.
A ``yourmod.so`` file is now in the same directory and your module,
``yourmod``, is available for you to import as you normally would.
=========
Compiling with ``distutils``
Distutils
============================
=========
* Ensure Distutils is installed in your system.
First, make sure that ``distutils`` package is installed in your
* The following assumes a Cython file to be compiled called *hello.pyx*.
system. The following assumes a Cython file to be compiled called
*
C
reate a ``setup.py`` script::
*
hello.pyx*. Now, c
reate a ``setup.py`` script::
from distutils.core import setup
from distutils.core import setup
from distutils.extension import Extension
from distutils.extension import Extension
from Cython.Distutils import build_ext
from Cython.Distutils import build_ext
ext_modules = [Extension("hello", ["hello.pyx"])]
ext_modules = [Extension("spam", ["spam.pyx"]),
Extension("ham", ["ham.pyx"])]
# You can add directives for each extension too
# by attaching the `pyrex_directives`
for e in ext modules:
e.pyrex_directives = {"boundscheck": False}
setup(
setup(
name =
’Hello world app’
,
name =
"My hello app"
,
cmdclass = {
’build_ext’
: build_ext},
cmdclass = {
"build_ext"
: build_ext},
ext_modules = ext_modules
ext_modules = ext_modules
)
)
* Run the command ``python setup.py build_ext --inplace`` in your system's command shell.
Run the command ``python setup.py build_ext --inplace`` in your
* Your done.. import your new extension module into your python shell or script as normal.
system's command shell and you are done. Import your new extension
module into your python shell or script as normal.
Cython provides utility code to automatically generate lists of
Extension objects from ```.pyx`` files, so one can write::
from distutils.core import setup
from Cython.Build import cythonize
=====
setup(
SCons
name = "My hello app",
=====
ext_modules = cythonize("*.pyx"),
)
to be completed...
to compile all ``.pyx`` files in a given directory.
The ``cythonize`` command also allows for multi-threaded compilation and
dependency resolution.
=========
Compiling with ``pyximport``
Pyximport
=============================
=========
* For generating Cython code right in your pure python modulc
e::
For generating Cython code right in your pure python module just typ
e::
>>> import pyximport; pyximport.install()
>>> import pyximport; pyximport.install()
>>> import helloworld
>>> import helloworld
Hello World
Hello World
* Use for simple Cython builds only.
This allows you to automatically run Cython on every ``.pyx`` that
Python is trying to import. You should use this for simple Cython
* No extra C libraries.
builds only where no extra C libraries and no special building setup
* No special build setup needed.
is needed.
* Also has experimental compilation support for normal Python modules.
* Allows you to automatically run Cython on every ``.pyx`` and ``.py`` module that Python imports.
* This includes the standard library and installed packages.
In the case that Cython fails to compile a Python module, *pyximport*
* In the case that Cython fails to compile a Python module, *pyximport*
will fall back to loading the source modules instead.
will fall back to loading the source modules instead.
* The ``.py`` import mechanism is installed like this::
It is also possible to compile new ``.py`` modules that are being
imported (including the standard library and installed packages). For
using this feature, just tell that to ``pyximport``::
>>> pyximport.install(pyimport = True)
>>> pyximport.install(pyimport = True)
Compiling with ``cython.inline``
.. note:: Authors
=============================
Paul Prescod, Stefan Behnal
One can also compile Cython in a fashion similar to SciPy's ``weave.inline``.
For example::
====
Sage
>>> import cython
====
>>> def f(a):
... ret = cython.inline("return a+b", b=3)
The Sage notebook allows transparently editing and
...
compiling Cython code simply by typing %cython at
the top of a cell and evaluate it. Variables and func-
Unbound variables are automatically pulled from the surrounding local
tions defined in a Cython cell imported into the run-
and global scopes, and the result of the compilation is cached for
ning session.
efficient re-use.
.. todo:: Provide a link to Sage docs
Compiling with Sage
===================
The Sage notebook allows transparently editing and compiling Cython
code simply by typing ``%cython`` at the top of a cell and evaluate
it. Variables and functions defined in a Cython cell are imported into the
running session. Please check `Sage documentation
<http://www.sagemath.org/doc/>`_ for details.
You can tailor the behavior of the Cython compiler by specifying the
directives below.
====================
Compiler directives
====================
Compiler directives are instructions which affect the behavior of
Cython code. Here is the list of currently supported directives:
``boundscheck`` (True / False)
If set to False, Cython is free to assume that indexing operations
([]-operator) in the code will not cause any IndexErrors to be
raised. Currently this is only made use of for buffers, lists and
tuples, but could be affected other types in the future. Conditions
which would normally trigger an IndexError may instead cause
segfaults or data corruption if this is set to False.
Default is True.
``wraparound`` (True / False)
In Python arrays can be indexed relative to the end. For example
A[-1] indexes the last value of a list. In C negative indexing is
not supported. If set to False, Cython will neither check for nor
correctly handle negative indices, possibly causing segfaults or
data corruption.
Default is True.
``nonecheck`` (True / False)
If set to False, Cython is free to assume that native field
accesses on variables typed as an extension type, or buffer
accesses on a buffer variable, never occurs when the variable is
set to ``None``. Otherwise a check is inserted and the
appropriate exception is raised. This is off by default for
performance reasons. Default is False.
``embedsignature`` (True / False)
If set to True, Cython will embed a textual copy of the call
signature in the docstring of all Python visible functions and
classes. Tools like IPython and epydoc can thus display the
signature, which cannot otherwise be retrieved after
compilation. Default is False.
``cdivision`` (True / False)
If set to False, Cython will adjust the remainder and quotient
operators C types to match those of Python ints (which differ when
the operands have opposite signs) and raise a
``ZeroDivisionError`` when the right operand is 0. This has up to
a 35% speed penalty. If set to True, no checks are performed. See
`CEP 516 <http://wiki.cython.org/enhancements/division>`_. Default
is False.
``cdivision_warnings`` (True / False)
If set to True, Cython will emit a runtime warning whenever
division is performed with negative operands. See `CEP 516
<http://wiki.cython.org/enhancements/division>`_. Default is
False.
``always_allow_keywords`` (True / False)
Avoid the ``METH_NOARGS`` and ``METH_O`` when constructing
functions/methods which take zero or one arguments. Has no effect
on special methods and functions with more than one argument. The
``METH_NOARGS`` and ``METH_O`` signatures provide faster
calling conventions but disallow the use of keywords.
``profile`` (True / False)
Add hooks for Python profilers into the compiled C code. Default
is False.
``infer_types`` (True / False)
Infer types of untyped variables in function bodies. Default is
None, indicating that on safe (semantically-unchanging) inferences
are allowed.
How to set directives
---------------------
Globally
:::::::::
One can set compiler directives through a special header comment at the top of the file, like this::
#!python
#cython: boundscheck=False
The comment must appear before any code (but can appear after other
comments or whitespace).
One can also pass a directive on the command line by using the -X switch::
$ cython -X boundscheck=True ...
Directives passed on the command line will override directives set in
header comments.
Locally
::::::::
For local blocks, you need to cimport the special builtin ``cython``
module::
#!python
cimport cython
Then you can use the directives either as decorators or in a with
statement, like this::
#!python
@cython.boundscheck(False) # turn off boundscheck for this function
def f():
...
with cython.boundscheck(True): # turn it temporarily on again for this block
...
.. Warning:: These two methods of setting directives are **not**
affected by overriding the directive on the command-line using the
-X option.
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