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
afb995d7
Commit
afb995d7
authored
Oct 21, 2015
by
Kevin R. Thornton
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1 from cython/master
Merge upstream
parents
e414aa44
01b47caa
Changes
48
Show whitespace changes
Inline
Side-by-side
Showing
48 changed files
with
147 additions
and
70 deletions
+147
-70
Cython/Compiler/Code.py
Cython/Compiler/Code.py
+1
-1
Cython/Compiler/ExprNodes.py
Cython/Compiler/ExprNodes.py
+2
-5
Cython/Compiler/Main.py
Cython/Compiler/Main.py
+11
-6
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+3
-3
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+9
-9
Cython/Compiler/ParseTreeTransforms.py
Cython/Compiler/ParseTreeTransforms.py
+1
-1
Cython/Compiler/Symtab.py
Cython/Compiler/Symtab.py
+6
-0
Cython/Includes/Deprecated/python.pxd
Cython/Includes/Deprecated/python.pxd
+1
-1
Cython/Includes/Deprecated/python_bool.pxd
Cython/Includes/Deprecated/python_bool.pxd
+1
-1
Cython/Includes/Deprecated/python_buffer.pxd
Cython/Includes/Deprecated/python_buffer.pxd
+1
-1
Cython/Includes/Deprecated/python_bytes.pxd
Cython/Includes/Deprecated/python_bytes.pxd
+1
-1
Cython/Includes/Deprecated/python_cobject.pxd
Cython/Includes/Deprecated/python_cobject.pxd
+1
-1
Cython/Includes/Deprecated/python_complex.pxd
Cython/Includes/Deprecated/python_complex.pxd
+1
-1
Cython/Includes/Deprecated/python_dict.pxd
Cython/Includes/Deprecated/python_dict.pxd
+1
-1
Cython/Includes/Deprecated/python_exc.pxd
Cython/Includes/Deprecated/python_exc.pxd
+1
-1
Cython/Includes/Deprecated/python_float.pxd
Cython/Includes/Deprecated/python_float.pxd
+1
-1
Cython/Includes/Deprecated/python_function.pxd
Cython/Includes/Deprecated/python_function.pxd
+1
-1
Cython/Includes/Deprecated/python_getargs.pxd
Cython/Includes/Deprecated/python_getargs.pxd
+1
-1
Cython/Includes/Deprecated/python_instance.pxd
Cython/Includes/Deprecated/python_instance.pxd
+1
-1
Cython/Includes/Deprecated/python_int.pxd
Cython/Includes/Deprecated/python_int.pxd
+1
-1
Cython/Includes/Deprecated/python_iterator.pxd
Cython/Includes/Deprecated/python_iterator.pxd
+1
-1
Cython/Includes/Deprecated/python_list.pxd
Cython/Includes/Deprecated/python_list.pxd
+1
-1
Cython/Includes/Deprecated/python_long.pxd
Cython/Includes/Deprecated/python_long.pxd
+1
-1
Cython/Includes/Deprecated/python_mapping.pxd
Cython/Includes/Deprecated/python_mapping.pxd
+1
-1
Cython/Includes/Deprecated/python_mem.pxd
Cython/Includes/Deprecated/python_mem.pxd
+1
-1
Cython/Includes/Deprecated/python_method.pxd
Cython/Includes/Deprecated/python_method.pxd
+1
-1
Cython/Includes/Deprecated/python_module.pxd
Cython/Includes/Deprecated/python_module.pxd
+1
-1
Cython/Includes/Deprecated/python_number.pxd
Cython/Includes/Deprecated/python_number.pxd
+1
-1
Cython/Includes/Deprecated/python_object.pxd
Cython/Includes/Deprecated/python_object.pxd
+1
-1
Cython/Includes/Deprecated/python_oldbuffer.pxd
Cython/Includes/Deprecated/python_oldbuffer.pxd
+1
-1
Cython/Includes/Deprecated/python_pycapsule.pxd
Cython/Includes/Deprecated/python_pycapsule.pxd
+1
-1
Cython/Includes/Deprecated/python_ref.pxd
Cython/Includes/Deprecated/python_ref.pxd
+1
-1
Cython/Includes/Deprecated/python_sequence.pxd
Cython/Includes/Deprecated/python_sequence.pxd
+1
-1
Cython/Includes/Deprecated/python_set.pxd
Cython/Includes/Deprecated/python_set.pxd
+1
-1
Cython/Includes/Deprecated/python_string.pxd
Cython/Includes/Deprecated/python_string.pxd
+1
-1
Cython/Includes/Deprecated/python_tuple.pxd
Cython/Includes/Deprecated/python_tuple.pxd
+1
-1
Cython/Includes/Deprecated/python_type.pxd
Cython/Includes/Deprecated/python_type.pxd
+1
-1
Cython/Includes/Deprecated/python_unicode.pxd
Cython/Includes/Deprecated/python_unicode.pxd
+1
-1
Cython/Includes/Deprecated/python_version.pxd
Cython/Includes/Deprecated/python_version.pxd
+1
-1
Cython/Includes/Deprecated/python_weakref.pxd
Cython/Includes/Deprecated/python_weakref.pxd
+1
-1
Cython/Includes/Deprecated/stdio.pxd
Cython/Includes/Deprecated/stdio.pxd
+1
-1
Cython/Includes/Deprecated/stdlib.pxd
Cython/Includes/Deprecated/stdlib.pxd
+1
-1
Cython/Includes/cpython/buffer.pxd
Cython/Includes/cpython/buffer.pxd
+1
-1
Cython/Includes/numpy/__init__.pxd
Cython/Includes/numpy/__init__.pxd
+1
-1
Cython/Includes/posix/types.pxd
Cython/Includes/posix/types.pxd
+1
-1
Cython/Utility/MemoryView_C.c
Cython/Utility/MemoryView_C.c
+4
-4
tests/buffers/bufaccess.pyx
tests/buffers/bufaccess.pyx
+68
-0
tests/buffers/mockbuffers.pxi
tests/buffers/mockbuffers.pxi
+4
-3
No files found.
Cython/Compiler/Code.py
View file @
afb995d7
...
...
@@ -1324,7 +1324,7 @@ class GlobalState(object):
for
py_string
in
c
.
py_strings
.
values
():
py_strings
.
append
((
c
.
cname
,
len
(
py_string
.
cname
),
py_string
))
for
c
,
cname
in
s
elf
.
pyunicode_ptr_const_index
.
items
(
):
for
c
,
cname
in
s
orted
(
self
.
pyunicode_ptr_const_index
.
items
()
):
utf16_array
,
utf32_array
=
StringEncoding
.
encode_pyunicode_string
(
c
)
if
utf16_array
:
# Narrow and wide representations differ
...
...
Cython/Compiler/ExprNodes.py
View file @
afb995d7
...
...
@@ -3421,11 +3421,8 @@ class IndexNode(_IndexingBaseNode):
elif
base_type
.
is_buffer
and
len
(
indices
)
==
base_type
.
ndim
:
# Buffer indexing
is_buffer_access
=
True
for
index
in
indices
:
index
=
index
.
analyse_types
(
env
)
if
not
index
.
type
.
is_int
:
is_buffer_access
=
False
if
is_buffer_access
:
indices
=
[
index
.
analyse_types
(
env
)
for
index
in
indices
]
if
all
(
index
.
type
.
is_int
for
index
in
indices
):
replacement_node
=
BufferIndexNode
(
self
.
pos
,
indices
=
indices
,
base
=
self
.
base
)
# On cloning, indices is cloned. Otherwise, unpack index into indices.
assert
not
isinstance
(
self
.
index
,
CloneNode
)
...
...
Cython/Compiler/Main.py
View file @
afb995d7
...
...
@@ -432,14 +432,19 @@ def create_default_resultobj(compilation_source, options):
result
.
main_source_file
=
compilation_source
.
source_desc
.
filename
result
.
compilation_source
=
compilation_source
source_desc
=
compilation_source
.
source_desc
if
options
.
output_file
:
result
.
c_file
=
os
.
path
.
join
(
compilation_source
.
cwd
,
options
.
output_file
)
else
:
if
options
.
cplus
:
c_suffix
=
".cpp"
else
:
c_suffix
=
".c"
result
.
c_file
=
Utils
.
replace_suffix
(
source_desc
.
filename
,
c_suffix
)
suggested_file_name
=
Utils
.
replace_suffix
(
source_desc
.
filename
,
c_suffix
)
if
options
.
output_file
:
out_path
=
os
.
path
.
join
(
compilation_source
.
cwd
,
options
.
output_file
)
if
os
.
path
.
isdir
(
out_path
):
result
.
c_file
=
os
.
path
.
join
(
out_path
,
os
.
path
.
basename
(
suggested_file_name
))
else
:
result
.
c_file
=
out_path
else
:
result
.
c_file
=
suggested_file_name
result
.
embedded_metadata
=
options
.
embedded_metadata
return
result
...
...
Cython/Compiler/ModuleNode.py
View file @
afb995d7
...
...
@@ -1987,7 +1987,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
def
create_import_star_conversion_utility_code
(
self
,
env
):
# Create all conversion helpers that are needed for "import *" assignments.
# Must be done before code generation to support CythonUtilityCode.
for
name
,
entry
in
env
.
entries
.
items
(
):
for
name
,
entry
in
sorted
(
env
.
entries
.
items
()
):
if
entry
.
is_cglobal
and
entry
.
used
:
if
not
entry
.
type
.
is_pyobject
:
entry
.
type
.
create_from_py_utility_code
(
env
)
...
...
@@ -2016,7 +2016,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
old_error_label
=
code
.
new_error_label
()
code
.
putln
(
"if (0);"
)
# so the first one can be "else if"
for
name
,
entry
in
env
.
entries
.
items
(
):
for
name
,
entry
in
sorted
(
env
.
entries
.
items
()
):
if
entry
.
is_cglobal
and
entry
.
used
:
code
.
putln
(
'else if (__Pyx_StrEq(name, "%s")) {'
%
name
)
if
entry
.
type
.
is_pyobject
:
...
...
@@ -2461,7 +2461,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
entry
.
type
.
global_init_code
(
entry
,
code
)
def
generate_wrapped_entries_code
(
self
,
env
,
code
):
for
name
,
entry
in
env
.
entries
.
items
(
):
for
name
,
entry
in
sorted
(
env
.
entries
.
items
()
):
if
(
entry
.
create_wrapper
and
not
entry
.
is_type
and
entry
.
scope
is
env
):
...
...
Cython/Compiler/Nodes.py
View file @
afb995d7
...
...
@@ -5126,8 +5126,8 @@ class CascadedAssignmentNode(AssignmentNode):
# collect distinct types used on the LHS
lhs_types
=
set
()
for
lhs
in
self
.
lhs_list
:
lhs
.
analyse_target_types
(
env
)
for
i
,
lhs
in
enumerate
(
self
.
lhs_list
)
:
lhs
=
self
.
lhs_list
[
i
]
=
lhs
.
analyse_target_types
(
env
)
lhs
.
gil_assignment_check
(
env
)
lhs_types
.
add
(
lhs
.
type
)
...
...
@@ -7832,7 +7832,7 @@ class ParallelStatNode(StatNode, ParallelNode):
def
initialize_privates_to_nan
(
self
,
code
,
exclude
=
None
):
first
=
True
for
entry
,
(
op
,
lastprivate
)
in
s
elf
.
privates
.
items
(
):
for
entry
,
(
op
,
lastprivate
)
in
s
orted
(
self
.
privates
.
items
()
):
if
not
op
and
(
not
exclude
or
entry
!=
exclude
):
invalid_value
=
entry
.
type
.
invalid_value
()
...
...
@@ -7874,7 +7874,7 @@ class ParallelStatNode(StatNode, ParallelNode):
"""
self
.
modified_entries
=
[]
for
entry
in
s
elf
.
assignments
:
for
entry
in
s
orted
(
self
.
assignments
)
:
if
entry
.
from_closure
or
entry
.
in_closure
:
self
.
_allocate_closure_temp
(
code
,
entry
)
...
...
@@ -7899,7 +7899,7 @@ class ParallelStatNode(StatNode, ParallelNode):
self
.
temps
=
temps
=
code
.
funcstate
.
stop_collecting_temps
()
privates
,
firstprivates
=
[],
[]
for
temp
,
type
in
temps
:
for
temp
,
type
in
sorted
(
temps
)
:
if
type
.
is_pyobject
or
type
.
is_memoryviewslice
:
firstprivates
.
append
(
temp
)
else
:
...
...
@@ -7922,7 +7922,7 @@ class ParallelStatNode(StatNode, ParallelNode):
# Now clean up any memoryview slice and object temporaries
if
self
.
is_parallel
and
not
self
.
is_nested_prange
:
code
.
putln
(
"/* Clean up any temporaries */"
)
for
temp
,
type
in
s
elf
.
temps
:
for
temp
,
type
in
s
orted
(
self
.
temps
)
:
if
type
.
is_memoryviewslice
:
code
.
put_xdecref_memoryviewslice
(
temp
,
have_gil
=
False
)
elif
type
.
is_pyobject
:
...
...
@@ -8094,7 +8094,7 @@ class ParallelStatNode(StatNode, ParallelNode):
c
=
self
.
begin_of_parallel_control_block_point
temp_count
=
0
for
entry
,
(
op
,
lastprivate
)
in
s
elf
.
privates
.
items
(
):
for
entry
,
(
op
,
lastprivate
)
in
s
orted
(
self
.
privates
.
items
()
):
if
not
lastprivate
or
entry
.
type
.
is_pyobject
:
continue
...
...
@@ -8303,7 +8303,7 @@ class ParallelWithBlockNode(ParallelStatNode):
if
self
.
privates
:
privates
=
[
e
.
cname
for
e
in
self
.
privates
if
not
e
.
type
.
is_pyobject
]
code
.
put
(
'private(%s)'
%
', '
.
join
(
privates
))
code
.
put
(
'private(%s)'
%
', '
.
join
(
sorted
(
privates
)
))
self
.
privatization_insertion_point
=
code
.
insertion_point
()
self
.
put_num_threads
(
code
)
...
...
@@ -8623,7 +8623,7 @@ class ParallelRangeNode(ParallelStatNode):
code
.
putln
(
"#ifdef _OPENMP"
)
code
.
put
(
"#pragma omp for"
)
for
entry
,
(
op
,
lastprivate
)
in
s
elf
.
privates
.
items
(
):
for
entry
,
(
op
,
lastprivate
)
in
s
orted
(
self
.
privates
.
items
()
):
# Don't declare the index variable as a reduction
if
op
and
op
in
"+*-&^|"
and
entry
!=
self
.
target
.
entry
:
if
entry
.
type
.
is_pyobject
:
...
...
Cython/Compiler/ParseTreeTransforms.py
View file @
afb995d7
...
...
@@ -636,7 +636,7 @@ class InterpretCompilerDirectives(CythonTransform, SkipDeclarations):
'operator.postincrement'
:
ExprNodes
.
inc_dec_constructor
(
False
,
'++'
),
'operator.postdecrement'
:
ExprNodes
.
inc_dec_constructor
(
False
,
'--'
),
# For backwards compat
a
bility.
# For backwards compat
i
bility.
'address'
:
ExprNodes
.
AmpersandNode
,
}
...
...
Cython/Compiler/Symtab.py
View file @
afb995d7
...
...
@@ -223,6 +223,12 @@ class Entry(object):
def
all_entries
(
self
):
return
[
self
]
+
self
.
inner_entries
def
__lt__
(
left
,
right
):
if
isinstance
(
left
,
Entry
)
and
isinstance
(
right
,
Entry
):
return
(
left
.
name
,
left
.
cname
)
<
(
right
.
name
,
right
.
cname
)
else
:
return
NotImplemented
class
InnerEntry
(
Entry
):
"""
...
...
Cython/Includes/Deprecated/python.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython
cimport
*
Cython/Includes/Deprecated/python_bool.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.bool
cimport
*
Cython/Includes/Deprecated/python_buffer.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.buffer
cimport
*
Cython/Includes/Deprecated/python_bytes.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.bytes
cimport
*
Cython/Includes/Deprecated/python_cobject.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.cobject
cimport
*
Cython/Includes/Deprecated/python_complex.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.complex
cimport
*
Cython/Includes/Deprecated/python_dict.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.dict
cimport
*
Cython/Includes/Deprecated/python_exc.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.exc
cimport
*
Cython/Includes/Deprecated/python_float.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.float
cimport
*
Cython/Includes/Deprecated/python_function.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.function
cimport
*
Cython/Includes/Deprecated/python_getargs.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.getargs
cimport
*
Cython/Includes/Deprecated/python_instance.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.instance
cimport
*
Cython/Includes/Deprecated/python_int.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.int
cimport
*
Cython/Includes/Deprecated/python_iterator.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.iterator
cimport
*
Cython/Includes/Deprecated/python_list.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.list
cimport
*
Cython/Includes/Deprecated/python_long.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.long
cimport
*
Cython/Includes/Deprecated/python_mapping.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.mapping
cimport
*
Cython/Includes/Deprecated/python_mem.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.mem
cimport
*
Cython/Includes/Deprecated/python_method.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.method
cimport
*
Cython/Includes/Deprecated/python_module.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.module
cimport
*
Cython/Includes/Deprecated/python_number.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.number
cimport
*
Cython/Includes/Deprecated/python_object.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.object
cimport
*
Cython/Includes/Deprecated/python_oldbuffer.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.oldbuffer
cimport
*
Cython/Includes/Deprecated/python_pycapsule.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.pycapsule
cimport
*
Cython/Includes/Deprecated/python_ref.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.ref
cimport
*
Cython/Includes/Deprecated/python_sequence.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.sequence
cimport
*
Cython/Includes/Deprecated/python_set.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.set
cimport
*
Cython/Includes/Deprecated/python_string.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.string
cimport
*
Cython/Includes/Deprecated/python_tuple.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.tuple
cimport
*
Cython/Includes/Deprecated/python_type.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.type
cimport
*
Cython/Includes/Deprecated/python_unicode.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.unicode
cimport
*
Cython/Includes/Deprecated/python_version.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.version
cimport
*
Cython/Includes/Deprecated/python_weakref.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
cpython.weakref
cimport
*
Cython/Includes/Deprecated/stdio.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
libc.stdio
cimport
*
Cython/Includes/Deprecated/stdlib.pxd
View file @
afb995d7
# Present for backwards compat
a
bility
# Present for backwards compat
i
bility
from
libc.stdlib
cimport
*
Cython/Includes/cpython/buffer.pxd
View file @
afb995d7
...
...
@@ -5,7 +5,7 @@ cdef extern from "Python.h":
cdef
enum
:
PyBUF_SIMPLE
,
PyBUF_WRITABLE
,
PyBUF_WRITEABLE
,
# backwards compat
a
bility
PyBUF_WRITEABLE
,
# backwards compat
i
bility
PyBUF_FORMAT
,
PyBUF_ND
,
PyBUF_STRIDES
,
...
...
Cython/Includes/numpy/__init__.pxd
View file @
afb995d7
...
...
@@ -3,7 +3,7 @@
# If any of the PyArray_* functions are called, import_array must be
# called first.
#
# This also defines backwards-compat
a
bility buffer acquisition
# This also defines backwards-compat
i
bility buffer acquisition
# code for use in Python 2.x (or Python <= 2.5 when NumPy starts
# implementing PEP-3118 directly).
#
...
...
Cython/Includes/posix/types.pxd
View file @
afb995d7
# Note that the actual size of these types is system-depend
a
nt, and
# Note that the actual size of these types is system-depend
e
nt, and
# can't be detected at C compile time. However, the generated C code
# will correctly use the actual size of these types *except* for
# determining promotion in binary arithmetic expressions involving
...
...
Cython/Utility/MemoryView_C.c
View file @
afb995d7
...
...
@@ -753,11 +753,11 @@ __pyx_memviewslice_index_full(const char *bufp, Py_ssize_t idx,
/////////////// MemviewDtypeToObject.proto ///////////////
{{
if
to_py_function
}}
static
PyObject
*
{{
get_function
}}(
const
char
*
itemp
);
/* proto */
static
CYTHON_INLINE
PyObject
*
{{
get_function
}}(
const
char
*
itemp
);
/* proto */
{{
endif
}}
{{
if
from_py_function
}}
static
int
{{
set_function
}}(
const
char
*
itemp
,
PyObject
*
obj
);
/* proto */
static
CYTHON_INLINE
int
{{
set_function
}}(
const
char
*
itemp
,
PyObject
*
obj
);
/* proto */
{{
endif
}}
/////////////// MemviewDtypeToObject ///////////////
...
...
@@ -767,13 +767,13 @@ static int {{set_function}}(const char *itemp, PyObject *obj); /* proto */
/* Convert a dtype to or from a Python object */
{{
if
to_py_function
}}
static
PyObject
*
{{
get_function
}}(
const
char
*
itemp
)
{
static
CYTHON_INLINE
PyObject
*
{{
get_function
}}(
const
char
*
itemp
)
{
return
(
PyObject
*
)
{{
to_py_function
}}(
*
({{
dtype
}}
*
)
itemp
);
}
{{
endif
}}
{{
if
from_py_function
}}
static
int
{{
set_function
}}(
const
char
*
itemp
,
PyObject
*
obj
)
{
static
CYTHON_INLINE
int
{{
set_function
}}(
const
char
*
itemp
,
PyObject
*
obj
)
{
{{
dtype
}}
value
=
{{
from_py_function
}}(
obj
);
if
({{
error_condition
}})
return
0
;
...
...
tests/buffers/bufaccess.pyx
View file @
afb995d7
...
...
@@ -483,6 +483,63 @@ def set_int_2d(object[int, ndim=2] buf, int i, int j, int value):
"""
buf
[
i
,
j
]
=
value
@
testcase
def
set_int_2d_cascaded
(
object
[
int
,
ndim
=
2
]
buf
,
int
i
,
int
j
,
int
value
):
"""
Uses get_int_2d to read back the value afterwards. For pure
unit test, one should support reading in MockBuffer instead.
>>> C = IntMockBuffer("C", range(6), (2,3))
>>> set_int_2d_cascaded(C, 1, 1, 10)
acquired C
released C
10
>>> get_int_2d(C, 1, 1)
acquired C
released C
10
Check negative indexing:
>>> set_int_2d_cascaded(C, -1, 0, 3)
acquired C
released C
3
>>> get_int_2d(C, -1, 0)
acquired C
released C
3
>>> set_int_2d_cascaded(C, -1, -2, 8)
acquired C
released C
8
>>> get_int_2d(C, -1, -2)
acquired C
released C
8
>>> set_int_2d_cascaded(C, -2, -3, 9)
acquired C
released C
9
>>> get_int_2d(C, -2, -3)
acquired C
released C
9
Out-of-bounds errors:
>>> set_int_2d_cascaded(C, 2, 0, 19)
Traceback (most recent call last):
IndexError: Out of bounds on buffer access (axis 0)
>>> set_int_2d_cascaded(C, 0, -4, 19)
Traceback (most recent call last):
IndexError: Out of bounds on buffer access (axis 1)
"""
cdef
int
casc_value
buf
[
i
,
j
]
=
casc_value
=
value
return
casc_value
@
testcase
def
list_comprehension
(
object
[
int
]
buf
,
len
):
"""
...
...
@@ -1184,3 +1241,14 @@ def test_inplace_assignment():
buf
[
0
]
=
get_int
()
print
buf
[
0
]
@
testcase
def
test_nested_assignment
():
"""
>>> test_nested_assignment()
100
"""
cdef
object
[
int
]
inner
=
IntMockBuffer
(
None
,
[
1
,
2
,
3
])
cdef
object
[
int
]
outer
=
IntMockBuffer
(
None
,
[
1
,
2
,
3
])
outer
[
inner
[
0
]]
=
100
return
outer
[
inner
[
0
]]
tests/buffers/mockbuffers.pxi
View file @
afb995d7
...
...
@@ -17,7 +17,8 @@ available_flags = (
cdef
class
MockBuffer
:
cdef
object
format
,
offset
cdef
void
*
buffer
cdef
int
len
,
itemsize
,
ndim
cdef
Py_ssize_t
len
,
itemsize
cdef
int
ndim
cdef
Py_ssize_t
*
strides
cdef
Py_ssize_t
*
shape
cdef
Py_ssize_t
*
suboffsets
...
...
@@ -55,7 +56,7 @@ cdef class MockBuffer:
else
:
break
if
len
(
datashape
)
>
1
:
# indirect access
self
.
ndim
=
len
(
datashape
)
self
.
ndim
=
<
int
>
len
(
datashape
)
shape
=
datashape
self
.
buffer
=
self
.
create_indirect_buffer
(
data
,
shape
)
suboffsets
=
[
0
]
*
(
self
.
ndim
-
1
)
+
[
-
1
]
...
...
@@ -64,7 +65,7 @@ cdef class MockBuffer:
else
:
# strided and/or simple access
self
.
buffer
=
self
.
create_buffer
(
data
)
self
.
ndim
=
len
(
shape
)
self
.
ndim
=
<
int
>
len
(
shape
)
self
.
suboffsets
=
NULL
try
:
...
...
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