Skip to content
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

Merged
merged 1 commit into from
Jan 9, 2025
Merged

wxWidgets-3.0: set c++ standards #27309

merged 1 commit into from
Jan 9, 2025

Conversation

kencu
Copy link
Contributor

@kencu kencu commented Jan 5, 2025

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.

@macportsbot
Copy link

Notifying maintainers:
@mojca for port wxWidgets-3.0.

@macportsbot macportsbot added maintainer: open Affects an openmaintainer port by: member Created by a member with commit rights labels Jan 5, 2025
@kencu
Copy link
Contributor Author

kencu commented Jan 5, 2025

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.

@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

Oh, I think I see what it was. glib2 failed to build… perhaps due to the py313-packaging issue.

Copy link
Contributor

@barracuda156 barracuda156 left a 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.

graphics/wxWidgets-3.0/Portfile Show resolved Hide resolved
@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

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.

@barracuda156
Copy link
Contributor

@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.

@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

@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…

@barracuda156
Copy link
Contributor

It will be nice to fix this in the same go, to avoid another revbump: https://trac.macports.org/ticket/71713
(That is trivial issue, either disable those deps or declare them, to avoid opportunistic linking.)

@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

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…

@barracuda156
Copy link
Contributor

@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…

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?).

@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

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.

@barracuda156
Copy link
Contributor

barracuda156 commented Jan 6, 2025

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…

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.

@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

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…

What wx cares about is exact (as it seems at least) match of C++ ABI between the wx library in use and a given dependency of it. If no dependencies 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.

@barracuda156
Copy link
Contributor

barracuda156 commented Jan 6, 2025

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.

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.

@barracuda156
Copy link
Contributor

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 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).

@kencu
Copy link
Contributor Author

kencu commented Jan 6, 2025

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
@kencu
Copy link
Contributor Author

kencu commented Jan 9, 2025

maintainer timeout.

@kencu kencu merged commit 5afd513 into macports:master Jan 9, 2025
2 of 3 checks passed
@kencu kencu deleted the wxfix branch January 9, 2025 07:19
@barracuda156
Copy link
Contributor

So you decided just to break all non-C++11 wx ports )

@kencu
Copy link
Contributor Author

kencu commented Jan 9, 2025

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.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
by: member Created by a member with commit rights maintainer: open Affects an openmaintainer port
Development

Successfully merging this pull request may close these issues.

4 participants