add c# binding including example
This commit is contained in:
		
							parent
							
								
									3bf5249d08
								
							
						
					
					
						commit
						eb723701cf
					
				
					 20 changed files with 884 additions and 5 deletions
				
			
		
							
								
								
									
										2
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
										
									
									
										vendored
									
									
								
							|  | @ -1,3 +1,5 @@ | ||||||
| target | target | ||||||
| .idea | .idea | ||||||
| out | out | ||||||
|  | bin | ||||||
|  | obj | ||||||
|  |  | ||||||
							
								
								
									
										31
									
								
								Cargo.lock
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										31
									
								
								Cargo.lock
									
										
									
										generated
									
									
									
								
							|  | @ -144,7 +144,7 @@ dependencies = [ | ||||||
|  "heck", |  "heck", | ||||||
|  "proc-macro2", |  "proc-macro2", | ||||||
|  "quote", |  "quote", | ||||||
|  "syn", |  "syn 2.0.63", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
|  | @ -168,6 +168,16 @@ dependencies = [ | ||||||
|  "cfg-if", |  "cfg-if", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "csbindgen" | ||||||
|  | version = "1.9.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "cf70eb656f35e0e6956cbde31c66431c53d8a546823489719099c71525767a9c" | ||||||
|  | dependencies = [ | ||||||
|  |  "regex", | ||||||
|  |  "syn 1.0.109", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "env_filter" | name = "env_filter" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
|  | @ -410,6 +420,14 @@ version = "0.8.3" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "adad44e29e4c806119491a7f06f03de4d1af22c3a680dd47f1e6e179439d1f56" | checksum = "adad44e29e4c806119491a7f06f03de4d1af22c3a680dd47f1e6e179439d1f56" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "servicepoint-binding-cs" | ||||||
|  | version = "0.1.0" | ||||||
|  | dependencies = [ | ||||||
|  |  "csbindgen", | ||||||
|  |  "servicepoint2", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "servicepoint2" | name = "servicepoint2" | ||||||
| version = "0.2.0" | version = "0.2.0" | ||||||
|  | @ -427,6 +445,17 @@ version = "0.11.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f" | checksum = "7da8b5736845d9f2fcb837ea5d9e2628564b3b043a70948a3f0b778838c5fb4f" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "syn" | ||||||
|  | version = "1.0.109" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" | ||||||
|  | dependencies = [ | ||||||
|  |  "proc-macro2", | ||||||
|  |  "quote", | ||||||
|  |  "unicode-ident", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "syn" | name = "syn" | ||||||
| version = "2.0.63" | version = "2.0.63" | ||||||
|  |  | ||||||
|  | @ -7,4 +7,5 @@ members = [ | ||||||
|     "examples/moving_line", |     "examples/moving_line", | ||||||
|     "examples/wiping_clear", |     "examples/wiping_clear", | ||||||
|     "examples/random_brightness", |     "examples/random_brightness", | ||||||
|  |     "servicepoint2-binding-cs", | ||||||
| ] | ] | ||||||
|  |  | ||||||
							
								
								
									
										19
									
								
								examples/lang-cs/Program.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								examples/lang-cs/Program.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,19 @@ | ||||||
|  | using ServicePoint2; | ||||||
|  | 
 | ||||||
|  | using var connection = Connection.Open("127.0.0.1:2342"); | ||||||
|  | 
 | ||||||
|  | connection.Send(Command.Clear()); | ||||||
|  | connection.Send(Command.Brightness(128)); | ||||||
|  | 
 | ||||||
|  | using var pixels = PixelGrid.New(Constants.PixelWidth, Constants.PixelHeight); | ||||||
|  | 
 | ||||||
|  | for (var offset = 0; offset < int.MaxValue; offset++) | ||||||
|  | { | ||||||
|  |     pixels.Fill(false); | ||||||
|  | 
 | ||||||
|  |     for (var y = 0; y < pixels.Height; y++) | ||||||
|  |         pixels[(y + offset) % Constants.PixelWidth, y] = true; | ||||||
|  | 
 | ||||||
|  |     connection.Send(Command.BitmapLinearWin(0, 0, pixels.Clone())); | ||||||
|  |     Thread.Sleep(14); | ||||||
|  | } | ||||||
							
								
								
									
										21
									
								
								examples/lang-cs/lang-cs.csproj
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								examples/lang-cs/lang-cs.csproj
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,21 @@ | ||||||
|  | <Project Sdk="Microsoft.NET.Sdk"> | ||||||
|  | 
 | ||||||
|  |     <PropertyGroup> | ||||||
|  |         <OutputType>Exe</OutputType> | ||||||
|  |         <TargetFramework>net8.0</TargetFramework> | ||||||
|  |         <RootNamespace>lang_cs</RootNamespace> | ||||||
|  |         <ImplicitUsings>enable</ImplicitUsings> | ||||||
|  |         <Nullable>enable</Nullable> | ||||||
|  |     </PropertyGroup> | ||||||
|  | 
 | ||||||
|  |     <ItemGroup> | ||||||
|  |       <ProjectReference Include="..\..\servicepoint2-binding-cs\ServicePoint2\ServicePoint2.csproj" /> | ||||||
|  |     </ItemGroup> | ||||||
|  | 
 | ||||||
|  |     <ItemGroup> | ||||||
|  |       <Content Include="..\..\target\debug\libservicepoint2.so" CopyToOutputDirectory="Always"> | ||||||
|  |         <Link>libservicepoint2.so</Link> | ||||||
|  |       </Content> | ||||||
|  |     </ItemGroup> | ||||||
|  | 
 | ||||||
|  | </Project> | ||||||
							
								
								
									
										13
									
								
								servicepoint2-binding-cs/Cargo.toml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								servicepoint2-binding-cs/Cargo.toml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,13 @@ | ||||||
|  | [package] | ||||||
|  | name = "servicepoint-binding-cs" | ||||||
|  | version = "0.1.0" | ||||||
|  | edition = "2021" | ||||||
|  | 
 | ||||||
|  | [lib] | ||||||
|  | crate-type = ["cdylib"] | ||||||
|  | 
 | ||||||
|  | [dependencies] | ||||||
|  | servicepoint2 = { path = "../servicepoint2" } | ||||||
|  | 
 | ||||||
|  | [build-dependencies] | ||||||
|  | csbindgen = "1.8.0" | ||||||
|  | @ -0,0 +1,245 @@ | ||||||
|  | // <auto-generated> | ||||||
|  | // This code is generated by csbindgen. | ||||||
|  | // DON'T CHANGE THIS DIRECTLY. | ||||||
|  | // </auto-generated> | ||||||
|  | #pragma warning disable CS8500 | ||||||
|  | #pragma warning disable CS8981 | ||||||
|  | using System; | ||||||
|  | using System.Runtime.InteropServices; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | namespace ServicePoint2.BindGen | ||||||
|  | { | ||||||
|  |     public static unsafe partial class NativeMethods | ||||||
|  |     { | ||||||
|  |         const string __DllName = "servicepoint2"; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         /// <summary>Creates a new `BitVec` instance. The returned instance has to be freed with `bit_vec_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_new", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern BitVec* sp2_bit_vec_new(nuint size); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Loads a `BitVec` from the provided data. The returned instance has to be freed with `bit_vec_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_load", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern BitVec* sp2_bit_vec_load(byte* data, nuint data_length); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Clones a `BitVec`. The returned instance has to be freed with `bit_vec_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_clone", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern BitVec* sp2_bit_vec_clone(BitVec* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Deallocates a `BitVec`.  Note: do not call this if the grid has been consumed in another way, e.g. to create a command.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_dealloc", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_bit_vec_dealloc(BitVec* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Gets the value of a bit from the `BitVec`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_get", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         [return: MarshalAs(UnmanagedType.U1)] | ||||||
|  |         public static extern bool sp2_bit_vec_get(BitVec* @this, nuint index); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Sets the value of a bit in the `BitVec`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_set", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         [return: MarshalAs(UnmanagedType.U1)] | ||||||
|  |         public static extern bool sp2_bit_vec_set(BitVec* @this, nuint index, [MarshalAs(UnmanagedType.U1)] bool value); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Sets the value of all bits in the `BitVec`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_fill", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_bit_vec_fill(BitVec* @this, [MarshalAs(UnmanagedType.U1)] bool value); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Gets the length of the `BitVec` in bits.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_bit_vec_len", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern nuint sp2_bit_vec_len(BitVec* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Creates a new `ByteGrid` instance. The returned instance has to be freed with `byte_grid_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_new", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern ByteGrid* sp2_byte_grid_new(nuint width, nuint height); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Loads a `ByteGrid` with the specified dimensions from the provided data. The returned instance has to be freed with `byte_grid_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_load", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern ByteGrid* sp2_byte_grid_load(nuint width, nuint height, byte* data, nuint data_length); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Clones a `ByteGrid`. The returned instance has to be freed with `byte_grid_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_clone", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern ByteGrid* sp2_byte_grid_clone(ByteGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Deallocates a `ByteGrid`.  Note: do not call this if the grid has been consumed in another way, e.g. to create a command.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_dealloc", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_byte_grid_dealloc(ByteGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Get the current value at the specified position</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_get", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern byte sp2_byte_grid_get(ByteGrid* @this, nuint x, nuint y); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Sets the current value at the specified position</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_set", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_byte_grid_set(ByteGrid* @this, nuint x, nuint y, byte value); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Fills the whole `ByteGrid` with the specified value</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_fill", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_byte_grid_fill(ByteGrid* @this, byte value); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Gets the width in pixels of the `ByteGrid` instance.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_width", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern nuint sp2_byte_grid_width(ByteGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Gets the height in pixels of the `ByteGrid` instance.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_byte_grid_height", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern nuint sp2_byte_grid_height(ByteGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Tries to load a `Command` from the passed array with the specified length.  returns: NULL in case of an error, pointer to the allocated command otherwise</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_try_load", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_try_load(byte* data, nuint length); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Clones a `Command` instance</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_clone", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_clone(Command* original); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::Clear` instance</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_clear", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_clear(); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::HardReset` instance</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_hard_reset", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_hard_reset(); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::FadeOut` instance</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_fade_out", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_fade_out(); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::Brightness` instance</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_brightness", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_brightness(byte brightness); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::CharBrightness` instance. The passed `ByteGrid` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_char_brightness", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_char_brightness(ushort x, ushort y, ByteGrid* byte_grid); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::BitmapLinear` instance. The passed `BitVec` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_bitmap_linear", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_bitmap_linear(ushort offset, BitVec* bit_vec, CompressionCode compression); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::BitmapLinearAnd` instance. The passed `BitVec` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_bitmap_linear_and", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_bitmap_linear_and(ushort offset, BitVec* bit_vec, CompressionCode compression); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::BitmapLinearOr` instance. The passed `BitVec` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_bitmap_linear_or", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_bitmap_linear_or(ushort offset, BitVec* bit_vec, CompressionCode compression); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::BitmapLinearXor` instance. The passed `BitVec` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_bitmap_linear_xor", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_bitmap_linear_xor(ushort offset, BitVec* bit_vec, CompressionCode compression); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::Cp437Data` instance. The passed `ByteGrid` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_cp437_data", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_cp437_data(ushort x, ushort y, ByteGrid* byte_grid); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Allocates a new `Command::BitmapLinearWin` instance. The passed `PixelGrid` gets deallocated in the process.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_bitmap_linear_win", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Command* sp2_command_bitmap_linear_win(ushort x, ushort y, PixelGrid* byte_grid); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Deallocates a `Command`. Note that connection_send does this implicitly, so you only need to do this if you use the library for parsing commands.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_command_dealloc", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_command_dealloc(Command* ptr); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Creates a new instance of Connection. The returned instance has to be deallocated with `connection_dealloc`.  returns: NULL if connection fails or connected instance  Panics: bad string encoding</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_connection_open", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern Connection* sp2_connection_open(byte* host); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Sends the command instance. The instance is consumed / destroyed and cannot be used after this call.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_connection_send", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         [return: MarshalAs(UnmanagedType.U1)] | ||||||
|  |         public static extern bool sp2_connection_send(Connection* connection, Command* command_ptr); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Closes and deallocates a connection instance</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_connection_dealloc", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_connection_dealloc(Connection* ptr); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Creates a new `PixelGrid` instance. The returned instance has to be freed with `pixel_grid_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_new", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern PixelGrid* sp2_pixel_grid_new(nuint width, nuint height); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Loads a `PixelGrid` with the specified dimensions from the provided data. The returned instance has to be freed with `pixel_grid_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_load", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern PixelGrid* sp2_pixel_grid_load(nuint width, nuint height, byte* data, nuint data_length); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Clones a `PixelGrid`. The returned instance has to be freed with `pixel_grid_dealloc`.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_clone", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern PixelGrid* sp2_pixel_grid_clone(PixelGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Deallocates a `PixelGrid`.  Note: do not call this if the grid has been consumed in another way, e.g. to create a command.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_dealloc", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_pixel_grid_dealloc(PixelGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Get the current value at the specified position</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_get", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         [return: MarshalAs(UnmanagedType.U1)] | ||||||
|  |         public static extern bool sp2_pixel_grid_get(PixelGrid* @this, nuint x, nuint y); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Sets the current value at the specified position</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_set", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_pixel_grid_set(PixelGrid* @this, nuint x, nuint y, [MarshalAs(UnmanagedType.U1)] bool value); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Fills the whole `PixelGrid` with the specified value</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_fill", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern void sp2_pixel_grid_fill(PixelGrid* @this, [MarshalAs(UnmanagedType.U1)] bool value); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Gets the width in pixels of the `PixelGrid` instance.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_width", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern nuint sp2_pixel_grid_width(PixelGrid* @this); | ||||||
|  | 
 | ||||||
|  |         /// <summary>Gets the height in pixels of the `PixelGrid` instance.</summary> | ||||||
|  |         [DllImport(__DllName, EntryPoint = "sp2_pixel_grid_height", CallingConvention = CallingConvention.Cdecl, ExactSpelling = true)] | ||||||
|  |         public static extern nuint sp2_pixel_grid_height(PixelGrid* @this); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     [StructLayout(LayoutKind.Sequential)] | ||||||
|  |     public unsafe partial struct BitVec | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     [StructLayout(LayoutKind.Sequential)] | ||||||
|  |     public unsafe partial struct ByteGrid | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     [StructLayout(LayoutKind.Sequential)] | ||||||
|  |     public unsafe partial struct Connection | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     [StructLayout(LayoutKind.Sequential)] | ||||||
|  |     public unsafe partial struct PixelGrid | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public enum Command | ||||||
|  |     { | ||||||
|  |         Clear, | ||||||
|  |         HardReset, | ||||||
|  |         FadeOut, | ||||||
|  |         CharBrightness, | ||||||
|  |         Brightness, | ||||||
|  |         BitmapLegacy, | ||||||
|  |         BitmapLinear, | ||||||
|  |         BitmapLinearAnd, | ||||||
|  |         BitmapLinearOr, | ||||||
|  |         BitmapLinearXor, | ||||||
|  |         Cp437Data, | ||||||
|  |         BitmapLinearWin, | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public enum CompressionCode : ushort | ||||||
|  |     { | ||||||
|  |         Uncompressed = 0, | ||||||
|  |         Gz = 26490, | ||||||
|  |         Bz = 25210, | ||||||
|  |         Lz = 27770, | ||||||
|  |         Zs = 31347, | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
							
								
								
									
										79
									
								
								servicepoint2-binding-cs/ServicePoint2/BitVec.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								servicepoint2-binding-cs/ServicePoint2/BitVec.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,79 @@ | ||||||
|  | using ServicePoint2.BindGen; | ||||||
|  | 
 | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public sealed class BitVec : Sp2NativeInstance<BindGen.BitVec> | ||||||
|  | { | ||||||
|  |     public static BitVec New(int size) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new BitVec(NativeMethods.sp2_bit_vec_new((nuint)size)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static BitVec Load(Span<byte> bytes) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             fixed (byte* bytesPtr = bytes) | ||||||
|  |             { | ||||||
|  |                 return new BitVec(NativeMethods.sp2_bit_vec_load(bytesPtr, (nuint)bytes.Length)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public BitVec Clone() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new BitVec(NativeMethods.sp2_bit_vec_clone(Instance)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public bool this[int index] | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return NativeMethods.sp2_bit_vec_get(Instance, (nuint)index); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         set | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 NativeMethods.sp2_bit_vec_set(Instance, (nuint)index, value); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Fill(bool value) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             NativeMethods.sp2_bit_vec_fill(Instance, value); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int Length | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return (int)NativeMethods.sp2_bit_vec_len(Instance); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private unsafe BitVec(BindGen.BitVec* instance) : base(instance) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     protected override unsafe void Dealloc() | ||||||
|  |     { | ||||||
|  |         NativeMethods.sp2_bit_vec_dealloc(Instance); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										91
									
								
								servicepoint2-binding-cs/ServicePoint2/ByteGrid.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								servicepoint2-binding-cs/ServicePoint2/ByteGrid.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,91 @@ | ||||||
|  | using ServicePoint2.BindGen; | ||||||
|  | 
 | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public sealed class ByteGrid : Sp2NativeInstance<BindGen.ByteGrid> | ||||||
|  | { | ||||||
|  |     public static ByteGrid New(int width, int height) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new ByteGrid(NativeMethods.sp2_byte_grid_new((nuint)width, (nuint)height)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static ByteGrid Load(int width, int height, Span<byte> bytes) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             fixed (byte* bytesPtr = bytes) | ||||||
|  |             { | ||||||
|  |                 return new ByteGrid(NativeMethods.sp2_byte_grid_load((nuint)width, (nuint)height, bytesPtr, | ||||||
|  |                     (nuint)bytes.Length)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public ByteGrid Clone() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new ByteGrid(NativeMethods.sp2_byte_grid_clone(Instance)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public byte this[int x, int y] | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return NativeMethods.sp2_byte_grid_get(Instance, (nuint)x, (nuint)y); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         set | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 NativeMethods.sp2_byte_grid_set(Instance, (nuint)x, (nuint)y, value); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Fill(byte value) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             NativeMethods.sp2_byte_grid_fill(Instance, value); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int Width | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return (int)NativeMethods.sp2_byte_grid_width(Instance); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int Height | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return (int)NativeMethods.sp2_byte_grid_height(Instance); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private unsafe ByteGrid(BindGen.ByteGrid* instance) : base(instance) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     protected override unsafe void Dealloc() | ||||||
|  |     { | ||||||
|  |         NativeMethods.sp2_byte_grid_dealloc(Instance); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										131
									
								
								servicepoint2-binding-cs/ServicePoint2/Command.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										131
									
								
								servicepoint2-binding-cs/ServicePoint2/Command.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,131 @@ | ||||||
|  | using System.Diagnostics.CodeAnalysis; | ||||||
|  | using ServicePoint2.BindGen; | ||||||
|  | 
 | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public sealed class Command : Sp2NativeInstance<BindGen.Command> | ||||||
|  | { | ||||||
|  |     public Command Clone() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_clone(Instance)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static bool TryLoad(Span<byte> bytes, [MaybeNullWhen(false)] out Command command) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             fixed (byte* bytesPtr = bytes) | ||||||
|  |             { | ||||||
|  |                 var instance = NativeMethods.sp2_command_try_load(bytesPtr, (nuint)bytes.Length); | ||||||
|  |                 command = instance == null | ||||||
|  |                     ? null | ||||||
|  |                     : new Command(instance); | ||||||
|  |                 return command != null; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command Clear() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_clear()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command HardReset() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_hard_reset()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command FadeOut() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_fade_out()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command Brightness(byte brightness) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_brightness(brightness)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command CharBrightness(int x, int y, ByteGrid grid) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_char_brightness((ushort)x, (ushort)y, grid.Into())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command BitmapLinear(int offset, BitVec bitVec, CompressionCode compressionCode) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command( | ||||||
|  |                 NativeMethods.sp2_command_bitmap_linear((ushort)offset, bitVec.Into(), compressionCode)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command BitmapLinearAnd(int offset, BitVec bitVec, CompressionCode compressionCode) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command( | ||||||
|  |                 NativeMethods.sp2_command_bitmap_linear_and((ushort)offset, bitVec.Into(), compressionCode)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command BitmapLinearOr(int offset, BitVec bitVec, CompressionCode compressionCode) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command( | ||||||
|  |                 NativeMethods.sp2_command_bitmap_linear_or((ushort)offset, bitVec.Into(), compressionCode)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command BitmapLinearXor(int offset, BitVec bitVec, CompressionCode compressionCode) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command( | ||||||
|  |                 NativeMethods.sp2_command_bitmap_linear_xor((ushort)offset, bitVec.Into(), compressionCode)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command BitmapLinearWin(int x, int y, PixelGrid pixelGrid) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_bitmap_linear_win((ushort)x, (ushort)y, pixelGrid.Into())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static Command Cp437Data(int x, int y, ByteGrid byteGrid) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new Command(NativeMethods.sp2_command_cp437_data((ushort)x, (ushort)y, byteGrid.Into())); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private unsafe Command(BindGen.Command* instance) : base(instance) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     protected override unsafe void Dealloc() | ||||||
|  |     { | ||||||
|  |         NativeMethods.sp2_command_dealloc(Instance); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										35
									
								
								servicepoint2-binding-cs/ServicePoint2/Connection.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								servicepoint2-binding-cs/ServicePoint2/Connection.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | ||||||
|  | using System.Text; | ||||||
|  | using ServicePoint2.BindGen; | ||||||
|  | 
 | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public sealed class Connection : Sp2NativeInstance<BindGen.Connection> | ||||||
|  | { | ||||||
|  |     public static Connection Open(string host) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             fixed (byte* bytePtr = Encoding.UTF8.GetBytes(host)) | ||||||
|  |             { | ||||||
|  |                 return new Connection(NativeMethods.sp2_connection_open(bytePtr)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public bool Send(Command command) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return NativeMethods.sp2_connection_send(Instance, command.Into()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     protected override unsafe void Dealloc() | ||||||
|  |     { | ||||||
|  |         NativeMethods.sp2_connection_dealloc(Instance); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private unsafe Connection(BindGen.Connection* instance) : base(instance) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										22
									
								
								servicepoint2-binding-cs/ServicePoint2/Constants.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								servicepoint2-binding-cs/ServicePoint2/Constants.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public static class Constants | ||||||
|  | { | ||||||
|  |     /// size of a single tile in one dimension | ||||||
|  |     public const int TileSize = 8; | ||||||
|  | 
 | ||||||
|  |     /// tile count in the x-direction | ||||||
|  |     public const int TileWidth = 56; | ||||||
|  | 
 | ||||||
|  |     /// tile count in the y-direction | ||||||
|  |     public const int TileHeight = 20; | ||||||
|  | 
 | ||||||
|  |     /// screen width in pixels | ||||||
|  |     public const int PixelWidth = TileWidth * TileSize; | ||||||
|  | 
 | ||||||
|  |     /// screen height in pixels | ||||||
|  |     public const int PixelHeight = TileHeight * TileSize; | ||||||
|  | 
 | ||||||
|  |     /// pixel count on whole screen | ||||||
|  |     public const int PixelCount = PixelWidth * PixelHeight; | ||||||
|  | } | ||||||
							
								
								
									
										91
									
								
								servicepoint2-binding-cs/ServicePoint2/PixelGrid.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								servicepoint2-binding-cs/ServicePoint2/PixelGrid.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,91 @@ | ||||||
|  | using ServicePoint2.BindGen; | ||||||
|  | 
 | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public sealed class PixelGrid : Sp2NativeInstance<BindGen.PixelGrid> | ||||||
|  | { | ||||||
|  |     public static PixelGrid New(int width, int height) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new PixelGrid(NativeMethods.sp2_pixel_grid_new((nuint)width, (nuint)height)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static PixelGrid Load(int width, int height, Span<byte> bytes) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             fixed (byte* bytesPtr = bytes) | ||||||
|  |             { | ||||||
|  |                 return new PixelGrid(NativeMethods.sp2_pixel_grid_load((nuint)width, (nuint)height, bytesPtr, | ||||||
|  |                     (nuint)bytes.Length)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public PixelGrid Clone() | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             return new PixelGrid(NativeMethods.sp2_pixel_grid_clone(Instance)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public bool this[int x, int y] | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return NativeMethods.sp2_pixel_grid_get(Instance, (nuint)x, (nuint)y); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         set | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 NativeMethods.sp2_pixel_grid_set(Instance, (nuint)x, (nuint)y, value); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Fill(bool value) | ||||||
|  |     { | ||||||
|  |         unsafe | ||||||
|  |         { | ||||||
|  |             NativeMethods.sp2_pixel_grid_fill(Instance, value); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int Width | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return (int)NativeMethods.sp2_pixel_grid_width(Instance); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public int Height | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             unsafe | ||||||
|  |             { | ||||||
|  |                 return (int)NativeMethods.sp2_pixel_grid_height(Instance); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private unsafe PixelGrid(BindGen.PixelGrid* instance) : base(instance) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     protected override unsafe void Dealloc() | ||||||
|  |     { | ||||||
|  |         NativeMethods.sp2_pixel_grid_dealloc(Instance); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										10
									
								
								servicepoint2-binding-cs/ServicePoint2/ServicePoint2.csproj
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								servicepoint2-binding-cs/ServicePoint2/ServicePoint2.csproj
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | ||||||
|  | <Project Sdk="Microsoft.NET.Sdk"> | ||||||
|  | 
 | ||||||
|  |     <PropertyGroup> | ||||||
|  |         <TargetFramework>net8.0</TargetFramework> | ||||||
|  |         <ImplicitUsings>enable</ImplicitUsings> | ||||||
|  |         <Nullable>enable</Nullable> | ||||||
|  |         <AllowUnsafeBlocks>true</AllowUnsafeBlocks> | ||||||
|  |     </PropertyGroup> | ||||||
|  | 
 | ||||||
|  | </Project> | ||||||
							
								
								
									
										22
									
								
								servicepoint2-binding-cs/ServicePoint2/ServicePoint2.sln
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								servicepoint2-binding-cs/ServicePoint2/ServicePoint2.sln
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  |  | ||||||
|  | Microsoft Visual Studio Solution File, Format Version 12.00 | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ServicePoint2", "ServicePoint2.csproj", "{70EFFA3F-012A-4518-9627-466BEAE4252E}" | ||||||
|  | EndProject | ||||||
|  | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "lang-cs", "..\..\examples\lang-cs\lang-cs.csproj", "{DA3B8B6E-993A-47DA-844B-F92AF520FF59}" | ||||||
|  | EndProject | ||||||
|  | Global | ||||||
|  | 	GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||||||
|  | 		Debug|Any CPU = Debug|Any CPU | ||||||
|  | 		Release|Any CPU = Release|Any CPU | ||||||
|  | 	EndGlobalSection | ||||||
|  | 	GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||||||
|  | 		{70EFFA3F-012A-4518-9627-466BEAE4252E}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{70EFFA3F-012A-4518-9627-466BEAE4252E}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{70EFFA3F-012A-4518-9627-466BEAE4252E}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{70EFFA3F-012A-4518-9627-466BEAE4252E}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 		{DA3B8B6E-993A-47DA-844B-F92AF520FF59}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||||||
|  | 		{DA3B8B6E-993A-47DA-844B-F92AF520FF59}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||||||
|  | 		{DA3B8B6E-993A-47DA-844B-F92AF520FF59}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||||||
|  | 		{DA3B8B6E-993A-47DA-844B-F92AF520FF59}.Release|Any CPU.Build.0 = Release|Any CPU | ||||||
|  | 	EndGlobalSection | ||||||
|  | EndGlobal | ||||||
							
								
								
									
										51
									
								
								servicepoint2-binding-cs/ServicePoint2/Sp2NativeInstance.cs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								servicepoint2-binding-cs/ServicePoint2/Sp2NativeInstance.cs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,51 @@ | ||||||
|  | namespace ServicePoint2; | ||||||
|  | 
 | ||||||
|  | public abstract class Sp2NativeInstance<T> | ||||||
|  |     : IDisposable | ||||||
|  |     where T : unmanaged | ||||||
|  | { | ||||||
|  |     private unsafe T* _instance; | ||||||
|  | 
 | ||||||
|  |     internal unsafe T* Instance | ||||||
|  |     { | ||||||
|  |         get | ||||||
|  |         { | ||||||
|  |             if (_instance == null) | ||||||
|  |                 throw new NullReferenceException("instance is null"); | ||||||
|  |             return _instance; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private protected unsafe Sp2NativeInstance(T* instance) | ||||||
|  |     { | ||||||
|  |         ArgumentNullException.ThrowIfNull(instance); | ||||||
|  |         _instance = instance; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     protected abstract void Dealloc(); | ||||||
|  | 
 | ||||||
|  |     internal unsafe T* Into() | ||||||
|  |     { | ||||||
|  |         var instance = _instance; | ||||||
|  |         _instance = null; | ||||||
|  |         return instance; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private unsafe void ReleaseUnmanagedResources() | ||||||
|  |     { | ||||||
|  |         if (_instance != null) | ||||||
|  |             Dealloc(); | ||||||
|  |         _instance = null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Dispose() | ||||||
|  |     { | ||||||
|  |         ReleaseUnmanagedResources(); | ||||||
|  |         GC.SuppressFinalize(this); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     ~Sp2NativeInstance() | ||||||
|  |     { | ||||||
|  |         ReleaseUnmanagedResources(); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								servicepoint2-binding-cs/build.rs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								servicepoint2-binding-cs/build.rs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,17 @@ | ||||||
|  | fn main() { | ||||||
|  |     println!("cargo:rerun-if-changed=DOESNOTEXIST"); // rebuild every time
 | ||||||
|  |     csbindgen::Builder::default() | ||||||
|  |         .input_extern_file("../servicepoint2/src/bit_vec.rs") | ||||||
|  |         .input_extern_file("../servicepoint2/src/byte_grid.rs") | ||||||
|  |         .input_extern_file("../servicepoint2/src/command.rs") | ||||||
|  |         .input_extern_file("../servicepoint2/src/compression_code.rs") | ||||||
|  |         .input_extern_file("../servicepoint2/src/connection.rs") | ||||||
|  |         .input_extern_file("../servicepoint2/src/pixel_grid.rs") | ||||||
|  |         .input_extern_file("../servicepoint2/src/lib.rs") | ||||||
|  |         .csharp_dll_name("servicepoint2") | ||||||
|  |         .csharp_namespace("ServicePoint2.BindGen") | ||||||
|  |         .csharp_use_nint_types(true) | ||||||
|  |         .csharp_class_accessibility("public") | ||||||
|  |         .generate_csharp_file("ServicePoint2/BindGen/ServicePoint2.g.cs") | ||||||
|  |         .unwrap(); | ||||||
|  | } | ||||||
							
								
								
									
										0
									
								
								servicepoint2-binding-cs/src/lib.rs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								servicepoint2-binding-cs/src/lib.rs
									
										
									
									
									
										Normal file
									
								
							|  | @ -10,7 +10,7 @@ repository = "https://github.com/kaesaecracker/servicepoint" | ||||||
| readme = "../README.md" | readme = "../README.md" | ||||||
| 
 | 
 | ||||||
| [lib] | [lib] | ||||||
| crate-type = ["staticlib", "rlib"] | crate-type = ["staticlib", "rlib", "cdylib"] | ||||||
| 
 | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| log = "0.4" | log = "0.4" | ||||||
|  |  | ||||||
|  | @ -61,7 +61,7 @@ impl Into<Vec<u8>> for ByteGrid { | ||||||
| #[cfg(feature = "c-api")] | #[cfg(feature = "c-api")] | ||||||
| pub mod c_api | pub mod c_api | ||||||
| { | { | ||||||
|     use crate::{ByteGrid, PixelGrid}; |     use crate::ByteGrid; | ||||||
| 
 | 
 | ||||||
|     /// Creates a new `ByteGrid` instance.
 |     /// Creates a new `ByteGrid` instance.
 | ||||||
|     /// The returned instance has to be freed with `byte_grid_dealloc`.
 |     /// The returned instance has to be freed with `byte_grid_dealloc`.
 | ||||||
|  | @ -113,13 +113,13 @@ pub mod c_api | ||||||
| 
 | 
 | ||||||
|     /// Gets the width in pixels of the `ByteGrid` instance.
 |     /// Gets the width in pixels of the `ByteGrid` instance.
 | ||||||
|     #[no_mangle] |     #[no_mangle] | ||||||
|     pub unsafe extern "C" fn sp2_byte_grid_width(this: *const PixelGrid) -> usize { |     pub unsafe extern "C" fn sp2_byte_grid_width(this: *const ByteGrid) -> usize { | ||||||
|         (*this).width |         (*this).width | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// Gets the height in pixels of the `ByteGrid` instance.
 |     /// Gets the height in pixels of the `ByteGrid` instance.
 | ||||||
|     #[no_mangle] |     #[no_mangle] | ||||||
|     pub unsafe extern "C" fn sp2_byte_grid_height(this: *const PixelGrid) -> usize { |     pub unsafe extern "C" fn sp2_byte_grid_height(this: *const ByteGrid) -> usize { | ||||||
|         (*this).height |         (*this).height | ||||||
|     } |     } | ||||||
| } | } | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vinzenz Schroeter
						Vinzenz Schroeter