- Documentation
See LESSONS-LEARNED.md.
C2CS
is distributed as a NuGet tool. To get started, the .NET 9 software development kit (SDK) is required.
dotnet tool install bottlenoselabs.c2cs.tool --global
dotnet tool install bottlenoselabs.c2cs.tool --global --add-source https://www.myget.org/F/bottlenoselabs/api/v3/index.json --version "*-*"
- 💡 For a specific pre-release, including a specific pull-request or the latest Git commit of the
main
branch, see: https://www.myget.org/feed/bottlenoselabs/package/nuget/bottlenoselabs.C2CS. - 💡 If you see a specific version but the
dotnet tool
command doesn't see it, try clearing your NuGet caches:
dotnet nuget locals all --clear
To generate C# bindings for a C library you need to first install and use the c2ffi
tool. Then setup a couple configuration files. See the helloworld-bindgen
example projects for an example of these configuration files.
See the auxiliary project Getting Started
section: https://github.com/bottlenoselabs/c2ffi#getting-started.
You should extract all the platform specific FFIs you wish to have as target platforms using c2ffi extract --config ...
. See the helloworld-bindgen/config-extract.json
for example configuration file for Windows, macOS, and Linux platforms.
Once all the platform FFIs are extracted to a directory, merge them together into a cross-platform FFI using c2ffi merge --inputDirectoryPath ... --outputFilePath ...
option.
See the helloworld-bindgen
C# program for example of using c2ffi
from command line.
Once you have a cross-platform FFI .json
file, you are ready to use c2cs
.
Run c2cs --config ...
from terminal specifying a configuration file. See the config-generate-cs.json
for an example configuration .json
file.
The Interop.Runtime
C# code is by default generated to a new file as Runtime.g.cs
. The Interop.Runtime
namespace contains helper structs, methods, and other kind of "glue" that make interoperability with C in C# easier and more idiomatic.
See the HelloWorld example for C# code that uses and explains how to use Interop.Runtime
.
- Install .NET 9 SDK.
- Install build tools for C/C++.
- Windows:
- Install Git Bash. (Usually installed with Git for Windows: https://git-scm.com/downloads.)
- Install MSCV (Microsoft Visual C++) Build Tools + some C/C++ SDK for Windows. (You can use Visual Studio Installer application to install the C/C++ workload or the components individually. You can also install it all via web or appropriate command line.)
- macOS:
- Install XCode CommandLineTools (gcc, clang, etc):
xcode-select --install
- Install XCode through the App Store (necessary for SDKs).
- Install Brew if you have not already: https://brew.sh
- Install CMake:
brew install cmake
- Install XCode CommandLineTools (gcc, clang, etc):
- Linux:
- Install the software build tools for your distro including GCC, Clang, and CMake.
- Windows:
- Clone the repository with submodules:
git clone --recurse-submodules https://github.com/bottlenoselabs/c2cs.git
.
Open ./C2CS.sln
dotnet build
By default C2CS
has logs enabled for Information
level. To enable logs for Debug
level place the following appsettings.json
file beside C2CS
or in the current directory where C2CS
is being run from. You can also change some other settings for logs through this file.
{
"Logging": {
"Console": {
"LogLevel": {
"Default": "Warning",
"C2CS": "Debug"
},
"FormatterOptions": {
"ColorBehavior": "Enabled",
"SingleLine": true,
"IncludeScopes": true,
"TimestampFormat": "yyyy-dd-MM HH:mm:ss ",
"UseUtcTimestamp": true
}
}
}
}
Here you will find examples of C libraries being demonstrated with C2CS
as smoke tests or otherwise used directly.
Hello world example of callings C functions from C#. This is meant to be minimalistic to demonstrate the minimum required things to get this working.
- Run the C# project
helloworld-bindgen
. This builds the example shared C library and generate the bindings for themy_c_library
C project. The C# bindings will be written tomy_c_library.g.cs
. - Run the C# project
helloworld-app
. You should see output to the console of C functions being called from C#.