question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

Xamarin NLogLoggerProvider linker error

See original GitHub issue

Type: Bug

NLog version: 4.6.8 NLog.Extensions.Logging version: 1.6.2 NLog.Web.AspNetCore version: not used

Platform: Xamarin Android / Xamarin iOS

  • What is the current result? Using NLogLoggerProvider in a Release build (Link SDK assemblies enabled) on either platform results in a Linker error. I don’t know enough to guess whether it’s an issue in how this extension library is referencing classes from NLog, or if the Xamarin iOS/Android linkers are resulting in very similar issues due to common logic.

  • Are there any work arounds? yes Disabling linking globally does work, but not ideal for publishing apps. There may be a way to avoid the issue with linker exclusions, haven’t had any luck there though. Quick workaround has been to clone the library and remove the NLogLogger::BeginScope logic & parser.

  • To reproduce issue (tested in Visual Studio Mac with latest updates) Create new Xamarin iOS / Android project Add latest NLog.Extensions.Logging package Add code to create an instance of NLogLoggerProvider Rebuild in release mode (Link SDK Frameworks/Assemblies enabled).

  • Exception details (message, stacktrace, inner exceptions)

Xamarin.iOS

MTOUCH : error MT2101: Can’t resolve the reference ‘System.IDisposable NLog.MappedDiagnosticsLogicalContext::SetScoped(System.Collections.Generic.IReadOnlyList1<System.Collections.Generic.KeyValuePair2<System.String,System.Object>>)’, referenced from the method ‘System.IDisposable NLog.Extensions.Logging.NLogBeginScopeParser/ScopeProperties::CreateScopeProperties(System.Object,System.Collections.Generic.IReadOnlyList1<System.Collections.Generic.KeyValuePair2<System.String,System.Object>>)’ in ‘NLog, Version=4.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c’.

Xamarin.Android

error XALNK7000: Mono.Linker.MarkException: Error processing method: ‘System.IDisposable NLog.Extensions.Logging.NLogBeginScopeParser/ScopeProperties::CreateScopeProperties(System.Object,System.Collections.Generic.IReadOnlyList1<System.Collections.Generic.KeyValuePair2<System.String,System.Object>>)’ in assembly: ‘NLog.Extensions.Logging.dll’ —> Mono.Cecil.ResolutionException: Failed to resolve System.IDisposable NLog.MappedDiagnosticsLogicalContext::SetScoped(System.Collections.Generic.IReadOnlyList1<System.Collections.Generic.KeyValuePair2<System.String,System.Object>>)

Issue Analytics

  • State:closed
  • Created 3 years ago
  • Reactions:1
  • Comments:6 (5 by maintainers)

github_iconTop GitHub Comments

2reactions
304NotModifiedcommented, May 15, 2020

This is fixed with the release of NLog 4.7.1, which is now live 😃

2reactions
snakefootcommented, Apr 19, 2020

Thank you for the quick response. It is very strange that the LInker changes from NetStandard to Xamarin build when compiling to near native code.

Read more comments on GitHub >

github_iconTop Results From Across the Web

Xamarin Android Linker Error when Linking is On, and ...
In my visual Studio i have reached a point for my Xamarin Forms project, where i cannot build it, neither in debug or...
Read more >
how do I resolve native linking failed after updating VS for ...
I updated to VS for Mac version 8.9.4. Xamarin.iOS version 14.14.2.5 and now I get native linking failed errors. I have linker behavior...
Read more >
Mono.Linker Error With Xamarin Android
Error The "LinkAssemblies" task failed unexpectedly. Mono.Linker.MarkException: Error processing method: 'System.Void FAB.Droid.
Read more >
Investing Time in the Xamarin Linker for Smaller App Sizes
With these tips & tricks you can use the Xamarin linker to shrink your application size in no time at all.
Read more >
Fixing Xamarin.Forms linker issues - Progrunning
The solution. To fix Xamarin.Forms linker related issues one needs to instruct it to keep the code that shouldn't be stripped out. There...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found