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
Gwenaël Samain
cython
Commits
4e306e24
Commit
4e306e24
authored
Jul 08, 2016
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of
git+ssh://github.com/cython/cython
parents
78129c5a
bfd2e433
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
127 additions
and
21 deletions
+127
-21
Cython/Compiler/ExprNodes.py
Cython/Compiler/ExprNodes.py
+1
-1
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+1
-0
Cython/Utility/CppConvert.pyx
Cython/Utility/CppConvert.pyx
+32
-0
docs/src/reference/compilation.rst
docs/src/reference/compilation.rst
+26
-0
docs/src/reference/special_methods_table.rst
docs/src/reference/special_methods_table.rst
+1
-1
docs/src/tutorial/strings.rst
docs/src/tutorial/strings.rst
+5
-8
docs/src/userguide/buffer.rst
docs/src/userguide/buffer.rst
+2
-3
docs/src/userguide/pyrex_differences.rst
docs/src/userguide/pyrex_differences.rst
+1
-3
docs/src/userguide/sharing_declarations.rst
docs/src/userguide/sharing_declarations.rst
+3
-0
docs/src/userguide/special_methods.rst
docs/src/userguide/special_methods.rst
+4
-5
tests/run/complex_numbers_cpp.pyx
tests/run/complex_numbers_cpp.pyx
+21
-0
tests/run/cpp_classes_def.pyx
tests/run/cpp_classes_def.pyx
+30
-0
No files found.
Cython/Compiler/ExprNodes.py
View file @
4e306e24
...
...
@@ -6302,7 +6302,7 @@ class AttributeNode(ExprNode):
# as an ordinary function.
if
entry
.
func_cname
and
not
hasattr
(
entry
.
type
,
'op_arg_struct'
):
cname
=
entry
.
func_cname
if
entry
.
type
.
is_static_method
:
if
entry
.
type
.
is_static_method
or
env
.
parent_scope
.
is_cpp_class_scope
:
ctype
=
entry
.
type
elif
type
.
is_cpp_class
:
error
(
self
.
pos
,
"%s not a static member of %s"
%
(
entry
.
name
,
type
))
...
...
Cython/Compiler/PyrexTypes.py
View file @
4e306e24
...
...
@@ -3231,6 +3231,7 @@ builtin_cpp_conversions = {
"std::unordered_set"
:
1
,
"std::map"
:
2
,
"std::unordered_map"
:
2
,
"std::complex"
:
1
,
}
class
CppClassType
(
CType
):
...
...
Cython/Utility/CppConvert.pyx
View file @
4e306e24
...
...
@@ -227,3 +227,35 @@ cdef object {{cname}}(const map[X,Y]& s):
o
[
X_to_py
(
key_value
.
first
)]
=
Y_to_py
(
key_value
.
second
)
cython
.
operator
.
preincrement
(
iter
)
return
o
#################### complex.from_py ####################
{{
template_type_declarations
}}
cdef
extern
from
*
:
cdef
cppclass
std_complex
"std::complex"
[
T
]:
std_complex
()
std_complex
(
T
,
T
)
except
+
@
cname
(
"{{cname}}"
)
cdef
std_complex
[
X
]
{{
cname
}}(
object
o
)
except
*
:
cdef
double
complex
z
=
o
return
std_complex
[
X
](
<
X
>
z
.
real
,
<
X
>
z
.
imag
)
#################### complex.to_py ####################
{{
template_type_declarations
}}
cdef
extern
from
*
:
cdef
cppclass
std_complex
"std::complex"
[
T
]:
X
real
()
X
imag
()
@
cname
(
"{{cname}}"
)
cdef
object
{{
cname
}}(
const
std_complex
[
X
]
&
z
):
cdef
double
complex
tmp
tmp
.
real
=
<
double
>
z
.
real
()
tmp
.
imag
=
<
double
>
z
.
imag
()
return
tmp
docs/src/reference/compilation.rst
View file @
4e306e24
...
...
@@ -222,6 +222,32 @@ list in the Extensions when not using Cython::
extension.sources[:] = sources
return extensions
Another option is to make Cython a setup dependency of your system and use
Cython's build_ext module which runs ``cythonize`` as part of the build process::
setup(
setup_requires=[
'cython>=0.x',
],
extensions = [Extension("*", ["*.pyx"])],
cmdclass={'build_ext': Cython.Build.build_ext},
...
)
If you want to expose the C-level interface of your library for other
libraries to cimport from, use package_data to install the ``.pxd`` files,
e.g.::
setup(
package_data = {
'my_package': ['*.pxd'],
'my_package/sub_package': ['*.pxd'],
},
...
)
These ``.pxd`` files need not correspond have corresponding ``.pyx``
modules if they contain purely declarations of external libraries.
Compiling with ``pyximport``
=============================
...
...
docs/src/reference/special_methods_table.rst
View file @
4e306e24
...
...
@@ -201,7 +201,7 @@ Descriptor objects
.. note::
Descriptor objects are part of the support mechanism for new-style
Python classes. See the discussion of descriptors in the Python documentation.
See also
PEP 252, "Making Types Look More Like Classes", and PEP 253
,
See also
:PEP:`252`, "Making Types Look More Like Classes", and :PEP:`253`
,
"Subtyping Built-In Types".
+-----------------------+---------------------------------------+-------------+-----------------------------------------------------+
...
...
docs/src/tutorial/strings.rst
View file @
4e306e24
...
...
@@ -67,7 +67,7 @@ Cython understands all Python string type prefixes:
* ``b'bytes'`` for byte strings
* ``u'text'`` for Unicode strings
* ``f'formatted {value}'`` for formatted Unicode string literals as defined by
`PEP 498 <https://www.python.org/dev/peps/pep-0498/>`_
(added in Cython 0.24)
:PEP:`498`
(added in Cython 0.24)
Unprefixed string literals become :obj:`str` objects when compiling
with language level 2 and :obj:`unicode` objects (i.e. Python 3
...
...
@@ -558,7 +558,7 @@ When string literals appear in the code, the source code encoding is
important. It determines the byte sequence that Cython will store in
the C code for bytes literals, and the Unicode code points that Cython
builds for unicode literals when parsing the byte encoded source file.
Following
`PEP 263`_
, Cython supports the explicit declaration of
Following
:PEP:`263`
, Cython supports the explicit declaration of
source file encodings. For example, putting the following comment at
the top of an ``ISO-8859-15`` (Latin-9) encoded source file (into the
first or second line) is required to enable ``ISO-8859-15`` decoding
...
...
@@ -567,14 +567,12 @@ in the parser::
# -*- coding: ISO-8859-15 -*-
When no explicit encoding declaration is provided, the source code is
parsed as UTF-8 encoded text, as specified by
`PEP 3120`_
. `UTF-8`_
parsed as UTF-8 encoded text, as specified by
:PEP:`3120`
. `UTF-8`_
is a very common encoding that can represent the entire Unicode set of
characters and is compatible with plain ASCII encoded text that it
encodes efficiently. This makes it a very good choice for source code
files which usually consist mostly of ASCII characters.
.. _`PEP 263`: http://www.python.org/dev/peps/pep-0263/
.. _`PEP 3120`: http://www.python.org/dev/peps/pep-3120/
.. _`UTF-8`: http://en.wikipedia.org/wiki/UTF-8
As an example, putting the following line into a UTF-8 encoded source
...
...
@@ -731,15 +729,14 @@ to the internal representation of the Unicode string. Instead, any
Unicode character can be represented on all platforms without
resorting to surrogate pairs. This implies that narrow builds no
longer exist from that version on, regardless of the size of
:c:type:`Py_UNICODE`. See
`PEP 393 <http://www.python.org/dev/peps/pep-0393/>`_ for details.
:c:type:`Py_UNICODE`. See :PEP:`393` for details.
Cython 0.16 and later handles this change internally and does the right
thing also for single character values as long as either type inference
is applied to untyped variables or the portable :c:type:`Py_UCS4` type
is explicitly used in the source code instead of the platform specific
:c:type:`Py_UNICODE` type. Optimisations that Cython applies to the
Python unicode type will automatically adapt to
PEP 393
at C compile
Python unicode type will automatically adapt to
:PEP:`393`
at C compile
time, as usual.
Iteration
...
...
docs/src/userguide/buffer.rst
View file @
4e306e24
...
...
@@ -176,8 +176,7 @@ References
----------
The buffer interface used here is set out in
`PEP 3118, Revising the buffer protocol
<http://legacy.python.org/dev/peps/pep-3118/>`_
:PEP:`3118`, Revising the buffer protocol.
A tutorial for using this API from C is on Jake Vanderplas's blog,
`An Introduction to the Python Buffer Protocol
...
...
@@ -188,5 +187,5 @@ Reference documentation is available for
and `Python 2 <https://docs.python.org/2.7/c-api/buffer.html>`_.
The Py2 documentation also describes an older buffer protocol
that is no longer in use;
since Python 2.6, the
PEP 3118
protocol has been implemented,
since Python 2.6, the
:PEP:`3118`
protocol has been implemented,
and the older protocol is only relevant for legacy code.
docs/src/userguide/pyrex_differences.rst
View file @
4e306e24
...
...
@@ -310,9 +310,7 @@ Synonyms
Source code encoding
======================
.. TODO: add the links to the relevant PEPs
Cython supports PEP 3120 and PEP 263, i.e. you can start your Cython source
Cython supports :PEP:`3120` and :PEP:`263`, i.e. you can start your Cython source
file with an encoding comment and generally write your source code in UTF-8.
This impacts the encoding of byte strings and the conversion of unicode string
literals like ``u'abcd'`` to unicode objects.
...
...
docs/src/userguide/sharing_declarations.rst
View file @
4e306e24
...
...
@@ -128,6 +128,9 @@ It searches for this file along the path for include files
(as specified by ``-I`` command line options or the ``include_path``
option to ``cythonize()``), as well as ``sys.path``.
Using ``package_data`` to install ``.pxd`` files in your ``setup.py`` script
allows other packages to cimport items from your module as a dependency.
Also, whenever you compile a file :file:`modulename.pyx`, the corresponding
definition file :file:`modulename.pxd` is first searched for along the
include path (but not ``sys.path``), and if found, it is processed before
...
...
docs/src/userguide/special_methods.rst
View file @
4e306e24
...
...
@@ -329,8 +329,8 @@ Iterators
| __next__ | self | object | Get next item (called next in Python) |
+-----------------------+---------------------------------------+-------------+-----------------------------------------------------+
Buffer interface [
PEP 3118
] (no Python equivalents - see note 1)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Buffer interface [
:PEP:`3118`
] (no Python equivalents - see note 1)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
^^^
+-----------------------+---------------------------------------+-------------+-----------------------------------------------------+
| Name | Parameters | Return type | Description |
...
...
@@ -371,11 +371,10 @@ Descriptor objects (see note 2)
.. note:: (1) The buffer interface was intended for use by C code and is not directly
accessible from Python. It is described in the Python/C API Reference Manual
of Python 2.x under sections 6.6 and 10.6. It was superseded by the new
PEP 3118
buffer protocol in Python 2.6 and is no longer available in Python 3.
:PEP:`3118`
buffer protocol in Python 2.6 and is no longer available in Python 3.
For a how-to guide to the new API, see :ref:`buffer`.
.. note:: (2) Descriptor objects are part of the support mechanism for new-style
Python classes. See the discussion of descriptors in the Python documentation.
See also
PEP 252, "Making Types Look More Like Classes", and PEP 253
,
See also
:PEP:`252`, "Making Types Look More Like Classes", and :PEP:`253`
,
"Subtyping Built-In Types".
tests/run/complex_numbers_cpp.pyx
0 → 100644
View file @
4e306e24
# tag: cpp
from
libcpp.complex
cimport
complex
as
complex_class
def
double_complex
(
complex_class
[
double
]
a
):
"""
>>> double_complex(1 + 2j)
(1+2j)
>>> double_complex(1.5 + 2.5j)
(1.5+2.5j)
"""
return
a
def
double_int
(
complex_class
[
int
]
a
):
"""
>>> double_int(1 + 2j)
(1+2j)
>>> double_int(1.5 + 2.5j)
(1+2j)
"""
return
a
tests/run/cpp_classes_def.pyx
View file @
4e306e24
...
...
@@ -5,6 +5,7 @@
cdef
double
pi
from
math
import
pi
from
libc.math
cimport
sin
,
cos
from
libcpp
cimport
bool
cdef
extern
from
"shapes.h"
namespace
"shapes"
:
cdef
cppclass
Shape
:
...
...
@@ -42,6 +43,35 @@ def test_Poly(int n, float radius=1):
finally
:
del
poly
cdef
cppclass
BaseClass
:
int
n
int
method
():
return
this
.
n
cdef
cppclass
SubClass
(
BaseClass
):
bool
override
__init__
(
bool
override
):
this
.
n
=
1
this
.
override
=
override
int
method
():
if
override
:
return
0
else
:
return
BaseClass
.
method
()
def
test_BaseMethods
(
x
):
"""
>>> test_BaseMethods(True)
0
>>> test_BaseMethods(False)
1
"""
cdef
SubClass
*
subClass
try
:
subClass
=
new
SubClass
(
x
)
return
subClass
.
method
()
finally
:
del
subClass
cdef
cppclass
WithStatic
:
@
staticmethod
...
...
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