Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
gaoqiong
pybind11
Commits
9883ec01
Commit
9883ec01
authored
Mar 26, 2016
by
Wenzel Jakob
Browse files
allow nullptr string values (closes #138)
parent
7393343f
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
31 additions
and
9 deletions
+31
-9
example/example14.cpp
example/example14.cpp
+2
-0
example/example14.py
example/example14.py
+5
-2
example/example14.ref
example/example14.ref
+2
-0
include/pybind11/cast.h
include/pybind11/cast.h
+22
-7
No files found.
example/example14.cpp
View file @
9883ec01
...
...
@@ -29,4 +29,6 @@ void init_ex14(py::module &m) {
m
.
def
(
"return_void_ptr"
,
[]()
{
return
(
void
*
)
1234
;
});
m
.
def
(
"print_void_ptr"
,
[](
void
*
ptr
)
{
std
::
cout
<<
"Got void ptr : "
<<
(
uint64_t
)
ptr
<<
std
::
endl
;
});
m
.
def
(
"return_null_str"
,
[]()
{
return
(
char
*
)
nullptr
;
});
m
.
def
(
"print_null_str"
,
[](
char
*
ptr
)
{
std
::
cout
<<
"Got null str : "
<<
(
uint64_t
)
ptr
<<
std
::
endl
;
});
}
example/example14.py
View file @
9883ec01
...
...
@@ -4,6 +4,8 @@ import sys
sys
.
path
.
append
(
'.'
)
from
example
import
StringList
,
print_opaque_list
from
example
import
return_void_ptr
,
print_void_ptr
from
example
import
return_null_str
,
print_null_str
l
=
StringList
()
l
.
push_back
(
"Element 1"
)
...
...
@@ -13,6 +15,7 @@ print("Back element is %s" % l.back())
l
.
pop_back
()
print_opaque_list
(
l
)
from
example
import
return_void_ptr
,
print_void_ptr
print_void_ptr
(
return_void_ptr
())
print
(
return_null_str
())
print_null_str
(
return_null_str
())
example/example14.ref
View file @
9883ec01
...
...
@@ -5,3 +5,5 @@ Back element is Element 2
Opaque list:
Element 1
Got void ptr : 1234
None
Got null str : 0
include/pybind11/cast.h
View file @
9883ec01
...
...
@@ -391,6 +391,7 @@ public:
int
err
=
PYBIND11_BYTES_AS_STRING_AND_SIZE
(
load_src
.
ptr
(),
&
buffer
,
&
length
);
if
(
err
==
-
1
)
{
PyErr_Clear
();
return
false
;
}
// TypeError
value
=
std
::
string
(
buffer
,
length
);
success
=
true
;
return
true
;
}
...
...
@@ -399,6 +400,8 @@ public:
}
PYBIND11_TYPE_CASTER
(
std
::
string
,
_
(
PYBIND11_STRING_NAME
));
protected:
bool
success
=
false
;
};
template
<
>
class
type_caster
<
std
::
wstring
>
{
...
...
@@ -428,6 +431,7 @@ public:
#endif
if
(
!
buffer
)
{
PyErr_Clear
();
return
false
;
}
value
=
std
::
wstring
(
buffer
,
length
);
success
=
true
;
return
true
;
}
...
...
@@ -436,11 +440,19 @@ public:
}
PYBIND11_TYPE_CASTER
(
std
::
wstring
,
_
(
PYBIND11_STRING_NAME
));
protected:
bool
success
=
false
;
};
template
<
>
class
type_caster
<
char
>
:
public
type_caster
<
std
::
string
>
{
public:
bool
load
(
handle
src
,
bool
convert
)
{
if
(
src
.
ptr
()
==
Py_None
)
{
return
true
;
}
return
type_caster
<
std
::
string
>::
load
(
src
,
convert
);
}
static
handle
cast
(
const
char
*
src
,
return_value_policy
/* policy */
,
handle
/* parent */
)
{
if
(
src
==
nullptr
)
return
handle
(
Py_None
).
inc_ref
();
return
PyUnicode_FromString
(
src
);
}
...
...
@@ -449,18 +461,21 @@ public:
return
PyUnicode_DecodeLatin1
(
str
,
1
,
nullptr
);
}
operator
char
*
()
{
return
(
char
*
)
value
.
c_str
();
}
operator
char
()
{
if
(
value
.
length
()
>
0
)
return
value
[
0
];
else
return
'\0'
;
}
template
<
typename
T
>
using
cast_op_type
=
typename
std
::
conditional
<
std
::
is_pointer
<
T
>::
value
,
char
*
,
char
>::
type
;
operator
char
*
()
{
return
success
?
(
char
*
)
value
.
c_str
()
:
nullptr
;
}
operator
char
&
()
{
return
value
[
0
];
}
static
PYBIND11_DESCR
name
()
{
return
type_descr
(
_
(
PYBIND11_STRING_NAME
));
}
};
template
<
>
class
type_caster
<
wchar_t
>
:
public
type_caster
<
std
::
wstring
>
{
public:
bool
load
(
handle
src
,
bool
convert
)
{
if
(
src
.
ptr
()
==
Py_None
)
{
return
true
;
}
return
type_caster
<
std
::
wstring
>::
load
(
src
,
convert
);
}
static
handle
cast
(
const
wchar_t
*
src
,
return_value_policy
/* policy */
,
handle
/* parent */
)
{
if
(
src
==
nullptr
)
return
handle
(
Py_None
).
inc_ref
();
return
PyUnicode_FromWideChar
(
src
,
wcslen
(
src
));
}
...
...
@@ -469,8 +484,8 @@ public:
return
PyUnicode_FromWideChar
(
wstr
,
1
);
}
operator
wchar_t
*
()
{
return
(
wchar_t
*
)
value
.
c_str
();
}
operator
wchar_t
()
{
if
(
value
.
length
()
>
0
)
return
value
[
0
];
else
return
L'\0'
;
}
operator
wchar_t
*
()
{
return
success
?
(
wchar_t
*
)
value
.
c_str
()
:
nullptr
;
}
operator
wchar_t
&
()
{
return
value
[
0
]
;
}
static
PYBIND11_DESCR
name
()
{
return
type_descr
(
_
(
PYBIND11_STRING_NAME
));
}
};
...
...
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