-
Notifications
You must be signed in to change notification settings - Fork 48
Upgrade to 1.92.1 #51
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
Conversation
This is ready for review, but currently the build.zig.zon points to my forks for these changes: zig-gamedev/zsdl#24 and zig-gamedev/zgpu#18. I'll update the build.zig.zon once those are merged. |
I merged some of this into my own zgui fork so that I could test it against the zgpu changes I've been making. There are a few things that might have to be addressed later, but there was one thing I noticed which surely can be fixed right away - in zgui.cpp, there are some lingering usages of ImTextureID which I think should have been changed to ImTextureRef, but were maybe overlooked. I'll just link to the commit where I fixed them on my own fork to show you what I'm talking about: If these changes aren't made, using the affected functions will crash due to ABI mismatches. |
This commit might be directly incompatible with zig-gamedev#51
This commit might be directly incompatible with zig-gamedev#51
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pull Request Overview
This pull request upgrades Dear ImGui from version 1.91 to 1.92.1 with accompanying API changes and deprecation fixes. The main focus is implementing the new texture reference system and removing deprecated function usage.
- Updates to use TextureRef instead of TextureIdent for improved type safety in the new texture management system
- Implementation of ImGui 1.92.1's new font loader architecture replacing the old font builder system
- Removal of deprecated Dear ImGui functions throughout the codebase
Reviewed Changes
Copilot reviewed 62 out of 66 changed files in this pull request and generated 7 comments.
Show a summary per file
File | Description |
---|---|
src/zgui.cpp | Updates C bindings for new texture system and font APIs, removes deprecated window font scale |
src/gui.zig | Replaces TextureIdent with TextureRef system, updates configuration types and alignment APIs |
libs/node_editor/imgui_node_editor.cpp | Reverts workaround by re-adding GetKeyIndex calls for key handling |
libs/implot/* | Updates texture handling and conditional compilation for IMGUI_DISABLE support |
libs/imguizmo/* | Version bump and API updates for ImGuizmo compatibility |
libs/imgui_test_engine/* | License headers added and compatibility fixes for new ImGui versions |
libs/imgui/misc/freetype/* | Major refactor to new font loader architecture with TextureRef support |
Comments suppressed due to low confidence (1)
src/gui.zig:154
- Typo in field name: 'pading0' should be 'padding0' to match the corrected name on line 155.
dock_enable: bool = false,
Re. ImTextureID and ImTextureRef: ocornut/imgui@0e6e876 |
I have another small issue to bring up - not fatal like an ABI mismatch or anything, but some of the new imgui backend code is triggering the memory leak / static memory warning in gui.zig when an application exits. It's a case of "guess when this static memory gets a destructor call" that everyone loves from C++. The static variable to blame is here in imgui_impl_glfw.cpp The memory check, for reference, is here And this is the change I've tentatively made to deal with it for my own code, but there may be a nicer way to do it that doesn't require patching the imgui code like that, not sure. This could probably be filed as a "don't care, won't fix," but I hate seeing warnings on exit even if they don't matter functionally, so I just wanted to note it here. |
- Add TextureRef and update related APIs - Set IMGUI_DISABLE_OBSOLETE_FUNCTIONS and remove usage of deprecated functions - Fixup deprecated API usages (callconv, alignment)
- Update node_editor
…ions aren't name-mangled - Support loading the glfw backend via shared library - Clear the glfw backend's `g_ContextMap` allocation to avoid leak warnings - Fixup ImTextureID -> ImTextureRef - Fixup paddig field naming
Fixed these up, good catch.
I resolved this with a call to I also switched my project from using I'll continue with that solution (update other backends to use |
Oh nice, that's a much better solution to the memory warning. Thanks for fixing that. |
Sorry but I had to revert this because it broke the opengl backend and the newer wgpu backend seems to incompatible with the version of dawn we're currently stuck with in zgpu. |
It took me a while to figure out why my calls to the backend functions were not being exported correctly until tracing it back to this reverted PR. This is the error I ran into:
Adding this back in fixed my issue: if (options.shared) {
if (target.result.os.tag == .windows) {
imgui.root_module.addCMacro("IMGUI_API", "__declspec(dllexport)");
imgui.root_module.addCMacro("IMPLOT_API", "__declspec(dllexport)");
imgui.root_module.addCMacro("ZGUI_API", "__declspec(dllexport)");
}
if (target.result.os.tag == .macos) {
imgui.linker_allow_shlib_undefined = true;
}
}
+ else {
+ imgui.root_module.addCMacro("IMGUI_IMPL_API", "extern \"C\"");
+ } |
What are the incompatibilities?
Ah, I must have missed this when I copied the new backends in. I should be able to port those changes when I re-open this. |
Remaining TODOs: