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
Xavier Thompson
cython
Commits
edffe666
Commit
edffe666
authored
Aug 15, 2008
by
Dag Sverre Seljebotn
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Buffers: Support for typedefs floats.
parent
055de7b8
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
84 additions
and
40 deletions
+84
-40
Cython/Compiler/Buffer.py
Cython/Compiler/Buffer.py
+17
-11
tests/run/bufaccess.h
tests/run/bufaccess.h
+3
-1
tests/run/bufaccess.pyx
tests/run/bufaccess.pyx
+64
-28
No files found.
Cython/Compiler/Buffer.py
View file @
edffe666
...
@@ -474,20 +474,26 @@ def get_ts_check_item(dtype, writer):
...
@@ -474,20 +474,26 @@ def get_ts_check_item(dtype, writer):
(
'b'
,
'char'
),
(
'h'
,
'short'
),
(
'i'
,
'int'
),
(
'b'
,
'char'
),
(
'h'
,
'short'
),
(
'i'
,
'int'
),
(
'l'
,
'long'
),
(
'q'
,
'long long'
)
(
'l'
,
'long'
),
(
'q'
,
'long long'
)
]
]
if
dtype
.
signed
==
0
:
elif
dtype
.
is_float
:
code
+=
""
.
join
([
"
\
n
case '%s': ok = (sizeof(%s) == sizeof(%s) && (%s)-1 > 0); break;"
%
types
=
[(
'f'
,
'float'
),
(
'd'
,
'double'
),
(
'g'
,
'long double'
)]
else
:
assert
False
if
dtype
.
signed
==
0
:
code
+=
""
.
join
([
"
\
n
case '%s': ok = (sizeof(%s) == sizeof(%s) && (%s)-1 > 0); break;"
%
(
char
.
upper
(),
ctype
,
against
,
ctype
)
for
char
,
against
in
types
])
(
char
.
upper
(),
ctype
,
against
,
ctype
)
for
char
,
against
in
types
])
else
:
else
:
code
+=
""
.
join
([
"
\
n
case '%s': ok = (sizeof(%s) == sizeof(%s) && (%s)-1 < 0); break;"
%
code
+=
""
.
join
([
"
\
n
case '%s': ok = (sizeof(%s) == sizeof(%s) && (%s)-1 < 0); break;"
%
(
char
,
ctype
,
against
,
ctype
)
for
char
,
against
in
types
])
(
char
,
ctype
,
against
,
ctype
)
for
char
,
against
in
types
])
code
+=
dedent
(
"""
\
code
+=
dedent
(
"""
\
default: ok = 0;
default: ok = 0;
}
}
if (!ok) {
if (!ok) {
PyErr_Format(PyExc_ValueError, "Buffer datatype mismatch (rejecting on '%s')", ts);
PyErr_Format(PyExc_ValueError, "Buffer datatype mismatch (rejecting on '%s')", ts);
return NULL;
return NULL;
} else return ts + 1;
} else return ts + 1;
"""
,
2
)
"""
,
2
)
writer
.
globalstate
.
use_utility_code
([
dedent
(
"""
\
writer
.
globalstate
.
use_utility_code
([
dedent
(
"""
\
static const char* %s(const char* ts); /*proto*/
static const char* %s(const char* ts); /*proto*/
"""
)
%
name
,
dedent
(
"""
"""
)
%
name
,
dedent
(
"""
...
...
tests/run/bufaccess.h
View file @
edffe666
/* See bufaccess.pyx */
/* See bufaccess.pyx */
typedef
short
htypedef_short
;
typedef
short
td_h_short
;
typedef
double
td_h_double
;
typedef
unsigned
short
td_h_ushort
;
tests/run/bufaccess.pyx
View file @
edffe666
...
@@ -657,19 +657,22 @@ def printbuf_float(o, shape):
...
@@ -657,19 +657,22 @@ def printbuf_float(o, shape):
#
#
# Typedefs
# Typedefs
#
#
ctypedef
int
cytypedef_int
# Test three layers of typedefs going through a h file for plain int, and
# simply a header file typedef for floats and unsigned.
ctypedef
int
td_cy_int
cdef
extern
from
"bufaccess.h"
:
cdef
extern
from
"bufaccess.h"
:
ctypedef
cytypedef_int
htypedef_short
# Defined as short, but Cython doesn't know this!
ctypedef
td_cy_int
td_h_short
# Defined as short, but Cython doesn't know this!
ctypedef
htypedef_short
cytypedef2
ctypedef
float
td_h_double
# Defined as double
ctypedef
unsigned
int
td_h_ushort
# Defined as unsigned short
ctypedef
td_h_short
td_h_cy_short
@
testcase
@
testcase
def
printbuf_
cytypedef_int
(
object
[
cytypedef
_int
]
buf
,
shape
):
def
printbuf_
td_cy_int
(
object
[
td_cy
_int
]
buf
,
shape
):
"""
"""
>>> printbuf_cytypedef_int(IntMockBuffer("A", range(3)), (3,))
>>> printbuf_td_cy_int(IntMockBuffer(None, range(3)), (3,))
acquired A
0 1 2 END
0 1 2 END
released A
>>> printbuf_td_cy_int(ShortMockBuffer(None, range(3)), (3,))
>>> printbuf_cytypedef_int(ShortMockBuffer("B", range(3)), (3,))
Traceback (most recent call last):
Traceback (most recent call last):
...
...
ValueError: Buffer datatype mismatch (rejecting on 'h')
ValueError: Buffer datatype mismatch (rejecting on 'h')
...
@@ -681,41 +684,66 @@ def printbuf_cytypedef_int(object[cytypedef_int] buf, shape):
...
@@ -681,41 +684,66 @@ def printbuf_cytypedef_int(object[cytypedef_int] buf, shape):
print
'END'
print
'END'
@
testcase
@
testcase
def
printbuf_
htypedef_short
(
object
[
htypedef
_short
]
buf
,
shape
):
def
printbuf_
td_h_short
(
object
[
td_h
_short
]
buf
,
shape
):
"""
"""
>>> printbuf_htypedef_short(ShortMockBuffer("A", range(3)), (3,))
>>> printbuf_td_h_short(ShortMockBuffer(None, range(3)), (3,))
acquired A
0 1 2 END
0 1 2 END
released A
>>> printbuf_td_h_short(IntMockBuffer(None, range(3)), (3,))
>>> printbuf_htypedef_short(IntMockBuffer("B", range(3)), (3,))
Traceback (most recent call last):
Traceback (most recent call last):
...
...
ValueError: Buffer datatype mismatch (rejecting on 'i')
ValueError: Buffer datatype mismatch (rejecting on 'i')
"""
"""
cdef
int
i
cdef
int
i
for
i
in
range
(
shape
[
0
]):
for
i
in
range
(
shape
[
0
]):
print
buf
[
i
],
print
buf
[
i
],
print
'END'
print
'END'
@
testcase
@
testcase
def
printbuf_
cytypedef2
(
object
[
cytypedef2
]
buf
,
shape
):
def
printbuf_
td_h_cy_short
(
object
[
td_h_cy_short
]
buf
,
shape
):
"""
"""
>>> printbuf_cytypedef2(ShortMockBuffer("A", range(3)), (3,))
>>> printbuf_td_h_cy_short(ShortMockBuffer(None, range(3)), (3,))
acquired A
0 1 2 END
0 1 2 END
released A
>>> printbuf_td_h_cy_short(IntMockBuffer(None, range(3)), (3,))
>>> printbuf_cytypedef2(IntMockBuffer("B", range(3)), (3,))
Traceback (most recent call last):
Traceback (most recent call last):
...
...
ValueError: Buffer datatype mismatch (rejecting on 'i')
ValueError: Buffer datatype mismatch (rejecting on 'i')
"""
"""
cdef
int
i
cdef
int
i
for
i
in
range
(
shape
[
0
]):
for
i
in
range
(
shape
[
0
]):
print
buf
[
i
],
print
buf
[
i
],
print
'END'
print
'END'
@
testcase
def
printbuf_td_h_ushort
(
object
[
td_h_ushort
]
buf
,
shape
):
"""
>>> printbuf_td_h_ushort(UnsignedShortMockBuffer(None, range(3)), (3,))
0 1 2 END
>>> printbuf_td_h_ushort(ShortMockBuffer(None, range(3)), (3,))
Traceback (most recent call last):
...
ValueError: Buffer datatype mismatch (rejecting on 'h')
"""
cdef
int
i
for
i
in
range
(
shape
[
0
]):
print
buf
[
i
],
print
'END'
@
testcase
def
printbuf_td_h_double
(
object
[
td_h_double
]
buf
,
shape
):
"""
>>> printbuf_td_h_double(DoubleMockBuffer(None, [0.25, 1, 3.125]), (3,))
0.25 1.0 3.125 END
>>> printbuf_td_h_double(FloatMockBuffer(None, [0.25, 1, 3.125]), (3,))
Traceback (most recent call last):
...
ValueError: Buffer datatype mismatch (rejecting on 'f')
"""
cdef
int
i
for
i
in
range
(
shape
[
0
]):
print
buf
[
i
],
print
'END'
#
#
# Object access
# Object access
#
#
...
@@ -932,13 +960,6 @@ cdef class MockBuffer:
...
@@ -932,13 +960,6 @@ cdef class MockBuffer:
cdef
get_default_format
(
self
):
cdef
get_default_format
(
self
):
print
"ERROR, not subclassed"
,
self
.
__class__
print
"ERROR, not subclassed"
,
self
.
__class__
cdef
class
FloatMockBuffer
(
MockBuffer
):
cdef
int
write
(
self
,
char
*
buf
,
object
value
)
except
-
1
:
(
<
float
*>
buf
)[
0
]
=
<
float
>
value
return
0
cdef
get_itemsize
(
self
):
return
sizeof
(
float
)
cdef
get_default_format
(
self
):
return
b"=f"
cdef
class
IntMockBuffer
(
MockBuffer
):
cdef
class
IntMockBuffer
(
MockBuffer
):
cdef
int
write
(
self
,
char
*
buf
,
object
value
)
except
-
1
:
cdef
int
write
(
self
,
char
*
buf
,
object
value
)
except
-
1
:
(
<
int
*>
buf
)[
0
]
=
<
int
>
value
(
<
int
*>
buf
)[
0
]
=
<
int
>
value
...
@@ -960,6 +981,21 @@ cdef class UnsignedShortMockBuffer(MockBuffer):
...
@@ -960,6 +981,21 @@ cdef class UnsignedShortMockBuffer(MockBuffer):
cdef
get_itemsize
(
self
):
return
sizeof
(
unsigned
short
)
cdef
get_itemsize
(
self
):
return
sizeof
(
unsigned
short
)
cdef
get_default_format
(
self
):
return
b"=1H"
# Try with repeat count
cdef
get_default_format
(
self
):
return
b"=1H"
# Try with repeat count
cdef
class
FloatMockBuffer
(
MockBuffer
):
cdef
int
write
(
self
,
char
*
buf
,
object
value
)
except
-
1
:
(
<
float
*>
buf
)[
0
]
=
<
float
>
value
return
0
cdef
get_itemsize
(
self
):
return
sizeof
(
float
)
cdef
get_default_format
(
self
):
return
b"f"
cdef
class
DoubleMockBuffer
(
MockBuffer
):
cdef
int
write
(
self
,
char
*
buf
,
object
value
)
except
-
1
:
(
<
double
*>
buf
)[
0
]
=
<
double
>
value
return
0
cdef
get_itemsize
(
self
):
return
sizeof
(
double
)
cdef
get_default_format
(
self
):
return
b"d"
cdef
extern
from
*
:
cdef
extern
from
*
:
void
*
addr_of_pyobject
"(void*)"
(
object
)
void
*
addr_of_pyobject
"(void*)"
(
object
)
...
...
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