From 0bdf2fa156f5133b09ddac7beb326b942d524b38 Mon Sep 17 00:00:00 2001 From: Conan Chen Date: Mon, 28 Sep 2020 14:56:59 -0400 Subject: [PATCH] [C#] Fix and improve project files (#6142) * [C#] Fix and improve project files * "net35" target included for Unity 5 * "net46" target included for Unity 2017 * "netstandard2.0" target included for Unity 2018 and general use * "netstandard2.1" target included for Span support Included project properties for defining UNSAFE_BYTEBUFFER, BYTEBUFFER_NO_BOUNDS_CHECK, and ENABLE_SPAN_T conditional compilation symbols. * Add documentation on building for C# --- docs/source/CsharpUsage.md | 69 ++++++++++++++++++++---- net/FlatBuffers/ByteBuffer.cs | 13 ++--- net/FlatBuffers/FlatBuffers.Core.csproj | 19 ------- net/FlatBuffers/FlatBuffers.csproj | 67 +++++++---------------- net/FlatBuffers/FlatBuffers.net35.csproj | 57 ++++++++++++++++++++ 5 files changed, 142 insertions(+), 83 deletions(-) delete mode 100644 net/FlatBuffers/FlatBuffers.Core.csproj create mode 100644 net/FlatBuffers/FlatBuffers.net35.csproj diff --git a/docs/source/CsharpUsage.md b/docs/source/CsharpUsage.md index 4bf012a8f..83f4842fc 100644 --- a/docs/source/CsharpUsage.md +++ b/docs/source/CsharpUsage.md @@ -14,14 +14,38 @@ documentation to build `flatc` and should be familiar with [Using the schema compiler](@ref flatbuffers_guide_using_schema_compiler) and [Writing a schema](@ref flatbuffers_guide_writing_schema). -## FlatBuffers C-sharp code location +## FlatBuffers C# code location The code for the FlatBuffers C# library can be found at `flatbuffers/net/FlatBuffers`. You can browse the library on the [FlatBuffers GitHub page](https://github.com/google/flatbuffers/tree/master/net/ FlatBuffers). -## Testing the FlatBuffers C-sharp libraries +## Building the FlatBuffers C# library + +The `FlatBuffers.csproj` project contains multitargeting for .NET Standard 2.1, +.NET Standard 2.0, and .NET Framework 4.6 (Unity 2017). Support for .NET +Framework 3.5 (Unity 5) is provided by the `FlatBuffers.net35.csproj` project. +In most cases (including Unity 2018 and newer), .NET Standard 2.0 is +recommended. + +You can build for a specific framework target when using the cross-platform +[.NET Core SDK](https://dotnet.microsoft.com/download) by adding the `-f` +command line option: + +~~~{.sh} + dotnet build -f netstandard2.0 "FlatBuffers.csproj" +~~~ + +The `FlatBuffers.csproj` project also provides support for defining various +conditional compilation symbols (see "Conditional compilation symbols" section +below) using the `-p` command line option: + +~~~{.sh} + dotnet build -f netstandard2.1 -p:ENABLE_SPAN_T=true -p:UNSAFE_BYTEBUFFER=true "FlatBuffers.csproj" +~~~ + +## Testing the FlatBuffers C# library The code to test the libraries can be found at `flatbuffers/tests`. @@ -31,12 +55,12 @@ tests, open `FlatBuffers.Test.csproj` in [Visual Studio]( https://www.visualstudio.com), and compile/run the project. Optionally, you can run this using [Mono](http://www.mono-project.com/) instead. -Once you have installed `Mono`, you can run the tests from the command line +Once you have installed Mono, you can run the tests from the command line by running the following commands from inside the `FlatBuffers.Test` folder: ~~~{.sh} - mcs *.cs ../MyGame/Example/*.cs ../../net/FlatBuffers/*.cs - mono Assert.exe + mcs *.cs ../MyGame/Example/*.cs ../../net/FlatBuffers/*.cs + mono Assert.exe ~~~ ## Using the FlatBuffers C# library @@ -74,7 +98,7 @@ Now you can access the data from the `Monster monster`: Vec3 pos = monster.Pos; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -C# code naming follows standard C# style with `PascalCasing` identifiers, +C# code naming follows standard C# style with PascalCasing identifiers, e.g. `GetRootAsMyRootType`. Also, values (except vectors and unions) are available as properties instead of parameterless accessor methods. The performance-enhancing methods to which you can pass an already created @@ -133,8 +157,8 @@ around using as little as possible of it. This does make the API clumsier For times when efficiency is less important a more convenient object based API can be used (through `--gen-object-api`) that is able to unpack & pack a -FlatBuffer into objects and standard System.Collections.Generic containers, allowing for convenient -construction, access and mutation. +FlatBuffer into objects and standard `System.Collections.Generic` containers, +allowing for convenient construction, access and mutation. To use: @@ -154,7 +178,7 @@ To use: ### Json Serialization An additional feature of the object API is the ability to allow you to -serialize & deserialize a JSON text. +serialize & deserialize a JSON text. To use Json Serialization, add `--cs-gen-json-serializer` option to `flatc` and add `Newtonsoft.Json` nuget package to csproj. @@ -172,4 +196,31 @@ add `Newtonsoft.Json` nuget package to csproj. * NuGet package Dependency * [Newtonsoft.Json](https://github.com/JamesNK/Newtonsoft.Json) +## Conditional compilation symbols + +There are three conditional compilation symbols that have an impact on +performance/features of the C# `ByteBuffer` implementation. + +* `UNSAFE_BYTEBUFFER` + + This will use unsafe code to manipulate the underlying byte array. This can + yield a reasonable performance increase. + +* `BYTEBUFFER_NO_BOUNDS_CHECK` + + This will disable the bounds check asserts to the byte array. This can yield a + small performance gain in normal code. + +* `ENABLE_SPAN_T` + + This will enable reading and writing blocks of memory with a `Span` instead + of just `T[]`. You can also enable writing directly to shared memory or other + types of memory by providing a custom implementation of `ByteBufferAllocator`. + `ENABLE_SPAN_T` also requires `UNSAFE_BYTEBUFFER` to be defined, or .NET + Standard 2.1. + +Using `UNSAFE_BYTEBUFFER` and `BYTEBUFFER_NO_BOUNDS_CHECK` together can yield a +performance gain of ~15% for some operations, however doing so is potentially +dangerous. Do so at your own risk! +
diff --git a/net/FlatBuffers/ByteBuffer.cs b/net/FlatBuffers/ByteBuffer.cs index 4ed00627d..6e0fe35bb 100644 --- a/net/FlatBuffers/ByteBuffer.cs +++ b/net/FlatBuffers/ByteBuffer.cs @@ -14,24 +14,25 @@ * limitations under the License. */ -// There are 3 #defines that have an impact on performance / features of this ByteBuffer implementation +// There are three conditional compilation symbols that have an impact on performance/features of this ByteBuffer implementation. // -// UNSAFE_BYTEBUFFER +// UNSAFE_BYTEBUFFER // This will use unsafe code to manipulate the underlying byte array. This // can yield a reasonable performance increase. // // BYTEBUFFER_NO_BOUNDS_CHECK // This will disable the bounds check asserts to the byte array. This can -// yield a small performance gain in normal code.. +// yield a small performance gain in normal code. // // ENABLE_SPAN_T -// This will enable reading and writing blocks of memory with a Span instead if just +// This will enable reading and writing blocks of memory with a Span instead of just // T[]. You can also enable writing directly to shared memory or other types of memory // by providing a custom implementation of ByteBufferAllocator. -// ENABLE_SPAN_T also requires UNSAFE_BYTEBUFFER to be defined +// ENABLE_SPAN_T also requires UNSAFE_BYTEBUFFER to be defined, or .NET +// Standard 2.1. // // Using UNSAFE_BYTEBUFFER and BYTEBUFFER_NO_BOUNDS_CHECK together can yield a -// performance gain of ~15% for some operations, however doing so is potentially +// performance gain of ~15% for some operations, however doing so is potentially // dangerous. Do so at your own risk! // diff --git a/net/FlatBuffers/FlatBuffers.Core.csproj b/net/FlatBuffers/FlatBuffers.Core.csproj deleted file mode 100644 index 040e7716a..000000000 --- a/net/FlatBuffers/FlatBuffers.Core.csproj +++ /dev/null @@ -1,19 +0,0 @@ - - - - netstandard2.0;netstandard2.1 - - - - - - - - - - - - - - - diff --git a/net/FlatBuffers/FlatBuffers.csproj b/net/FlatBuffers/FlatBuffers.csproj index a0290947f..54cba5aaf 100644 --- a/net/FlatBuffers/FlatBuffers.csproj +++ b/net/FlatBuffers/FlatBuffers.csproj @@ -1,54 +1,23 @@ - - - + + - Debug - AnyCPU - {28C00774-1E73-4A75-AD8F-844CD21A064D} - Library - Properties - FlatBuffers - FlatBuffers - v3.5 - 512 + netstandard2.1;netstandard2.0;net46 + false - - true - full - false - bin\Debug\ - DEBUG;TRACE - prompt - 4 + + + $(DefineConstants);UNSAFE_BYTEBUFFER + true - - pdbonly - true - bin\Release\ - TRACE - prompt - 4 + + $(DefineConstants);BYTEBUFFER_NO_BOUNDS_CHECK - - - + + $(DefineConstants);ENABLE_SPAN_T + + + + - - - - - - - - - - - - - \ No newline at end of file + + diff --git a/net/FlatBuffers/FlatBuffers.net35.csproj b/net/FlatBuffers/FlatBuffers.net35.csproj new file mode 100644 index 000000000..574580e37 --- /dev/null +++ b/net/FlatBuffers/FlatBuffers.net35.csproj @@ -0,0 +1,57 @@ + + + + + Debug + AnyCPU + {28C00774-1E73-4A75-AD8F-844CD21A064D} + Library + Properties + FlatBuffers + FlatBuffers + v3.5 + 512 + + + true + full + false + bin\Debug\net35 + obj\Debug\net35 + DEBUG;TRACE + prompt + 4 + + + pdbonly + true + bin\Release\net35 + obj\Release\net35 + TRACE + prompt + 4 + + + + + + + + + + + + + + + + + + + \ No newline at end of file