/core-koans

A set of Koans to teach the C# language on .NET Core.

Primary LanguageC#MIT LicenseMIT

.Net Core Koans

Build status All Contributors

The .NET Core Koans walk you along the path to enlightenment in order to learn C# on .NET Core. The goal is to learn C# syntax, structure and some common functions and libraries available on the .NET Core platform. .NET Core is a cross platform environment that runs happily on Windows, OS X and Linux. It is super simple to get started learning.

The Structure

The koans are broken out into areas by file, arrays are covered in AboutArrays.cs, lambdas are introduced in AboutLambdas.cs, etc. They are presented in order in the PathToEnlightenment.cs file.

Each koan builds up your knowledge of C# and builds upon itself. It will stop at the first place you need to correct.

Some koans simply need to have the correct answer substituted for an incorrect one. Some, however, require you to supply your own answer. If you see the object FILL_ME_IN listed, it is a hint to you to supply your own code in order to make it work correctly.

Getting Started

.NET Core Koans

Running Locally

  1. Install .NET Core SDK 3.1.
  2. Install Visual Studio Code, the Insiders Edition is highly recommended.
  3. Clone the repository: git clone https://github.com/NotMyself/DotNetCoreKoans.git.
  4. Change directory into the cloned repository cd DotNetCoreKoans.
  5. Restore packages: dotnet restore.
  6. Open the project in VSCode code-insiders . or code . depending on what version you chose to install.
  7. Run the koans in watch mode: dotnet watch --quiet run.
    • Note: The --quiet flag is used here to suppress mesages from the watch framework.
  8. Follow along with the instructions printed to your console. Each time you save a *.cs file, the project will be built and run again for you automatically.

Contributing

Want to contribute? Check out our Code of Conduct and Contributing docs. This project follows the all-contributors specification. Contributions of any kind welcome!

There are many topics yet to be covered by this set of koans. I have added a handful of needed topics as issues and tagged them as Up for Grabs. There are even some specifically tagged as Beginner Friendly.

If you have never contributed to an open source project, let this be your first. Take a stab at updating the AboutStrings Koan to include information about interpolation then submit it as a pull request. I promise to work with you to get your contribution into the repository and be friendly and encouraging about it. It is what Jim would have done.

If you think a topic is missing, propose it's inclusion by submitting an issue yourself. Or better yet submit the issue and an accompanying pull request with how you think the topic should be introduced. Think about beginners in your effort; be clear and informative, be concise and most of all be playful with your examples.

About Koans

This project is based on the work of Cory Foy and his original multi-language project DotNetKoans. If you are interested in learning VB.NET or the Full .NET Framework (windows only), please look at his fine work.

Programming Koans came about because of the most enlightened Ruby Koans by Jim Weirich. Jim was a great teacher & programmer whom I had the pleasure of meeting, learning from and playing games with. Rest in peace, sir. We will continue your effort to bring a love of the craft to anyone willing to learn.

For a fuller explanation of what is going here, see the blog post Learn C# on Windows, OSX or Linux with the .NET Core Koans

Contributors ✨

Thanks goes to these wonderful people (emoji key):


John Hoerr

💻

Victor Grigoriu

💻

James Naylor

💻

Samuel Cherinet

💻

Chris

💻

Delaine Wendling

💻

Allen

💻

Jonathan Couldridge

💻

Lukas Sinkus

💻

Richard D

💻

Stratos Kourtzanidis

💻

Agustin

💻

Matthew Parsons

💻

Jamie MacLeod

💻

Stuart Harrison

💻

Chris Jones

📖

Atanas Pashkov

💻

Tomasz Cielecki

💻

SophieLemos

💻 🐛 🎨 📖 🤔

Dan Schnau

🐛 📖

Joshua Belden

💻

Shawn Vause

💻

Jeannie Nguyen

🎨

Adam

💻

Ferrier Benjamin

💬 💻

Ibrahim Islam

💻

Nikiforov Alexey

💻

Ozge Cimendere

💻

Jakub Rusek

💻

RAFAELDEV2016

🎨

Cedric Rup

💻

This project follows the all-contributors specification. Contributions of any kind welcome!