-
Notifications
You must be signed in to change notification settings - Fork 46
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
[linter]discourage to use anonymous model and always give a model name #1727
Comments
I think we should re-consider whether we should suppress the occurrence of anonymous models.
|
@timotheeguerin regarding your comments, here are some of my thinkings. At the TypeSpec standpoint do we agree this is a good practice or anti-patterns? how should we guide customers to use anonymous model correctly? Can we set a clear bar for which cases should be allowed and which should be discouraged? Implementing something in TCGC is just kinda patch for TypeSpec or long-term solution? If we are talking about this in Azure scope, we could set some linters in tcgc because in it we have a chance to calculate models which are supposed to be public then any anonymous models could be reported. The drawback is it is too late for customers the errors happen during runtime and any language emitters are called. On the other hand we could do this linting in azure-core lib, which could report it in early stage. Imagine customers just writes their specs and they could be guided to not use this. This maybe better integrate with our IDE. |
as said in the other issue we cannot do this in azure core it was tried by David when he was working on this [See comment] If we have better way to deal with traits and building blocks in the future we could consider a more generic approach but here its just not possible. |
I think its reasonable for a language emitter (maybe tcgc) to throw a warning when an anonymous model is found. We plan to do this in csharp for both branded and unbranded and the user can choose to ignore them if they want. I think I agree that a tsp level warning doesn't make sense since I can imagine some emitters don't care about anonymous models such as the openapi emitter which has no issue dealing with them. |
Talked with @m-nash , I agreed with Michael's point:
It totally makes sense, so we'd like to skip the ugly name check during apiview review. This will save both the service team and our team the additional effort required to resolve the naming of anonymous models. |
Also just for clarity this is a great candidate for using the tcgc linter framework setup here #1208 |
Clear and concise description of the problem
Close typespec one filed an issue in typespec-azure repo.
Offline discussed with @ArcturusZhang and we think anomymous model may not be a good practice and we should encourage to give a name for models especially for exposed public APIs.
Most of downstreaming language emitters may not have ability to handle inline expressions like typespec so they need to GUESS a name for anomymous models. This could introduce uncertainty if downstreaming name rule is different and for example the name rule introduced breakings between m4 and tcgc and one issue happened in common types is tracked here.
Even we could find a name rule and these names could be fragile and it would be changed with its context or code order if conflicting happened.
For example in TCGC we try to guess this name according to context, including
parent model name + property name + model type
. So the name could be changed once any of these factors changed. Also we may name some models during conflicting and any code order changes would impact the generated code.Can we add a linter to discourage the anonymous model in typespec? Especially in azure could we avoid using anonymous model then?
Checklist
The text was updated successfully, but these errors were encountered: