Closed loop8ack closed 2 months ago
Hm, you may be able to achieve this with NULLABLE_ATTRIBUTES_DISABLE
, if you conditionally set that for the modern BCL.
However, I don't recall it being necessary for my uses in the past. The nuspec
already doesn't copy the attribute files for .NET 5.
Perhaps you have to dual-target instead of using .NET Standard: instead of <TargetFramework>netstandard2.0</TargetFramework>
, use <TargetFrameworks>net472;net8.0</TargetFrameworks>
, or similar.
Using NULLABLE_ATTRIBUTES_DISABLE
wouldn't really solve my issue, as the goal is to actually use these attributes in my .NET Standard 2.0 project. I understand that the nuspec doesn't copy the attribute files for .NET 5+, but the problem occurs when I reference the .NET Standard 2.0 project from a .NET 8 project, which leads to conflicts.
Your suggestion about multi-targeting is indeed a good one and should work as a workaround.
However, I still believe it would be beneficial to make the public vs. internal visibility configurable. This would allow users to resolve such issues with a single setting in the future, providing greater flexibility for various project configurations. I understand that making the attributes internal by default is likely not an option due to potential breaking changes, which is why a configurable option seems ideal.
Hey there!
Maybe I am misunderstanding something, but from my point of view, the attributes are already tagged as internal class
es to avoid the problem that you describe. In what situation / scenario do they appear as public types in your projects?
Good point, I don't have an answer. In my local NuGet cache (version 1.3.1) the classes are all public, I don't know why.
Clearing the cache and restoring packages has helped.
Strange world - sorry for the trouble and thanks.
No worries - glad that things could be resolved that easily! :heart:
Issue Description
The Nullable NuGet package provides attributes necessary for Nullable Reference Types when working with .NET Standard 2.0. However, these attributes are currently declared as public, which leads to conflicts when the .NET Standard 2.0 project is used in a .NET 8 project that already includes these attributes.
Problem Details
Proposed Solution
To resolve this issue, I suggest the following changes:
This change would maintain compatibility for projects that need these attributes while preventing conflicts in mixed-version scenarios.