Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
pybind11
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
open
pybind11
Commits
bd57eb48
Commit
bd57eb48
authored
May 01, 2016
by
Wenzel Jakob
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
don't try to cast 'None' into a C++ lvalue reference
parent
bdd11030
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
24 additions
and
6 deletions
+24
-6
example/issues.cpp
+5
-2
example/issues.py
+6
-1
example/issues.ref
+3
-0
include/pybind11/cast.h
+3
-1
include/pybind11/pybind11.h
+7
-2
No files found.
example/issues.cpp
View file @
bd57eb48
...
@@ -21,7 +21,7 @@ void init_issues(py::module &m) {
...
@@ -21,7 +21,7 @@ void init_issues(py::module &m) {
// #70 compilation issue if operator new is not public
// #70 compilation issue if operator new is not public
class
NonConstructible
{
private
:
void
*
operator
new
(
size_t
bytes
)
throw
();
};
class
NonConstructible
{
private
:
void
*
operator
new
(
size_t
bytes
)
throw
();
};
py
::
class_
<
NonConstructible
>
(
m
,
"Foo"
);
py
::
class_
<
NonConstructible
>
(
m
,
"Foo"
);
m
.
def
(
"getstmt"
,
[]()
->
NonConstructible
*
{
return
nullptr
;
},
m
2
.
def
(
"getstmt"
,
[]()
->
NonConstructible
*
{
return
nullptr
;
},
py
::
return_value_policy
::
reference
);
py
::
return_value_policy
::
reference
);
#endif
#endif
...
@@ -101,4 +101,7 @@ void init_issues(py::module &m) {
...
@@ -101,4 +101,7 @@ void init_issues(py::module &m) {
list
.
append
(
py
::
cast
(
e
));
list
.
append
(
py
::
cast
(
e
));
return
list
;
return
list
;
});
});
};
// (no id): should not be able to pass 'None' to a reference argument
m2
.
def
(
"print_element"
,
[](
ElementA
&
el
)
{
std
::
cout
<<
el
.
value
()
<<
std
::
endl
;
});
}
example/issues.py
View file @
bd57eb48
...
@@ -7,7 +7,7 @@ from example.issues import print_cchar, print_char
...
@@ -7,7 +7,7 @@ from example.issues import print_cchar, print_char
from
example.issues
import
DispatchIssue
,
dispatch_issue_go
from
example.issues
import
DispatchIssue
,
dispatch_issue_go
from
example.issues
import
Placeholder
,
return_vec_of_reference_wrapper
from
example.issues
import
Placeholder
,
return_vec_of_reference_wrapper
from
example.issues
import
iterator_passthrough
from
example.issues
import
iterator_passthrough
from
example.issues
import
ElementList
,
ElementA
from
example.issues
import
ElementList
,
ElementA
,
print_element
import
gc
import
gc
print_cchar
(
"const char *"
)
print_cchar
(
"const char *"
)
...
@@ -42,3 +42,8 @@ gc.collect()
...
@@ -42,3 +42,8 @@ gc.collect()
for
i
,
v
in
enumerate
(
el
.
get
()):
for
i
,
v
in
enumerate
(
el
.
get
()):
print
(
"
%
i==
%
i, "
%
(
i
,
v
.
value
()),
end
=
''
)
print
(
"
%
i==
%
i, "
%
(
i
,
v
.
value
()),
end
=
''
)
print
()
print
()
try
:
print_element
(
None
)
except
Exception
as
e
:
print
(
"Failed as expected: "
+
str
(
e
))
example/issues.ref
View file @
bd57eb48
...
@@ -5,3 +5,6 @@ Yay..
...
@@ -5,3 +5,6 @@ Yay..
[Placeholder[1], Placeholder[2], Placeholder[3], Placeholder[4]]
[Placeholder[1], Placeholder[2], Placeholder[3], Placeholder[4]]
[3, 5, 7, 9, 11, 13, 15]
[3, 5, 7, 9, 11, 13, 15]
0==0, 1==1, 2==2, 3==3, 4==4, 5==5, 6==6, 7==7, 8==8, 9==9,
0==0, 1==1, 2==2, 3==3, 4==4, 5==5, 6==6, 7==7, 8==8, 9==9,
Failed as expected: Incompatible function arguments. The following argument types are supported:
1. (example.issues.ElementA) -> NoneType
include/pybind11/cast.h
View file @
bd57eb48
...
@@ -225,6 +225,8 @@ using cast_op_type = typename std::conditional<std::is_pointer<typename std::rem
...
@@ -225,6 +225,8 @@ using cast_op_type = typename std::conditional<std::is_pointer<typename std::rem
typename
std
::
add_pointer
<
typename
intrinsic_type
<
T
>::
type
>::
type
,
typename
std
::
add_pointer
<
typename
intrinsic_type
<
T
>::
type
>::
type
,
typename
std
::
add_lvalue_reference
<
typename
intrinsic_type
<
T
>::
type
>::
type
>::
type
;
typename
std
::
add_lvalue_reference
<
typename
intrinsic_type
<
T
>::
type
>::
type
>::
type
;
/// Thrown then trying to cast a null pointer into a reference argument
class
invalid_reference_cast
:
public
std
::
exception
{
};
/// Generic type caster for objects stored on the heap
/// Generic type caster for objects stored on the heap
template
<
typename
type
>
class
type_caster_base
:
public
type_caster_generic
{
template
<
typename
type
>
class
type_caster_base
:
public
type_caster_generic
{
...
@@ -254,7 +256,7 @@ public:
...
@@ -254,7 +256,7 @@ public:
template
<
typename
T
>
using
cast_op_type
=
pybind11
::
detail
::
cast_op_type
<
T
>
;
template
<
typename
T
>
using
cast_op_type
=
pybind11
::
detail
::
cast_op_type
<
T
>
;
operator
type
*
()
{
return
(
type
*
)
value
;
}
operator
type
*
()
{
return
(
type
*
)
value
;
}
operator
type
&
()
{
return
*
((
type
*
)
value
);
}
operator
type
&
()
{
if
(
!
value
)
throw
invalid_reference_cast
();
return
*
((
type
*
)
value
);
}
protected
:
protected
:
typedef
void
*
(
*
Constructor
)(
const
void
*
stream
);
typedef
void
*
(
*
Constructor
)(
const
void
*
stream
);
...
...
include/pybind11/pybind11.h
View file @
bd57eb48
...
@@ -409,8 +409,13 @@ protected:
...
@@ -409,8 +409,13 @@ protected:
}
}
}
}
}
}
if
(
kwargs_consumed
==
nkwargs
)
result
=
it
->
impl
(
it
,
args_
,
parent
);
try
{
if
(
kwargs_consumed
==
nkwargs
)
result
=
it
->
impl
(
it
,
args_
,
parent
);
}
catch
(
detail
::
invalid_reference_cast
&
)
{
result
=
PYBIND11_TRY_NEXT_OVERLOAD
;
}
if
(
result
.
ptr
()
!=
PYBIND11_TRY_NEXT_OVERLOAD
)
if
(
result
.
ptr
()
!=
PYBIND11_TRY_NEXT_OVERLOAD
)
break
;
break
;
...
...
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