Allow generic extension methods with 'this in T' and T struct to compile #8815
Replies: 7 comments
-
see also: dotnet/roslyn#24601 |
Beta Was this translation helpful? Give feedback.
-
Duplicate of #3331 @tannergooding in that thread:
|
Beta Was this translation helpful? Give feedback.
-
@jnm2 |
Beta Was this translation helpful? Give feedback.
-
To be clear: In this case I have no direct problem regarding calling a method on a hidden copy of the struct. What I want is that
should compile, like
already compiles today. The generated IL code and native JIT code should be the same in both cases. Besides the difference in
of course. This allows a much more smarter usage (true extension method) and is symetric to the simple static method (without this). A warning when operating on a hidden copy of the parameter struct will be wellcomed equally in both cases. |
Beta Was this translation helpful? Give feedback.
-
Any news on this topic? |
Beta Was this translation helpful? Give feedback.
-
News is posted on the form of comments. |
Beta Was this translation helpful? Give feedback.
-
See also: #7696 |
Beta Was this translation helpful? Give feedback.
Uh oh!
There was an error while loading. Please reload this page.
Uh oh!
There was an error while loading. Please reload this page.
-
Overview
I want generic extension methods with
this in T
parameter to compile.The spec explicitly disallows this usage:
"On the other hand
in
extension methods exist specifically to reduce implicit copying. However any use of anin T
parameter will have to be done through an interface member. Since all interface members are considered mutating, any such use would require a copy. - Instead of reducing copying, the effect would be the opposite. Therefore inthis T
is not allowed whenT
is a generic type parameter regardless of constraints."But not every use of an
in T
parameter will have to be done through an interface member.in T
parameter.Unsafe.SizeOf<T>()
orUnsafe.AsRef<T>()
and converted to a managed pointer, which does not require any struct copy.Motivation
I have implemented an arbitrary precision floating point library designed for floats from 16 bytes up to a few hundred kbytes. The various floats are defined by a struct of desired size which must only implement the empty interface
IFpFloatReadonlyStruct
. No struct methods are implemented directly (beside aToString()
override).All float structs share the same generic library code.
The core functioniality is implemented in only 3 extension methods based on
These three base methods are using managed pointer API similar to the
System.Runtime.CompilerServcies.Unsafe
class.These base methods are consumed by higher level arithmetic functions like Add(), Multiply(), Log() and so on.
The JIT compiler really does an incredible good job with function inlining and generic code expansion.
Unintended struct copy does not occure during this usage. But any compiler warning - when doing so - would be strongly wellcomed!
Problem
At the moment every
in TFloat
argument passing is done by usingref
.But using
ref
instead ofin
has following drawbacks:Current Behavior
Compiling
raises following error at the function definition
Desired Behavior
The above code compiles.
Breaking Change
No, because currently this is an error.
But a compiler warning - when unintential struct copy occurs - is strongly recommended.
Remarks
I can supply more detailed examples and use cases, when desired.
Please consider a change.
BR Gerhard
Beta Was this translation helpful? Give feedback.
All reactions