Coroutine 1.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Coroutine --version 1.0.0                
NuGet\Install-Package Coroutine -Version 1.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Coroutine" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Coroutine --version 1.0.0                
#r "nuget: Coroutine, 1.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Coroutine as a Cake Addin
#addin nuget:?package=Coroutine&version=1.0.0

// Install Coroutine as a Cake Tool
#tool nuget:?package=Coroutine&version=1.0.0                

Coroutine

A simple implementation of Unity's Coroutines to be used for any C# project

Features

Coroutine adds the ability to run coroutines. Coroutines are methods that run in parallel to the rest of the application through the use of an Enumerator. This allows for the coroutine to pause execution using the yield return statement.

There are two predefined ways to pause a coroutine:

  • Waiting for a certain amount of seconds to have passed
  • Waiting for a certain custom event to occur

Additionally, Coroutine provides the following features:

  • Creation of custom events to wait for
  • Creation of custom wait conditions
  • No multi-threading, which allows for any kind of process to be executed in a coroutine, including rendering

How to Use

Setting up the CoroutineHandler

The CoroutineHandler is the place where coroutines get executed. For this to occur, the Tick method needs to be called continuously. The Tick method takes a single parameter which represents the amount of seconds since the last time it was called. It can either be called in your application's existing update loop or as follows.

var lastTime = DateTime.Now;
while (true) {
    var currTime = DateTime.Now;
    CoroutineHandler.Tick((currTime - lastTime).TotalSeconds);
    lastTime = currTime;
    Thread.Sleep(1);
}

Creating a Coroutine

To create a coroutine, simply create a method with the return type IEnumerator<Wait>. Then, you can use yield return to cause the coroutine to wait at any point:

private static IEnumerator<Wait> WaitSeconds() {
    Console.WriteLine("First thing " + DateTime.Now);
    yield return new WaitSeconds(1);
    Console.WriteLine("After 1 second " + DateTime.Now);
    yield return new WaitSeconds(5);
    Console.WriteLine("After 5 seconds " + DateTime.Now);
    yield return new WaitSeconds(10);
    Console.WriteLine("After 10 seconds " + DateTime.Now);
}

Starting a Coroutine

To start a coroutine, simply call Start:

CoroutineHandler.Start(WaitSeconds());

Using Events

To use an event, an Event instance first needs to be created. When not overriding any equality operators, only a single instance of each event should be used.

private static readonly Event TestEvent = new Event();

Waiting for an event in a coroutine works as follows:

private static IEnumerator<Wait> WaitForTestEvent() {
    yield return new WaitEvent(TestEvent);
    Console.WriteLine("Test event received");
}

To actually cause the event to be raised, causing all currently waiting coroutines to be continued, simply call RaiseEvent:

CoroutineHandler.RaiseEvent(TestEvent);

Additional Examples

For additional examples, take a look at the Example class.

Product Compatible and additional computed target framework versions.
.NET Framework net472 is compatible.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

NuGet packages (4)

Showing the top 4 NuGet packages that depend on Coroutine:

Package Downloads
SadConsole

A library that emulates old-school console and command prompt style graphics.

MLEM.Startup

MLEM Library for Extending MonoGame combined with some other useful libraries into a quick Game startup class

MLEM.Startup.FNA

MLEM Library for Extending FNA combined with some other useful libraries into a quick Game startup class

MLEM.Startup.KNI

MLEM Library for Extending KNI combined with some other useful libraries into a quick Game startup class

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on Coroutine:

Repository Stars
Thraka/SadConsole
A .NET ascii/ansi console engine written in C# for MonoGame and XNA. Create your own text roguelike (or other) games!
zaafar/ClickableTransparentOverlay
A library for creating transparent overlay using windows API & ImGui.NET
Version Downloads Last updated
2.1.5 11,656 2/23/2023
2.1.4 1,482 9/14/2022
2.1.3 1,760 11/29/2021
2.1.2 1,330 11/7/2021
2.1.1 1,580 5/29/2021
2.1.0 512 3/21/2021
2.0.2 401 3/17/2021
2.0.1 693 12/20/2020
2.0.0 2,554 6/13/2020
1.0.4 1,181 5/19/2020
1.0.3 965 2/28/2020
1.0.2 1,731 11/20/2019
1.0.1 2,320 8/5/2019
1.0.0 622 6/22/2019

Initial release