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
e3402907
Commit
e3402907
authored
May 30, 2014
by
Julien Delafontaine
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Rewrote the 'Pure Python mode' tutorial and moved the 'Types' chapter to 'Language basics'.
parent
913d9a19
Changes
2
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
180 additions
and
105 deletions
+180
-105
docs/src/tutorial/pure.rst
docs/src/tutorial/pure.rst
+139
-88
docs/src/userguide/language_basics.rst
docs/src/userguide/language_basics.rst
+41
-17
No files found.
docs/src/tutorial/pure.rst
View file @
e3402907
This diff is collapsed.
Click to expand it.
docs/src/userguide/language_basics.rst
View file @
e3402907
...
@@ -31,7 +31,7 @@ and C :keyword:`struct`, :keyword:`union` or :keyword:`enum` types::
...
@@ -31,7 +31,7 @@ and C :keyword:`struct`, :keyword:`union` or :keyword:`enum` types::
float *eggs
float *eggs
cdef enum CheeseType:
cdef enum CheeseType:
cheddar, edam,
cheddar, edam,
camembert
camembert
cdef enum CheeseState:
cdef enum CheeseState:
...
@@ -64,6 +64,30 @@ an anonymous :keyword:`enum` declaration for this purpose, for example,::
...
@@ -64,6 +64,30 @@ an anonymous :keyword:`enum` declaration for this purpose, for example,::
ctypedef int* IntPtr
ctypedef int* IntPtr
Types
-----
There are numerous types built in to the Cython module. One has all the
standard C types, namely ``char``, ``short``, ``int``, ``long``, ``longlong``
as well as their unsigned versions ``uchar``, ``ushort``, ``uint``, ``ulong``,
``ulonglong``. One also has ``bint`` and ``Py_ssize_t``.
For each type, there are pointer types ``p_int``, ``pp_int``, . . ., up to
three levels deep in interpreted mode, and infinitely deep in compiled mode.
The Python types int, long and bool are interpreted as C ``int``, ``long``
and ``bint`` respectively.
Also, the Python types ``list``, ``dict``, ``tuple``, . . . may
be used, as well as any user defined types. However at the moment they add very
few in terms of optimization to a simple ``object`` typing.
Pointer types may be constructed with ``cython.pointer(cython.int)``, and
arrays as ``cython.int[10]``. A limited attempt is made to emulate these more
complex types, but only so much can be done from the Python language.
Grouping multiple C declarations
Grouping multiple C declarations
--------------------------------
--------------------------------
...
@@ -92,14 +116,14 @@ Python objects as parameters and return Python objects.
...
@@ -92,14 +116,14 @@ Python objects as parameters and return Python objects.
C functions are defined using the new :keyword:`cdef` statement. They take
C functions are defined using the new :keyword:`cdef` statement. They take
either Python objects or C values as parameters, and can return either Python
either Python objects or C values as parameters, and can return either Python
objects or C values.
objects or C values.
Within a Cython module, Python functions and C functions can call each other
Within a Cython module, Python functions and C functions can call each other
freely, but only Python functions can be called from outside the module by
freely, but only Python functions can be called from outside the module by
interpreted Python code. So, any functions that you want to "export" from your
interpreted Python code. So, any functions that you want to "export" from your
Cython module must be declared as Python functions using def.
Cython module must be declared as Python functions using def.
There is also a hybrid function, called :keyword:`cpdef`. A :keyword:`cpdef`
There is also a hybrid function, called :keyword:`cpdef`. A :keyword:`cpdef`
can be called from anywhere, but uses the faster C calling conventions
can be called from anywhere, but uses the faster C calling conventions
when being called from other Cython code. A :keyword:`cpdef` can also be overridden
when being called from other Cython code. A :keyword:`cpdef` can also be overridden
by a Python method on a subclass or an instance attribute, even when called from Cython.
by a Python method on a subclass or an instance attribute, even when called from Cython.
If this happens, most performance gains are of course lost and even if it does not,
If this happens, most performance gains are of course lost and even if it does not,
...
@@ -212,18 +236,18 @@ This form causes Cython to generate a call to :c:func:`PyErr_Occurred` after
...
@@ -212,18 +236,18 @@ This form causes Cython to generate a call to :c:func:`PyErr_Occurred` after
every call to spam, regardless of what value it returns. If you have a
every call to spam, regardless of what value it returns. If you have a
function returning void that needs to propagate errors, you will have to use
function returning void that needs to propagate errors, you will have to use
this form, since there isn't any return value to test.
this form, since there isn't any return value to test.
Otherwise there is little use for this form.
Otherwise there is little use for this form.
An external C++ function that may raise an exception can be declared with::
An external C++ function that may raise an exception can be declared with::
cdef int spam() except +
cdef int spam() except +
See :ref:`wrapping-cplusplus` for more details.
See :ref:`wrapping-cplusplus` for more details.
Some things to note:
Some things to note:
* Exception values can only declared for functions returning an integer, enum,
* Exception values can only declared for functions returning an integer, enum,
float or pointer type, and the value must be a constant expression.
float or pointer type, and the value must be a constant expression.
Void functions can only use the ``except *`` form.
Void functions can only use the ``except *`` form.
* The exception value specification is part of the signature of the function.
* The exception value specification is part of the signature of the function.
If you're passing a pointer to a function as a parameter or assigning it
If you're passing a pointer to a function as a parameter or assigning it
...
@@ -236,7 +260,7 @@ Some things to note:
...
@@ -236,7 +260,7 @@ Some things to note:
* You don't need to (and shouldn't) declare exception values for functions
* You don't need to (and shouldn't) declare exception values for functions
which return Python objects. Remember that a function with no declared
which return Python objects. Remember that a function with no declared
return type implicitly returns a Python object. (Exceptions on such functions
return type implicitly returns a Python object. (Exceptions on such functions
are implicitly propagated by returning NULL.)
are implicitly propagated by returning NULL.)
Checking return values of non-Cython functions
Checking return values of non-Cython functions
...
@@ -260,7 +284,7 @@ return value and raise it yourself, for example,::
...
@@ -260,7 +284,7 @@ return value and raise it yourself, for example,::
if p == NULL:
if p == NULL:
raise SpamError("Couldn't open the spam file")
raise SpamError("Couldn't open the spam file")
Automatic type conversions
Automatic type conversions
==========================
==========================
...
@@ -287,7 +311,7 @@ possibilities.
...
@@ -287,7 +311,7 @@ possibilities.
| struct | | dict |
| struct | | dict |
+----------------------------+--------------------+------------------+
+----------------------------+--------------------+------------------+
.. [#] The conversion is to/from str for Python 2.x, and bytes for Python 3.x.
.. [#] The conversion is to/from str for Python 2.x, and bytes for Python 3.x.
Caveats when using a Python string in a C context
Caveats when using a Python string in a C context
-------------------------------------------------
-------------------------------------------------
...
@@ -352,9 +376,9 @@ direct equivalent in Python.
...
@@ -352,9 +376,9 @@ direct equivalent in Python.
* An integer literal is treated as a C constant, and will
* An integer literal is treated as a C constant, and will
be truncated to whatever size your C compiler thinks appropriate.
be truncated to whatever size your C compiler thinks appropriate.
To get a Python integer (of arbitrary precision) cast immediately to
To get a Python integer (of arbitrary precision) cast immediately to
an object (e.g. ``<object>100000000000000000000``). The ``L``, ``LL``,
an object (e.g. ``<object>100000000000000000000``). The ``L``, ``LL``,
and ``U`` suffixes have the same meaning as in C.
and ``U`` suffixes have the same meaning as in C.
* There is no ``->`` operator in Cython. Instead of ``p->x``, use ``p.x``
* There is no ``->`` operator in Cython. Instead of ``p->x``, use ``p.x``
* There is no unary ``*`` operator in Cython. Instead of ``*p``, use ``p[0]``
* There is no unary ``*`` operator in Cython. Instead of ``*p``, use ``p[0]``
* There is an ``&`` operator, with the same semantics as in C.
* There is an ``&`` operator, with the same semantics as in C.
...
@@ -495,7 +519,7 @@ Some things to note about the for-from loop:
...
@@ -495,7 +519,7 @@ Some things to note about the for-from loop:
* The name between the lower and upper bounds must be the same as the target
* The name between the lower and upper bounds must be the same as the target
name.
name.
* The direction of iteration is determined by the relations. If they are both
* The direction of iteration is determined by the relations. If they are both
from the set {``<``, ``<=``} then it is upwards; if they are both from the set
from the set {``<``, ``<=``} then it is upwards; if they are both from the set
{``>``, ``>=``} then it is downwards. (Any other combination is disallowed.)
{``>``, ``>=``} then it is downwards. (Any other combination is disallowed.)
Like other Python looping statements, break and continue may be used in the
Like other Python looping statements, break and continue may be used in the
...
@@ -505,8 +529,8 @@ body, and the loop may have an else clause.
...
@@ -505,8 +529,8 @@ body, and the loop may have an else clause.
The include statement
The include statement
=====================
=====================
.. warning::
.. warning::
Historically the ``include`` statement was used for sharing declarations.
Historically the ``include`` statement was used for sharing declarations.
Use :ref:`sharing-declarations` instead.
Use :ref:`sharing-declarations` instead.
A Cython source file can include material from other files using the include
A Cython source file can include material from other files using the include
...
...
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