Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/MichalStrehovsky/zerosharp
Demo of the potential of C# for systems programming with the .NET native ahead-of-time compilation technology.
https://github.com/MichalStrehovsky/zerosharp
csharp systems-programming
Last synced: 3 months ago
JSON representation
Demo of the potential of C# for systems programming with the .NET native ahead-of-time compilation technology.
- Host: GitHub
- URL: https://github.com/MichalStrehovsky/zerosharp
- Owner: MichalStrehovsky
- Created: 2019-02-03T16:34:23.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-07-06T18:47:03.000Z (7 months ago)
- Last Synced: 2024-10-29T15:38:50.876Z (3 months ago)
- Topics: csharp, systems-programming
- Language: C#
- Homepage:
- Size: 218 KB
- Stars: 2,016
- Watchers: 59
- Forks: 105
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# C# for systems programming
These samples show how to compile C# to native code using the .NET Native AOT technology ([NativeAOT](https://github.com/dotnet/runtimelab/tree/feature/NativeAOT), also known as CoreRT previously).
The samples are for people who would like to use C#, but don't want to be bound by the choices of the base class libraries that normally come with C# (in the form that it's bundled in .NET). If you just want to native compile your .NET apps, go to the [NativeAOT](https://github.com/dotnet/runtimelab/tree/feature/NativeAOT) repo/branch instead. Nothing to see for you in this repo.
`no-runtime` is a rather pointless sample that demonstrates how to write code in C# that is directly runnable without a runtime. C# has value types and you can p/invoke into an unmanaged memory allocator, so you can do things with this, but you're so severily limited it's rather pointless. But Hello world ends up being about 8 kB native EXE with no dependencies, so that's rather cool.
`with-runtime` is something that can be actually useful. This includes the full managed and unmanaged runtime - GC, exception handling, and interface dispatch all work. Test.CoreLib used as the class library here is the same Test.CoreLib that you can find in the NativeAOT repo. Don't look for things like `Object.ToString()` because being compatible with .NET is not the point. This sample comes down to about 400 kB, most of which is the C runtime library.
`efi-no-runtime` is an EFI boot application that lets you run C# on bare metal, without an OS. Similar restrictions to the `no-runtime` sample apply. Making a version of this sample with a runtime would require some porting work on the runtime side.
## Building the samples
[.NET 7 SDK](https://dotnet.microsoft.com/download) is a prerequisite for building these on all platforms.
In addition to the .NET 7 SDK, these are needed:
* On Windows: Visual Studio 2022 **with** C++ development support and a Windows SDK
* On Linux: clang
* On macOS (untested): XCodeOnce you made sure you have the prerequisites, enter the appropriate sample directory and type:
```bash
$ dotnet publish -c Release
```Some samples also come with a shell script (*.cmd) that pieces together all the tools and avoid MSBuild or dotnet. You need to make sure you have environment set up before running the script. Look at the script for details. The script is redundant with the *.csproj project files.