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
5de93050
Commit
5de93050
authored
Apr 25, 2012
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
clean up charptr types to support bytes/charptr coercion also for ctypedef'ed types in general
parent
7ab45417
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
71 additions
and
79 deletions
+71
-79
Cython/Compiler/PyrexTypes.py
Cython/Compiler/PyrexTypes.py
+42
-79
tests/run/ctypedef_char_types.pyx
tests/run/ctypedef_char_types.pyx
+29
-0
No files found.
Cython/Compiler/PyrexTypes.py
View file @
5de93050
...
@@ -2130,22 +2130,53 @@ impl="""
...
@@ -2130,22 +2130,53 @@ impl="""
#endif
#endif
"""
)
"""
)
class
CArrayType
(
CType
):
class
CPointerBaseType
(
CType
):
# base_type CType Element type
# common base type for pointer/array types
# size integer or None Number of elements
#
# base_type CType Reference type
is_array
=
1
subtypes
=
[
'base_type'
]
subtypes
=
[
'base_type'
]
def
__init__
(
self
,
base_type
,
size
):
def
__init__
(
self
,
base_type
):
self
.
base_type
=
base_type
self
.
base_type
=
base_type
self
.
size
=
size
for
char_type
in
(
c_char_type
,
c_uchar_type
,
c_schar_type
):
for
char_type
in
(
c_char_type
,
c_uchar_type
,
c_schar_type
):
if
base_type
.
same_as
(
char_type
):
if
base_type
.
same_as
(
char_type
):
self
.
is_string
=
1
self
.
is_string
=
1
break
break
if
self
.
is_string
:
if
base_type
.
signed
:
self
.
to_py_function
=
"__Pyx_PyBytes_FromUString"
if
self
.
is_ptr
:
self
.
from_py_function
=
"__Pyx_PyBytes_AsUString"
else
:
self
.
to_py_function
=
"PyBytes_FromString"
if
self
.
is_ptr
:
self
.
from_py_function
=
"PyBytes_AsString"
self
.
exception_value
=
"NULL"
def
py_type_name
(
self
):
if
self
.
is_string
:
return
"bytes"
else
:
return
super
(
CPointerBaseType
,
self
).
py_type_name
()
def
literal_code
(
self
,
value
):
if
self
.
is_string
:
assert
isinstance
(
value
,
str
)
return
'"%s"'
%
StringEncoding
.
escape_byte_string
(
value
)
class
CArrayType
(
CPointerBaseType
):
# base_type CType Element type
# size integer or None Number of elements
is_array
=
1
def
__init__
(
self
,
base_type
,
size
):
super
(
CArrayType
,
self
).
__init__
(
base_type
)
self
.
size
=
size
def
__repr__
(
self
):
def
__repr__
(
self
):
return
"<CArrayType %s %s>"
%
(
self
.
size
,
repr
(
self
.
base_type
))
return
"<CArrayType %s %s>"
%
(
self
.
size
,
repr
(
self
.
base_type
))
...
@@ -2180,21 +2211,12 @@ class CArrayType(CType):
...
@@ -2180,21 +2211,12 @@ class CArrayType(CType):
return
self
.
size
is
not
None
return
self
.
size
is
not
None
class
CPtrType
(
CType
):
class
CPtrType
(
C
PointerBase
Type
):
# base_type CType
Referenced
type
# base_type CType
Reference
type
is_ptr
=
1
is_ptr
=
1
default_value
=
"0"
default_value
=
"0"
subtypes
=
[
'base_type'
]
def
__init__
(
self
,
base_type
):
self
.
base_type
=
base_type
for
char_type
in
(
c_char_type
,
c_uchar_type
,
c_schar_type
):
if
base_type
.
same_as
(
char_type
):
self
.
is_string
=
1
break
def
__repr__
(
self
):
def
__repr__
(
self
):
return
"<CPtrType %s>"
%
repr
(
self
.
base_type
)
return
"<CPtrType %s>"
%
repr
(
self
.
base_type
)
...
@@ -3110,63 +3132,6 @@ class CEnumType(CType):
...
@@ -3110,63 +3132,6 @@ class CEnumType(CType):
base_code
=
public_decl
(
base_code
,
dll_linkage
)
base_code
=
public_decl
(
base_code
,
dll_linkage
)
return
self
.
base_declaration_code
(
base_code
,
entity_code
)
return
self
.
base_declaration_code
(
base_code
,
entity_code
)
class
CStringType
(
object
):
# Mixin class for C string types.
is_string
=
1
is_unicode
=
0
to_py_function
=
"PyBytes_FromString"
from_py_function
=
"PyBytes_AsString"
exception_value
=
"NULL"
def
literal_code
(
self
,
value
):
assert
isinstance
(
value
,
str
)
return
'"%s"'
%
StringEncoding
.
escape_byte_string
(
value
)
def
py_type_name
(
self
):
if
self
.
is_unicode
:
return
"unicode"
return
"bytes"
class
CUTF8CharArrayType
(
CStringType
,
CArrayType
):
# C 'char []' type.
is_unicode
=
1
to_py_function
=
"PyUnicode_DecodeUTF8"
exception_value
=
"NULL"
def
__init__
(
self
,
size
):
CArrayType
.
__init__
(
self
,
c_char_type
,
size
)
class
CCharArrayType
(
CStringType
,
CArrayType
):
# C 'char []' type.
from_py_function
=
None
def
__init__
(
self
,
size
):
CArrayType
.
__init__
(
self
,
c_char_type
,
size
)
class
CCharPtrType
(
CStringType
,
CPtrType
):
# C 'char *' type.
def
__init__
(
self
):
CPtrType
.
__init__
(
self
,
c_char_type
)
class
CUCharPtrType
(
CStringType
,
CPtrType
):
# C 'unsigned char *' type.
to_py_function
=
"__Pyx_PyBytes_FromUString"
from_py_function
=
"__Pyx_PyBytes_AsUString"
def
__init__
(
self
):
CPtrType
.
__init__
(
self
,
c_uchar_type
)
class
UnspecifiedType
(
PyrexType
):
class
UnspecifiedType
(
PyrexType
):
# Used as a placeholder until the type can be determined.
# Used as a placeholder until the type can be determined.
...
@@ -3270,10 +3235,8 @@ c_size_t_type = CSizeTType(RANK_LONG+0.5, UNSIGNED)
...
@@ -3270,10 +3235,8 @@ c_size_t_type = CSizeTType(RANK_LONG+0.5, UNSIGNED)
c_null_ptr_type
=
CNullPtrType
(
c_void_type
)
c_null_ptr_type
=
CNullPtrType
(
c_void_type
)
c_void_ptr_type
=
CPtrType
(
c_void_type
)
c_void_ptr_type
=
CPtrType
(
c_void_type
)
c_void_ptr_ptr_type
=
CPtrType
(
c_void_ptr_type
)
c_void_ptr_ptr_type
=
CPtrType
(
c_void_ptr_type
)
c_char_array_type
=
CCharArrayType
(
None
)
c_char_ptr_type
=
CPtrType
(
c_char_type
)
c_char_ptr_type
=
CCharPtrType
()
c_uchar_ptr_type
=
CPtrType
(
c_uchar_type
)
c_uchar_ptr_type
=
CUCharPtrType
()
c_utf8_char_array_type
=
CUTF8CharArrayType
(
None
)
c_char_ptr_ptr_type
=
CPtrType
(
c_char_ptr_type
)
c_char_ptr_ptr_type
=
CPtrType
(
c_char_ptr_type
)
c_int_ptr_type
=
CPtrType
(
c_int_type
)
c_int_ptr_type
=
CPtrType
(
c_int_type
)
c_py_unicode_ptr_type
=
CPtrType
(
c_py_unicode_type
)
c_py_unicode_ptr_type
=
CPtrType
(
c_py_unicode_type
)
...
...
tests/run/ctypedef_char_types.pyx
0 → 100644
View file @
5de93050
cimport
cython
from
cython
cimport
typeof
from
libc.string
cimport
const_char
,
const_uchar
@
cython
.
test_assert_path_exists
(
"//NameNode[@name = 'st' and @type.is_string = True]"
,
"//NameNode[@name = 'ust' and @type.is_string = True]"
,
"//NameNode[@name = 'my_st' and @type.is_string = True]"
,
"//NameNode[@name = 'my_ust' and @type.is_string = True]"
,
)
def
const_charptrs
():
"""
>>> const_charptrs()
"""
cdef
object
obj
cdef
const_char
*
st
=
b'XYZ'
cdef
const_uchar
*
ust
=
b'XYZ'
assert
typeof
(
st
)
==
"const_char *"
,
typeof
(
st
)
my_st
=
st
assert
typeof
(
my_st
)
==
"const_char *"
,
typeof
(
my_st
)
obj
=
my_st
assert
typeof
(
ust
)
==
"const_uchar *"
,
typeof
(
ust
)
my_ust
=
ust
assert
typeof
(
my_ust
)
==
"const_uchar *"
,
typeof
(
my_ust
)
obj
=
my_ust
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