-
Notifications
You must be signed in to change notification settings - Fork 521
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fatal error at GetCXXRecordDclFromBaseType in Parser.cpp #1750
Comments
Sounds like an interesting bindings. Don't have time right now to properly repro and test this, but based on looking where the code fails, I've pushed some changes that hopefully will help with the crash: #1751 Let me know how it goes with the new version. |
thanks, unfortunately that has just pushed the error to a new location:
|
Can you try making the following changes to First try adding Then try replacing the
Hopefully that works around it / fixes it. |
still hitting the error though with the code change |
update, after trying to bind |
@tritao do you have any updates? we're blocked at the moment due to this, but would still very much like to use this if we can |
No updates on my side, I can try to take a look next time I got some free time, but I need a test case. It would really help if you can help get me an isolated test case that can trigger this issue. |
thanks, any of the three headers listed in my fist post will trigger it |
Ok, those are not self contained tests, ideally we have something that is only a dozen lines or so and can be included in the test suite. Usually we would start with a self-contained header (after using the preprocessing option on the compiler, so no further includes are needed), then start removing code until we as minimal repro as possible. |
that should trigger it also if we cannot fix the error, any guidance on ignoring template functions during parsing would be great |
Ok cool, thanks, I will try to repro that later. |
@r-schmitt Btw which VS version are you using? |
i built cppsharp with 2019, but im running the bindings in 2022 |
Just tried to parse this with latest CppSharp in VS2019 and can't repro it. |
could you outline your build process/MSVC version/LLVM version and cppsharp settings/.net version? i still get this error, so maybe its a mis-configuration somwhere in my build process |
I've changed the C++ version in parser options to C++17, added the above code, including |
sorry, how can i change the c++ version for the parser? i don't see an option for that |
|
thanks, still getting the same errors, will try rebuilding from scratch again |
Cool, if that doesn't work, try adding Mine are:
Maybe your C++ standard library is more recent and that causes issues. |
If this is still an issue, might be worth testing with the new Clang branch that comes with a newer Clang version and supports VS 2022: #1724 |
thanks, i've been able to test this out again and am hitting two issues
|
It definitely exists: CppSharp/examples/Parser/Parser.cs Line 36 in 3c31179
Something wrong with auto-complete maybe? Dunno.
Sounds like your |
trying to set Verbose explicitly causes a compilation error for me and rebuilding CppParser.CppParser.dll still has the error pointing to clang 14 when run. Clearly something is misconfigured, but I cannot tell what. for this branch what are the generate and build commands you recommend? I am using the OTB ones from getting started:
|
Those should do it: https://github.com/mono/CppSharp/blob/main/.github/workflows/main.yml#L43 |
CppSharp/src/CppParser/Parser.cpp Lines 877 to 905 in 9071cd2
We should remove the assertion in both functions. If you are running in release mode, they won't bother anyway. But in debug mode they are buggy when you try to resolve a template parameter or a dependent type. The main purpose of these functions is to resolve the base classes of a struct/class in order to calculate the layout.In the case of a dependent type as base classes, this won't make any sense because the type can't be resolved. Check #1819, in the future layout calculation should be done on the managed side. |
Brief Description
We are attempting to use CppSharp to bind Pixar's USD library to C# to hopefully enable a great development environment for USD in C#
On first pass, we got about a 50% success rate, almost all the failures were here:
Parser.cpp line 884
These fatal parsing errors prevent us from generating any output, but I have unable to identify what specifically is breaking at this point. Any help identifying how we can avoid this error would be awesome! I've been very happy with what we've been able to generate successfully...
OS: Windows 10
Used headers
pxr/usd/sdf/path.h
pxr/usd/usd/prim.h
pxr/usd/usd/stage.h
these are three examples, representing a lot of core USD functionality
Used settings
DriverOptions options = driver.Options;
options.GeneratorKind = GeneratorKind.CSharp;
options.Verbose = true;
options.GenerationOutputMode = GenerationOutputMode.FilePerUnit;
Other settings
USD was exported with the cmake flag
set(CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS ON)
which is important for getting all the mangled names exported for bindings, but not needed for these parsing errorsThe text was updated successfully, but these errors were encountered: