7

There are two projects, one is a library targeting .NET Standard 2.0, while the other is a console app targeting .NET Core 2.2.

Now this piece of code is working on .NET Standard 2.0 library, but not on .NET Core 2.2.

for (int i = 0; i < 1; i++) {
    var y = new int[1].First(i => i == 0); // Conflict i name error here in .NET Core 2.2.
    Console.WriteLine("Hello " + y);
}

I understand from this question that simple names should not have different meanings, and thus, even .NET Standard 2.0 library should give an error, but it is not. Why is this inconsistency?

I have tried dotnet fiddle, and it seems to work on .NET Core 3.1 and Roslyn 3.4, but not .NET Framework 4.7.2, which is even more confusing. What is going on here?

Ghasan غسان
  • 5,577
  • 4
  • 33
  • 44
  • 1
    Could you double check that it's working with netstandard2.0? I can't reproduce that - I can get it working with netstandard2.1, but that's not the same. – Jon Skeet Mar 06 '20 at 07:41
  • 1
    Yup, you are right. The reason it was working on the .NET Standard 2.0 project was because we had `latest`. – Ghasan غسان Mar 06 '20 at 07:54

1 Answers1

6

What is going on here?

Basically, the ability to use a lambda expression parameter with the same name as an existing local variable is a new feature introduced in the C# 8 compiler - but there's been very little fuss about it. I happened to hear about it (from Mads himself) in a meeting this week, but otherwise wouldn't have known about it.

The target framework matters because it changes the default language version that the compiler applies. You can specify it explicitly using the <LangVersion> element though. For example, with this project file:

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
    <OutputType>Exe</OutputType>
    <TargetFramework>net471</TargetFramework>
    <LangVersion>8.0</LangVersion>
  </PropertyGroup>
</Project>

... the code builds fine. Ditto when targeting netstandard2.0 or netcoreapp2.2.

Jon Skeet
  • 1,421,763
  • 867
  • 9,128
  • 9,194