Skip to content
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

Try to get the control catalog working in NativeAOT builds #423

Merged
merged 2 commits into from
Sep 24, 2024

Conversation

Numpsy
Copy link
Collaborator

@Numpsy Numpsy commented May 8, 2024

The main issue besides the dynamically loaded xaml being trimmed out (avoided for now by rooting the control catalog assembly) is that it seems to not like using sprintf in views, e.g.

Unhandled Exception: System.NotSupportedException: 'Microsoft.FSharp.Core.PrintfImpl+Specializations`3[Microsoft.FSharp.Core.Unit,System.String,System.String].CaptureFinal1[System.Int32](Microsoft.FSharp.Core.PrintfImpl+Step[])' is missing native code. MethodInfo.MakeGenericMethod() is not compatible with AOT compilation. Inspect and fix AOT related warnings that were generated when the app was published. For more information see https://aka.ms/nativeaot-compatibility
   at System.Reflection.Runtime.MethodInfos.RuntimeNamedMethodInfo`1.GetUncachedMethodInvoker(RuntimeTypeInfo[], MemberInfo) + 0x2f
   at System.Reflection.Runtime.MethodInfos.RuntimeNamedMethodInfo`1.MakeGenericMethod(Type[]) + 0x189
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.buildCaptureFunc[a](PrintfImpl.FormatSpecifier, a, Type[], Type, Tuple`5) + 0x21b
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.parseAndCreateFuncFactoryAux(FSharpList`1, String, Type, Int32&) + 0x22c
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.parseAndCreateFunctionFactory() + 0x78
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.GetCurriedPrinterFactory() + 0x1f
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.GetCurriedStringPrinter() + 0x20
   at Avalonia.FuncUI.ControlCatalog.Views.DataTemplateDemo.view(DataTemplateDemo.State state, FSharpFunc`2 dispatch) + 0xae
   at Avalonia.FuncUI.ControlCatalog.Views.MainView.view(MainView.CounterState state, FSharpFunc`2 dispatch) + 0x64e
   at [email protected](model, FSharpFunc`2) + 0x78
   at Elmish.ProgramModule.runWithDispatch[msg,arg,model,view](FSharpFunc`2, arg, Program`4) + 0x200
   at Avalonia.FuncUI.ControlCatalog.App.OnFrameworkInitializationCompleted() + 0x11c
   at Avalonia.ClassicDesktopStyleApplicationLifetimeExtensions.StartWithClassicDesktopLifetime(AppBuilder, String[], Action`1) + 0x2f
   at Avalonia.FuncUI.ControlCatalog.Desktop!<BaseAddress>+0xa51d70
Unhandled Exception: System.Reflection.TargetInvocationException: Exception has been thrown by the target of an invocation.
 ---> System.NotSupportedException: 'Microsoft.FSharp.Core.PrintfImpl+Specializations`3[Microsoft.FSharp.Core.Unit,System.String,System.String].CaptureFinal1[System.Int32](Microsoft.FSharp.Core.PrintfImpl+Step[])' is missing native code. MethodInfo.MakeGenericMethod() is not compatible with AOT compilation. Inspect and fix AOT related warnings that were generated when the app was published. For more information see https://aka.ms/nativeaot-compatibility
   at System.Reflection.Runtime.MethodInfos.RuntimeNamedMethodInfo`1.GetUncachedMethodInvoker(RuntimeTypeInfo[], MemberInfo) + 0x2f
   at System.Reflection.Runtime.MethodInfos.RuntimeNamedMethodInfo`1.MakeGenericMethod(Type[]) + 0x189
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.buildCaptureFunc[a](PrintfImpl.FormatSpecifier, a, Type[], Type, Tuple`5) + 0x21b
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.parseAndCreateFuncFactoryAux(FSharpList`1, String, Type, Int32&) + 0x22c
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.parseAndCreateFunctionFactory() + 0x78
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.GetCurriedPrinterFactory() + 0x1f
   at Microsoft.FSharp.Core.PrintfImpl.FormatParser`4.GetCurriedStringPrinter() + 0x20
   at Avalonia.FuncUI.ControlCatalog.Views.GridDemo.view(GridDemo.State state, FSharpFunc`2 dispatch) + 0x52c

But changing those to use interpolated strings rather than sprintf seems to fix it - after that it seems to run ok (On Windows at least - haven't tried it on anything else yet)

@Numpsy
Copy link
Collaborator Author

Numpsy commented Jul 23, 2024

Running an AOT build of the control catalog on top of the .NET 8 changes seems to all work on Windows except that the drag drop demo page doesn't do drag/drop inside the page (dragging a file from explorer into the drop target does work though).

Not sure if that's an issue here or in Avalonia.

@Numpsy
Copy link
Collaborator Author

Numpsy commented Jul 24, 2024

Ok, replacing another sprintf seems to have fixed that (not sure why there were no visible exceptions like there were for the other instances - does the Elmish async machinery eat them?)

dragdrop

@Numpsy
Copy link
Collaborator Author

Numpsy commented Jul 24, 2024

The sprintf thing seems enough of a theme to make a pass over the code and replace any remaining ones that aren't doing partial application and such with interpolations.

@JaggerJo
Copy link
Member

@Numpsy what's the current state of this PR? should we merge this?

@Numpsy
Copy link
Collaborator Author

Numpsy commented Sep 22, 2024

It seemed to be working last time I tried.
(Maybe there's still scope for having a pass over the whole thing seperately to see if there are any other sprintf usages that could use interpolations though)

@JaggerJo JaggerJo merged commit f156f6e into fsprojects:master Sep 24, 2024
1 check passed
@Numpsy Numpsy deleted the catalog_aot branch September 24, 2024 09:06
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants