-
Notifications
You must be signed in to change notification settings - Fork 63
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
Notification of breaking changes #64
Comments
However, this feature would lose a lot of its utility once Zig reaches 1.0 (presumably). But until then, I think it might be helpful. |
This is a cool/interesting idea. I have some thoughts as to how something like this could be done. Did you have any ideas in mind as to how you would classify changes as breaking? |
I was simply thinking of looking for commits with |
@marler8997 could you please share your thoughts on the subject? In light of this, this feature could become very beneficial for some time. |
Alot of thoughts come to mind, mostly about how to classify/detect/enforce breaking changes. It seems to me that a perfect solution here couldn't exist since there's no way to know for certain whether a different compiler would break a project before actually trying to build/test it. So the best we can do is some sort of heuristic. We could manually maintain a list of versions along with breaking changes, maybe even categorize types of breaking changes. We could also establish a convention in the zig repo for this to include this information within commit messages. However, if we forgot to include the details of a breaking change in a commit then there's no way to go back and fix that. For this reason it seems like it would be best to maintain this information outside of the commits themselves so we could go back and add this information at any time. This would also keep the door open to improve how we categorize/classify breaking changes if desired. I also have questions about the best interface to include this information in zigup, if it would make sense at all. Maybe this sort of thing should go into Anyway those are just some of my thoughts. I see potential here but I'm not certain what direction we want to go and the considerations go beyond what I control with zigup which makes it more difficult to pick a direction. P.S. zigup doesn't have an P.P.S sorry more thoughts I forgot to include. This is related to an experimental project I've been playing around with (https://github.com/marler8997/zig-pkg-db). The idea is to maintain a database of zig packages and the latest versions that build and pass the tests. The zig toolchain would also be considered a dependency like any other and would therefore be able to detect when any zig compiler changes breaks any zig package in the database. |
I also think it would not be possible to tell whether a project will be broken by a new version (without recompiling the project, but zigup may be run at any place without the context of a specific project), but it still is a good idea to notify people that something breaking has changed, so that they can expect it. Maintaining a list of breaking changes is certainly doable and grants more flexibility, but I think that the baseline should still be a convention in the Zig repo. Not everyone might use zigup and have their own way of detecting breaking changes from commit messages (whether that is done manually or automatically). Its just good form for a project of Zig's size/seriousness and from what I see they are already trying to do that. Ad P.S.: yes, that's exactly how I use plugins in packer. Usually they have rolling releases and you just run Ad P.P.S.: sounds interesting 👍 what is the goal of it? Notify package maintainers as soon as one of their packages breaks on a new version? An interface for people to check whether their build.zig will run on a given version? I cannot see the repo, as it's private. |
It seems some people are using zigup to get the nightly version of zig. And some people also seem to occasionally miss new breaking changes in master. Wouldn't it be great if zigup would notify you about any breaking changes that happened between the last time you fetched? I imagine it a bit like how changes in plugins are displayed when running
:PackerUpdate
in neovim:Here you can see no breaking changes because there weren't any, but they would be marked red. The other commits might be interesting for some, but not essential. The feature would only be relevant for
master
.The text was updated successfully, but these errors were encountered: