-
Notifications
You must be signed in to change notification settings - Fork 48
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[BUG] Internal Utf8Json is incompatible with ILLink trimming #370
Comments
@andresanscartier Very interesting that this is iOS specific, I haven't done any development on .NET targeting iOS yet, I'll try to have a go at reproducing this. In the meantime if you're able to share a minimal reproducing project that'd be great, and is this reproducible inside a device emulator or only on hardware? |
@Xtansia |
@Xtansia Not sure if this is related, but ElasticSearch seems to have had a similar issue with its Net.Utf8Json.Resolvers.DynamicCompositeResolver_??? which was also constantly changing name and causing bad behaviors. Here is the link to this issue. Do you still need a project example ? Best regards |
@andresanscartier The issue linked appears to be a different issue and relates to their renaming of assemblies and is from before OpenSearch's fork so is in the history of this repo. Your note about "Link Everthing" being the issue has pointed me in the right direction and I'm now able to repro, I have some suspicions about what's happening so will do some more digging and then return with my findings |
So the issue seems to be that even you flag the I'm still investigating, but have not yet found any solution other than turning down the link level, or modifying the library to make the internals of Utf8Json public which would not be ideal. |
@Xtansia Best regards |
Hi @Xtansia |
My reasoning isn't about any adverse side effects, my concerns are more around if we made such a modification in the library proper, Utf8Json now becomes part of the library's public API surface and so has implications around support for end-users interacting with it along with semver commitments |
Hey @andresanscartier! Just following up here with an update. In the meantime I've managed to create an MSBuild task you could use to work around this, basically just lets you specify assemblies to have their You'd basically just the below into your csproj: <Project>
<!-- ... SNIP ... -->
<ItemGroup>
<PackageReference Include="Xtansia.IvtPatch" Version="1.0.0" />
</ItemGroup>
<ItemGroup>
<IvtPatchAssembly Include="OpenSearch.Client" />
<IvtPatchAssembly Include="OpenSearch.Net" />
</ItemGroup>
</Project> And then add then make sure your <linker>
<assembly fullname="OpenSearch.Net" preserve="all" />
<assembly fullname="OpenSearch.Client" preserve="all" />
</linker> |
Hi @Xtansia, |
What is the bug?
With IOS nuget OpenSearch.CLient 1.5.0 the "new ConnectionSettings(uri)" method crash with MethodAccessException error.
How can one reproduce the bug?
Try ConnectionSettings with (Uri uri = null, IConnection connection = null) signature.
What is your host/environment?
JetBrains Rider 2023.2.1
Build #RD-232.9559.61, built on August 22, 2023
Runtime version: 17.0.8+7-b1000.8 x86_64
VM: OpenJDK 64-Bit Server VM by JetBrains s.r.o.
macOS 13.0.1
.NET Core v7.0.7 x64 (Server GC)
IOS IPad 16.3.1
Do you have any additional context?
This code works well on Windows, Mac, Android and Linux but crash at the new ConnectionSettings on IOS.
With this error:
System.MethodAccessException: Method
OpenSearch.Net.Utf8Json.Resolvers.DynamicCompositeResolver..ctor(OpenSearch.Net.Utf8Json.IJsonFormatter[],OpenSearch.Net.Utf8Json.IJsonFormatterResolver[])' is inaccessible from method
DynamicCompositeResolver_868f210720364292b1ea67d7111b98de..ctor(OpenSearch.Net.Utf8Json.IJsonFormatter[],OpenSearch.Net.Utf8Json.IJsonFormatterResolver[])'at DynamicCompositeResolver_868f210720364292b1ea67d7111b98de..ctor(IJsonFormatter[] , IJsonFormatterResolver[] )
at System.Reflection.RuntimeConstructorInfo.InternalInvoke(Object , Object[] , Boolean )
at System.Reflection.RuntimeConstructorInfo.DoInvoke(Object , BindingFlags , Binder , Object[] , CultureInfo )
at System.Reflection.RuntimeConstructorInfo.Invoke(BindingFlags , Binder , Object[] , CultureInfo )
at System.RuntimeType.CreateInstanceImpl(BindingFlags , Binder , Object[] , CultureInfo )
at System.Activator.CreateInstance(Type type, BindingFlags bindingAttr, Binder binder, Object[] args, CultureInfo culture, Object[] activationAttributes)
at System.Activator.CreateInstance(Type type, Object[] args)
at OpenSearch.Net.Utf8Json.Resolvers.DynamicCompositeResolver.Create(IJsonFormatter[] , IJsonFormatterResolver[] )
at OpenSearch.Client.OpenSearchClientFormatterResolver.InnerResolver..cctor()
The text was updated successfully, but these errors were encountered: