-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
wxWidgets-3.0: set c++ standards #27309
Conversation
Notifying maintainers: |
I have such trouble reading the CI system for what went wrong. It looks like something went wrong with the macOS-15 builder building one of the ports. TBH, the wx30 ports are not really relevant to macOS-15 anyway, but I downloaded the log archive from the CI to see if I could at least see what the error was, but I can't sort it out. |
Oh, I think I see what it was. glib2 failed to build… perhaps due to the py313-packaging issue. |
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.
This won’t work correctly. It may build, but everything which uses wx* will likely be broken.
P. S. To be clear, I will not test every wx* port to confirm that everything is broken. The statement is based on known similar cases when C++ standard was changed either for wx* or for a dependent, without rebuilding the other.
I do think you’re right about revbumping these wx30 ports, however, to be certain they all build cleanly with the correctly-set c++ standards. |
@kencu Also if you force C++11 here, you do not need -cxx11 subports at all, since they existed exactly to provide C++11 (in practice 2011+) compatibility. |
I’m not following you. For example, there are two versions of wxgtk-30. The wxgtk30-cxx11 port will be set to std=c++11. The wxgtk-30 port will be set to std=c++03. Seems just right to me… |
It will be nice to fix this in the same go, to avoid another revbump: https://trac.macports.org/ticket/71713 |
I do wonder if the non-cxx11 versions of wx30 will be needed in future, though…if nobody uses them after time, perhaps they will turn out to be superfluous… |
Ok, fair enough, I forgot about that. Well, I do not know if there is any sense in keeping the two, since we either have a compiler which supports C++11 (all x86 besides 10.4–10.5) or a compiler which does not support either of these (or does gcc-4.2 support C++03?). |
did you make any progress on backporting the relaxed libgcc ABI checks from wx32 into wx30? I know this ABI checking causes runtime headaches sometimes. |
What wx cares about is exact (as it seems at least) match of C++ ABI between the wx library in use and a given dependent of it. If no dependents need exactly ++03, it is arguably pointless to provide wx with that standard, that too by default. |
I showed you in another ticket how that libgcc ABI check had been considerably relaxed in later wx versions, to reduce unnecessary runtime errors. |
I think what we rather need is fix wxGTK-32 for older systems (i.e. whichever cannot use wxWidgets32, not just ppc). I have a version of it that builds and I could build a couple of dependents against it. But other dependents did not, so there is something more to be fixed. |
I did not try modifying that, since not too many wx ports are stuck with old C++ indefinitely (not ones I care about at least), and rebuilding those (plus wx itself) once a year when compiler version changes is tolerable (and good to do anyway, periodically). |
The problem with fixing wx32 +cocoa to build on systems below the standard they have set of 10.10+ is that they can build but don't work properly. I have had a personal build of wx32 +x11 I've been using for several years on 10.7 to test things out, but ... not for pushing at present. Anyway, all of this is noise to this PR, so I'll try to stay on topic here rather than have another PR with 278 comments in it. |
the non-cxx11 ports are set to c++03 the cxx11 ports are set to c++11 fixes build with compilers that default to a too-new standard, such as clang-16
maintainer timeout. |
So you decided just to break all non-C++11 wx ports ) |
By letting the non-c++11 wx ports secretly build as c++11? Your arrogance is getting legendary. Anyway, I reverted it because the last few commits have really messed this port up and it needs a total re-haul. You were involved in some of those last few commits, so I’ll leave it to you. |
The builds of the wx30 ports are failing on 10.7, at least.
This appears to be because 10.7 is building them with clang-16, and clang-16 defaults to a too-new c++ standard, which causes all the builds to error out.
We have two versions of most of the wx30 ports, one a "standard" build, which up to now was defaulting to something pre-c++-11 in almost all cases, and one a "*-cxx11" build, where a c++11 compiler was used.
If we set the c++ standards as such in each of the subports, this fixes the builds of the wx30 ports on 10.7, at least.
I have not tested wxPython as yet, nor any other systems beyond 10.7 as yet.