UPDATE 2: you should also read this after you read the below blogpost. [I made a big mess of this yield blogpost and I apologize to my readers for that.][1]

Yes it is finally here. The yield keyword has come to VB.Net. It has been in C# for a while. This is all in attempt, no doubt, to make C# and VB.Net a bit more compatible. T annoy us less when you have to use the other language. To make our lives easier and more comfortable. Alas they failed again.

Via twitter I found [this little paste2][2] with an interesting approach to solve the Fibonacci thing using the Yield keyword.

This was the tweet.

David Siegel ‏@dvdsgl

A friend was asked to produce the fibonacci sequence in C# during an interview. Here’s a cute, very slow impl: http://paste2.org/p/2236575

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication5
{
    class Program
    {
        static void Main(string[] args)
        {
            foreach(int fib in Fibs)
            {
                Console.WriteLine(fib);
            }
            Console.ReadLine();
        }

        public static IEnumerable<int> Fibs
        {
            get
            {
                yield return 1;
                yield return 1;

                foreach (var n in Fibs.Zip(Fibs.Skip(1), (x, y) => x + y))
                    yield return n;
            }
        }
    }
}

I thought it was cute and was looking to replicate in VB.Net, as I want to learn new things and be less stupid.

And this would be the translation of the above.

Module Module1
    
    Sub Main()
        For Each fib In Fibs
            Console.WriteLine(fib)
        Next
        Console.ReadLine()
    End Sub

    Private ReadOnly Iterator Property Fibs() As IEnumerable(Of Integer)
        Get
            Yield 1
            Yield 1

            For Each n In Fibs.Zip(Fibs.Skip(1), Function(x, y) x + y)
                Yield n
            Next
        End Get
    End Property
    
End Module

Ain’t that cool? No. Because you get two errors.

The implicit return variable of an Iterator or Async method cannot be accessed.

It is referring to the Fibs in Fibs.Zip and Fibs.Skip.

Oh darnit.

But not to worry I have a less pretty solution.

Module Module1
    
    Sub Main()
        For Each fib In Fibs
            Console.WriteLine(fib)
        Next
        Console.ReadLine()
    End Sub

    Private Iterator Function Fibs() As IEnumerable(Of Integer)
        Dim previous As Integer
        Dim current As Integer
        Yield 1
        Yield 1
        previous = 1
        current = 1
        While current < Integer.MaxValue - previous
            current += previous
            previous = current
            Yield current
        End While
    End Function

End Module

My solution is however much faster. So there, take that.

Update: In the comments below Damien points out that VB is merely confused and needs a little push in the right direction. As seen below.

Module Module1

    Sub Main()
        For Each fib In Fibs
            Console.WriteLine(fib)
        Next
        Console.ReadLine()
    End Sub

    Private ReadOnly Iterator Property Fibs() As IEnumerable(Of Integer)
        Get
            Yield 1
            Yield 1

            For Each n In Module1.Fibs.Zip(Module1.Fibs.Skip(1), Function(x, y) x + y)
                Yield n
            Next
        End Get
    End Property

End Module```
Because in VB you can still do this.

```vbnet
Module Module1

    Sub Main()
        For Each fib In Fibs
            Console.WriteLine(fib)
        Next
        Console.ReadLine()
    End Sub

    Private ReadOnly Property Fibs() As IEnumerable(Of Integer)
        Get
            Fibs = {1, 1, 2}
        End Get
    End Property

End Module```
So I’m stupid, sue me.

Disclaimer: his post is full of sarcasm and other kinds of humor you might not understand.

 [1]: /index.php/DesktopDev/MSTech/i-made-a-big-mess
 [2]: http://paste2.org/p/2236575