Embed link.xml in UPM package (Unity3D)
#guide #unity #unity3d #upm #il2cpp
In Unity (the game engine) you can tell the compiler not to strip away certain parts of your code, or to “preserve” it to use the correct term. You do this either with a
[Preserve] attribute, or with a
Up until recently, it was unknown how to include such a
link.xml file inside your UPM packages, as it had not been documented. Big thanks to maksimbu over at the Unity forums who did the most RnD here.
You have two main options:
Add a section to your
README.mdtelling your users to create a
link.xmlfile themselves in their
Assets/directory and add given content you specify.
link.xmlinside a precompiled assembly (DLL) inside your package.
We will be going through option 2.
Create a .NET project, if you don't have one already. (Can be C#, F#, VB, whatever, as long as it has a
link.xmlfile to your project. Recommended to place it at
Add the following to your
<ItemGroup> <EmbeddedResource Include="Resources\link.xml"> <LogicalName>MyAssemblyName.xml</LogicalName> </EmbeddedResource> </ItemGroup>
The file must be an embedded resource, and if you omit the
<LogicalName>property then the resource will get a generated name with the assembly name prefixed on the files name. Even if you name your file
<LogicalName>that embedded resource will then have the name
MyAssemblyName.MyAssemblyName.xml, which Unity will then not find.
MyAssemblyNamewith the name of your assembly.
Compile and include the DLL in your package. For most cases, you can precompile all your C# code you would anyway include into your package to get much faster compiling and loading for the user, at the cost of a little bigger package size.
The above solution is used in my package Newtonsoft.Json-for-Unity, as can be seen here: https://github.com/jilleJr/Newtonsoft.Json-for-Unity/blob/bfd8ab8/Src/Newtonsoft.Json/Resources/link.xml
Have a great dane!~~