The .NET Koans walk you along the path to enlightenment in order to learn C# on .NET. The goal is to learn C# syntax, structure and some common functions and libraries available on the .NET platform. .NET is a cross platform environment that runs happily on Windows, OS X and Linux. It is super simple to get started learning.
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.
- Install .NET SDK 6.0.
- Install Visual Studio Code, the Insiders Edition is highly recommended.
- Clone the repository:
git clone https://github.com/NotMyself/DotNetKoans.git
. - Change directory into the cloned repository
cd DotNetKoans
. - Restore packages:
dotnet restore
. - Open the project in VSCode
code-insiders .
orcode .
depending on what version you chose to install. - Run the koans in watch mode:
dotnet watch --quiet run
.- Note: The
--quiet
flag is used here to suppress messages from the watch framework.
- Note: The
- 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.
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 those be your first. 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.
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, 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 Koans
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!