GitXplorerGitXplorer
M

zerosharp

public
2032 stars
108 forks
10 issues

Commits

List of commits on branch master.
Verified
33cb5b6a663da1918767a2c624afcd0b16e1da43

Fix a typo (#51)

KKubaZ2 committed 6 months ago
Verified
fd4a7b724a9b62f85065a07db59b65e07e1e6652

Update ZeroSharp to .NET 7 (#37)

kkant2002 committed 2 years ago
Verified
8bc7a12d1f08afa081454abf87eade5bfc340355

React to ILCompiler changes (#31)

MMichalStrehovsky committed 3 years ago
Verified
186dc165ec5cce3033200e1d4177b9bbb89fb7d9

Update README.md (#24)

WWhiteBlackGoose committed 3 years ago
Verified
aedf1318b8a2cbc1ec8f990c4cbd66f28129f491

Update README.md

MMichalStrehovsky committed 3 years ago
Unverified
a23ef9f05390823c676b846a64af704d410a26d8

Fix breakage

MMichalStrehovsky committed 3 years ago

README

The README file for this repository.

C# for systems programming

These samples show how to compile C# to native code using the .NET Native AOT technology (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 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 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): XCode

Once you made sure you have the prerequisites, enter the appropriate sample directory and type:

$ 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.