-
Notifications
You must be signed in to change notification settings - Fork 460
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
Support deprecated annotation on messages, fields, enums, enum values. #151
Comments
Ok, this one is turning into a complex problem. The annotations can go on the file, messages, enum, enum values, and fields. Spitting out the All the other code we generate (for For the fields, I can cheat and always ensure a deprecated field gets a _name private field that all the code uses and only the public _var name` gets tagged as deprecated. But when it comes to tagging enums and structs for messages, I don't see any way to cheat, they can be deprecated but still used in a deprecated field of another message also; and so that seems like it will always generate warnings when the code is compiled. It doesn't seem right to say the generated code won't compile warning free, so I'm not sure how we support deprecated… |
Un-assigning this at the moment. I think we need to support this, but if also seems like Swift doesn't have the support to do this correctly for Message/Enum/Enum Values, and if we generate code that doesn't compile cleanly, it will probably result in bugs against this project. |
I've filed SR-3357 to start a discussion about easing up on deprecation warnings originating from references within the same compilation unit or module, to see if the language itself can help here. |
Moving this to an enhancement, given the current support in Swift, it does't seem like we can do this and have the generate code compile (cleanly), so until that support is improved, we likely have to put this off. |
Any update on this or the limitations remain? |
SR-3357 doesn't have any updates, so without it, we wouldn't be able to generate something that would actually compile cleanly in the first place. |
Any updates? Since #861 is opening the door for a possible major version bump, we should consider whether it's time to do this. |
I haven't seen any one pick up the issue for Swift. Maybe with a stable ABI more folks will start to see how the current support for deprecated annotations in Swift doesn't work for library authors. |
If we can't do deprecation, at least generate a documentation comment. |
Sure. Most protos I've seen add something in the comments, but it can't hurt to also stick something else in after any comments pulled over from the .proto file. |
For a softer deprecation, we could add annotation like @available(swift, deprecated: 100.0) which doesn't spit out compiler warning but still let developer know it's deprecated. |
Does Xcode give any indication based on that? Or did you mean just because it it is something in the generated source? The comment idea is a good one since it should show up in IDEs with any copied over documentation comments. |
Doing a quick test, it seems like nothing shows up within Xcode including quick help, so developers would have to look at the generated sources to see it. For that reason, seems like something added to the doc string might be better. |
Don't pass stackTrace in EventSink.error
Seems like it's been a minute since this discussion tailed off, so I'm inclined to ask - can anyone comment on whether or not the limitation still exists? Additionally, assuming the state of things is still the same, would it be possible/would the limitation still be the same if we were to add "partial support" for a deprecation compiler warning - such that entire messages could be marked as deprecated with an |
The problems are when a field is of a type (message or enum) that is marked as deprecated. There was a recent evolution proposal that starts to make some headway on controlling warnings, but I don't think it will be enough yet to do a better mapping here. |
Sounds good - thank you. I just wanted to check in to make sure that this was still something that was being pursued and hadn't just become completely stale. Hopefully we'll be able to circumvent this issue eventually. Thanks @thomasvl! |
We're also open to ideas. Since the generated code is compiled in other packages, people tend to be sensitive to warnings in those contexts, so that's what makes it hard. We also don't want a lot of generation options, as that makes maintenance more difficult. |
descriptor.proto defines a deprecated bool on message, enum, enum value, field; the generated things should get the Swift annotations also.
note: Extensions should honor it since they are a field.
The text was updated successfully, but these errors were encountered: