From bb23ba754fd3f79fd008395b607d80e039c4563c Mon Sep 17 00:00:00 2001 From: andriish Date: Tue, 9 Apr 2024 01:40:45 +0200 Subject: [PATCH] Update context.cpp to comply with pybind11 2.0+ docs (#297) * LLVM 18 compatibility * Update context.cpp to comply with pybind11 2.0+ docs --- source/class.cpp | 12 ++++++++++++ source/context.cpp | 4 ++-- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/source/class.cpp b/source/class.cpp index 13156359..b9f98f38 100644 --- a/source/class.cpp +++ b/source/class.cpp @@ -616,7 +616,11 @@ bool is_callback_structure_needed(CXXRecordDecl const *C) // check if all pure-virtual methods could be overridden in Python if( C->isAbstract() ) { for( auto m = C->method_begin(); m != C->method_end(); ++m ) { +#if( LLVM_VERSION_MAJOR >= 18 ) + if( m->isPureVirtual() and is_const_overload(*m) ) return false; // it is not clear how to deal with this case since we can't overrdie const versions in Python, - so disabling for now +#else if( m->isPure() and is_const_overload(*m) ) return false; // it is not clear how to deal with this case since we can't overrdie const versions in Python, - so disabling for now +#endif } } @@ -644,7 +648,11 @@ bool is_callback_structure_constructible(CXXRecordDecl const *C) { if( C->isAbstract() ) { for( auto m = C->method_begin(); m != C->method_end(); ++m ) { +#if( LLVM_VERSION_MAJOR >= 18 ) + if( m->isPureVirtual() and !isa(*m) and (m->getAccess() == AS_private or !is_bindable(*m) or is_skipping_requested(*m, Config::get())) ) return false; +#else if( m->isPure() and !isa(*m) and (m->getAccess() == AS_private or !is_bindable(*m) or is_skipping_requested(*m, Config::get())) ) return false; +#endif } for( auto b = C->bases_begin(); b != C->bases_end(); ++b ) { @@ -766,7 +774,11 @@ string bind_member_functions_for_call_back(CXXRecordDecl const *C, string const string custom_function_info = Config::get().is_custom_trampoline_function_requested(member_function_name); if( custom_function_info == "" ) { c += indent(fmt::format(call_back_function_body_template, class_name, /*class_qualified_name(C), */ python_name, std::get<1>(args), return_type), "\t\t"); +#if( LLVM_VERSION_MAJOR >= 18 ) + if( m->isPureVirtual() ) c += "\t\tpybind11::pybind11_fail(\"Tried to call pure virtual function \\\"{}::{}\\\"\");\n"_format(C->getNameAsString(), python_name); +#else if( m->isPure() ) c += "\t\tpybind11::pybind11_fail(\"Tried to call pure virtual function \\\"{}::{}\\\"\");\n"_format(C->getNameAsString(), python_name); +#endif else c += "\t\treturn {}::{}({});\n"_format(C->getNameAsString(), m->getNameAsString(), std::get<1>(args)); } else { diff --git a/source/context.cpp b/source/context.cpp index 5aea93e9..21deda9d 100644 --- a/source/context.cpp +++ b/source/context.cpp @@ -132,7 +132,7 @@ const char *module_header = R"_( #ifndef BINDER_PYBIND11_TYPE_CASTER #define BINDER_PYBIND11_TYPE_CASTER {2} - PYBIND11_DECLARE_HOLDER_TYPE(T, T*) + PYBIND11_DECLARE_HOLDER_TYPE(T, T*, false) {3} #endif @@ -437,7 +437,7 @@ void Context::generate(Config const &config) string const holder_type = Config::get().holder_type(); - string shared_declare = "PYBIND11_DECLARE_HOLDER_TYPE(T, "+holder_type+")"; + string shared_declare = "PYBIND11_DECLARE_HOLDER_TYPE(T, "+holder_type+", false)"; string shared_make_opaque = "PYBIND11_MAKE_OPAQUE("+holder_type+")"; string const pybind11_include = "#include <" + Config::get().pybind11_include_file() + ">";