-
Notifications
You must be signed in to change notification settings - Fork 4.1k
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
Add public methods to supress visibility checks for compilation #11149
Comments
👍 cc @ReubenBond. If would really help also if we could suppress visibility check on a per-type in addition to a per-assembly basis. |
Why do you need per type? |
Today we inject generated code back into the original solution, so that we only produce a single assembly and can leverage IntelliSense. If we could mark only codegen'ed types for suppression, other application types in the same assembly wouldn't be adversely affected. |
This feature would be immensely useful for serializers and other nuts & bolts libraries which involve code generation, for example, ORMs and RPC frameworks. |
Is there any progress made on that issue @jkotas ? Other folks on Roslyn channel mentioned that there a new tooling and new scenarios being created for codegeneration that could make our lifes easier in Orleans... Is there anything we can have a look? |
@galvesribeiro Check #5561 IMHO, I am not sure whether it would make your life in Orleans easier because of it works only for static compilation from sources case. It does not work for the dynamic case where you create Orleans proxies on the fly. You would need to maintain two disjoint solutions for these. |
I'm actually more comfortable the way you do it (poking into Roslyn internals using reflection). This is a request to make the compiler stop obeying parts of the language specification, and... well... it is the job of the compiler to obey the language specification. |
@gafter I dont agree with you. If that is the case, remove |
@gafter the compiler already allows removing visibility checks at at API level for the expression evaluator. What is being asked here is not for the compiler command line to allow it but for the API experience to do so. |
This would be really good to have for the aforementioned reasons. Any chance we can plumb this through to a public API? |
If Source Generators could emit code which had greater access to type internals, that would be very useful for serialization libraries. For example, if we could emit code to get/set private/readonly/initonly fields and properties without reflection or runtime helpers (such as proposed in dotnet/runtime#45152), we could write high-performance, straight-forward code. Currently, serialization libraries choose between several options:
Option 1 coerces the user into avoiding language safety features (implementation hiding, immutable data), and may lead to buggier user code. 2 & 3 work today but are slow, potentially fragile, and are not AOT-friendly. 4 Is onerous for developers and prevents interop scenarios such as generating C# code external to foreign C# or F# assemblies. It is also overly restrictive in what code can be generated. For example, a generated deserialization ctor cannot be a generic method, and therefore cannot accept generic parameters (eg, I would like a mechanism to bend the accessibility rules for generated C# code in an opt-in fashion. For example, this could be enabled by adding a special attribute to generated types/methods which would otherwise be violating these checks. Consider |
I fully agree with @ReubenBond, Source Generators are truly awesome and we can finally move away from Reflection, Linq Expression and IL Generators to a more maintainable and less error prone solution. As it currently stands, we have to make 'ugly' workarounds to make things work like previously. This especially applies to ORMs and all other types of mappers. Of course one might say that such attributes or abilities might be a bad idea and brake rules and that it should better be hidden through the reflection APIs. Anyhow, we already have the |
Could we consider this in the .NET 7 timeframe? Please see my comment above for more info: #11149 (comment) As Source Generators are becoming more popular (in part due to a push for more AOT compilation), I believe this feature becomes more desirable. |
Closing as this is not planned for any release in the future. |
The ability to suppress visibility checks was proven to be useful for auto-generated code like interop or serialization. It requires manipulating internal Roslyn details via private reflection today. There should be a public API to achieve it instead.
See dotnet/orleans#1729 for example
The text was updated successfully, but these errors were encountered: