Skip to content
Snippets Groups Projects
Commit cdd47a27 authored by Enric Tejedor Saavedra's avatar Enric Tejedor Saavedra
Browse files

[ROOT-9859] Fall back to __repr__ in __str__ if cling returns an address

parent dad450da
No related branches found
No related tags found
No related merge requests found
...@@ -2272,7 +2272,13 @@ namespace { ...@@ -2272,7 +2272,13 @@ namespace {
Py_XDECREF(cppname); Py_XDECREF(cppname);
std::string printResult = gInterpreter->ToString(className.c_str(), self->GetObject()); std::string printResult = gInterpreter->ToString(className.c_str(), self->GetObject());
return PyROOT_PyUnicode_FromString(printResult.c_str()); if (printResult.find("@0x") == 0) {
// Fall back to __repr__ if we just get an address from cling
auto method = PyObject_GetAttrString((PyObject*)self, "__repr__");
return PyObject_CallObject(method, nullptr);
} else {
return PyROOT_PyUnicode_FromString(printResult.c_str());
}
} }
//- Adding array interface to classes --------------- //- Adding array interface to classes ---------------
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment