Unity/MessagePack
目次
MessagePackとは
効率の良いバイナリ形式のオブジェクト・シリアライズ フォーマット。jsonみたいなもので、署名機能などはない。
公式:https://msgpack.org/ja.html
c#のPackage
5つある C# msgpack C# ymofen C# caesay C# mlsomers C# neuecc
neueccのMessagePack導入
PackageManagerからMessagePack-v3のインストール
- MessagePack annotations for C# (NuGet)
- MessagePack for C# (NuGet)
- MessagePack Source Generator and Analyzer (NuGet)
もしくは、Packages/manifest.jsonに以下を追加
{ "dependencies": { "org.nuget.messagepack": "3.1.3",
v3になって、mpcはなくなった。(2024/12/06)
https://neue.cc/2024/12/06_MessagePack_v3.html
PackageManagerからMessagePack-v2のインストール
v3をインストールした場合は、v2は不要
neuecc https://github.com/MessagePack-CSharp/MessagePack-CSharp
PackageManagerのgiturlに
https://github.com/neuecc/MessagePack-CSharp.git?path=src/MessagePack.UnityClient/Assets/Scripts/MessagePack#v2.6.100-alpha
を追加。
もしくは、Packages/manifest.jsonに以下を追加
{ "dependencies": { "com.neuecc.messagepack": "https://github.com/neuecc/MessagePack-CSharp.git?path=src/MessagePack.UnityClient/Assets/Scripts/MessagePack#v2.6.100-alpha",
"namespace name 'NET' does not exist"エラーが出る時
error CS0234: The type or namespace name 'NET' does not exist in the namespace 'Microsoft' (are you missing an assembly reference?)
↓の手順で、Microsoft.NET.StringToolsをインストールする
nugetでMicrosoft.NET.StringToolsインストール
unityメイン/Edit/ProjectSettings/PackageManagerから以下を追加
Name: OpenUPM URL: https://package.openupm.com Scope(s): org.nuget
unityメイン/PackageManager/MyRegistoryでMicrosoft.NET.StringTools検索してインストール
mpcインストール
v2では必要。v3では不要。
netインストール(net7) https://dotnet.microsoft.com/ja-jp/download
mpcインストール
dotnet tool install --global MessagePack.Generator
Serializer.generated生成
$ mpc -i Assembly-CSharp.csproj -o ./Assets/Script/Serializer.generated.cs Project Compilation Start:Assembly-CSharp Project Compilation Complete:00:00:00.1201760 Method Collect Start Method Collect Complete:00:00:00.0297969 Output Generation Start [Out]./Assets/Script/Serializer.generated.cs Output Generation Complete:00:00:00.0046382
参考:https://limegame.hatenablog.com/entry/2023/05/30/164100
mpc実行で"Developer Pack をダウンロードして"とエラーが出た場合
/usr/local/share/dotnet/sdk/6.0.427/Microsoft.Common.CurrentVersion.targets(1220,5): error MSB3644: .NETFramework,Version=v4.7.1 の参照アセンブリが見つかりませんでした。この問題を解決するには、このフレームワーク バージョンの Developer Pack (SDK/Targeting Pack) をインストールするか、アプリケーションのターゲットを再設定してください。https://aka.ms/msbuild/developerpacks で .NET Framework Developer Pack をダウンロードできます。
以下のCodeGeneratorを使ってみる。
CodeGeneratorを使う
unityメインメニュー/Window/MessagePack/CodeGenerator
Assets/Scripts/MessagePack/Unity/MessagePackWindow.cs の以下部分を変更すると、CodeGeneratorが、macで、ちゃんと出たし、Generateもできた。
-ProcessStartAsync("dotnet", "tool list -g"); +ProcessStartAsync("/usr/local/share/dotnet/dotnet", "tool list -g"); -var log = await ProcessHelper.InvokeProcessStartAsync("mpc", commnadLineArguments); +var log = await ProcessHelper.InvokeProcessStartAsync("/Users/account1/.dotnet/tools/mpc", commnadLineArguments);
入力
-i input path ../Assembly-CSharp.csproj -o output filepath Scripts/Serializer.generated.cs
出力
Generate MessagePack Files, command:-i ../Assembly-CSharp.csproj -o Scripts/Serializer.generated.cs UnityEngine.Debug:Log (object)
出力ログは出るけど、ファイルはできなかった・・。なぜだろう・・。やってることは、上のmpcコマンド処理と同じなので、そちらが動いてファイルができてれば問題ない。
参考:https://qiita.com/IShix/items/490c3670ad771adb3c3d
dotnetインストール
https://dotnet.microsoft.com/ja-jp/download
% dotnet --list-sdks 9.0.203 [/usr/local/share/dotnet/sdk]
dotnetのpath確認
$ which dotnet /usr/local/share/dotnet/dotnet
mpcのpath確認
$ which mpc /Users/account1/.dotnet/tools/mpc
MessagePackサンプル
User.cs
using MessagePack; [MessagePackObject] public class User { [Key(0)] public string Name { get; set; } [Key(1)] public int Age { get; set; } }
処理
var user = new User(); user.Name = "taro"; user.Age = 10; var serialized = MessagePackSerializer.Serialize(user); Debug.Log("シリアライズされたデータ\n" + BitConverter.ToString(serialized)); var deserialized = MessagePackSerializer.Deserialize<User>(serialized); Debug.Log("デシリアライズされたデータ\n" + deserialized.Name + " Age=" + deserialized.Age);
出力
シリアライズされたデータ 92-A4-74-61-72-6F-0A デシリアライズされたデータ taro Age=10
オプション設定追加
sample
StaticCompositeResolver.Instance.Register( MessagePack.Unity.UnityResolver.Instance, MessagePack.Unity.Extension.UnityBlitWithPrimitiveArrayResolver.Instance, MessagePack.Resolvers.StandardResolver.Instance ); var options = MessagePackSerializerOptions.Standard.WithResolver(StaticCompositeResolver.Instance); MessagePackSerializer.DefaultOptions = options;
公式より:https://github.com/MessagePack-CSharp/MessagePack-CSharp