From 445dc210816981a1367e6d3ef086d64bb8e386fb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wies=C5=82aw=20=C5=A0olt=C3=A9s?= Date: Tue, 16 Aug 2016 16:12:52 +0200 Subject: [PATCH 01/35] Removed no longer necessary nuget folder --- nuget/.gitignore | 2 - nuget/build-appveyor.ps1 | 35 --------- nuget/build-version.ps1 | 84 --------------------- nuget/build.ps1 | 1 - nuget/include.ps1 | 1 - nuget/template/Avalonia.Android.nuspec | 28 ------- nuget/template/Avalonia.Desktop.nuspec | 30 -------- nuget/template/Avalonia.Skia.Desktop.nuspec | 20 ----- nuget/template/Avalonia.iOS.nuspec | 27 ------- nuget/template/Avalonia.nuspec | 26 ------- 10 files changed, 254 deletions(-) delete mode 100644 nuget/.gitignore delete mode 100644 nuget/build-appveyor.ps1 delete mode 100644 nuget/build-version.ps1 delete mode 100644 nuget/build.ps1 delete mode 100644 nuget/include.ps1 delete mode 100644 nuget/template/Avalonia.Android.nuspec delete mode 100644 nuget/template/Avalonia.Desktop.nuspec delete mode 100644 nuget/template/Avalonia.Skia.Desktop.nuspec delete mode 100644 nuget/template/Avalonia.iOS.nuspec delete mode 100644 nuget/template/Avalonia.nuspec diff --git a/nuget/.gitignore b/nuget/.gitignore deleted file mode 100644 index 32f9557fad..0000000000 --- a/nuget/.gitignore +++ /dev/null @@ -1,2 +0,0 @@ -Avalonia -*.nupkg \ No newline at end of file diff --git a/nuget/build-appveyor.ps1 b/nuget/build-appveyor.ps1 deleted file mode 100644 index 1441a6a79a..0000000000 --- a/nuget/build-appveyor.ps1 +++ /dev/null @@ -1,35 +0,0 @@ -$ErrorActionPreference = "Stop" -$scriptpath = $MyInvocation.MyCommand.Path -$dir = Split-Path $scriptpath -Push-Location $dir - - -sv version $env:APPVEYOR_BUILD_NUMBER -#sv version "1-debug" - -sv version 0.4.1-build$version-alpha -sv key $env:myget_key - -. ".\include.ps1" -.\build-version.ps1 $version - -sv reponame $env:APPVEYOR_REPO_NAME -sv repobranch $env:APPVEYOR_REPO_BRANCH -sv pullreq $env:APPVEYOR_PULL_REQUEST_NUMBER - -echo "Checking for publishing" -echo "$reponame $repobranch $pullreq" -if ([string]::IsNullOrWhiteSpace($pullreq)) -{ - echo "Build is not a PR" - if($repobranch -eq "master") - { - echo "Repo branch matched" - foreach($pkg in $Packages) - { - nuget.exe push "$($pkg).$($version).nupkg" $key -Source https://www.myget.org/F/avalonia-ci/api/v2/package - } - } -} - - diff --git a/nuget/build-version.ps1 b/nuget/build-version.ps1 deleted file mode 100644 index c59789ddb8..0000000000 --- a/nuget/build-version.ps1 +++ /dev/null @@ -1,84 +0,0 @@ -$ErrorActionPreference = "Stop" - -. ".\include.ps1" - -foreach($pkg in $Packages) -{ - rm -Force -Recurse .\$pkg -ErrorAction SilentlyContinue -} - -rm -Force -Recurse *.nupkg -ErrorAction SilentlyContinue -Copy-Item template Avalonia -Recurse -sv lib "Avalonia\lib\portable-windows8+net45" -sv build "Avalonia.Desktop\lib\net45" - -sv skia_root "Avalonia.Skia.Desktop" -sv skia_lib "Avalonia.Skia.Desktop\lib\net45" -sv android "Avalonia.Android\lib\MonoAndroid10" -sv ios "Avalonia.iOS\lib\Xamarin.iOS10" - -mkdir $lib -ErrorAction SilentlyContinue -mkdir $build -ErrorAction SilentlyContinue -mkdir $skia_lib -mkdir $android -mkdir $ios - - -Copy-Item ..\src\Avalonia.Animation\bin\Release\Avalonia.Animation.dll $lib -Copy-Item ..\src\Avalonia.Animation\bin\Release\Avalonia.Animation.xml $lib -Copy-Item ..\src\Avalonia.Base\bin\Release\Avalonia.Base.dll $lib -Copy-Item ..\src\Avalonia.Base\bin\Release\Avalonia.Base.xml $lib -Copy-Item ..\src\Avalonia.Controls\bin\Release\Avalonia.Controls.dll $lib -Copy-Item ..\src\Avalonia.Controls\bin\Release\Avalonia.Controls.xml $lib -Copy-Item ..\src\Avalonia.DesignerSupport\bin\Release\Avalonia.DesignerSupport.dll $lib -Copy-Item ..\src\Avalonia.DesignerSupport\bin\Release\Avalonia.DesignerSupport.xml $lib -Copy-Item ..\src\Avalonia.Diagnostics\bin\Release\\Avalonia.Diagnostics.dll $lib -Copy-Item ..\src\Avalonia.Diagnostics\bin\Release\\Avalonia.Diagnostics.xml $lib -Copy-Item ..\src\Avalonia.Input\bin\Release\Avalonia.Input.dll $lib -Copy-Item ..\src\Avalonia.Input\bin\Release\Avalonia.Input.xml $lib -Copy-Item ..\src\Avalonia.Interactivity\bin\Release\Avalonia.Interactivity.dll $lib -Copy-Item ..\src\Avalonia.Interactivity\bin\Release\Avalonia.Interactivity.xml $lib -Copy-Item ..\src\Avalonia.Layout\bin\Release\Avalonia.Layout.dll $lib -Copy-Item ..\src\Avalonia.Layout\bin\Release\Avalonia.Layout.xml $lib -Copy-Item ..\src\Avalonia.Logging.Serilog\bin\Release\Avalonia.Logging.Serilog.dll $lib -Copy-Item ..\src\Avalonia.Logging.Serilog\bin\Release\Avalonia.Logging.Serilog.xml $lib -Copy-Item ..\src\Avalonia.SceneGraph\bin\Release\Avalonia.SceneGraph.dll $lib -Copy-Item ..\src\Avalonia.SceneGraph\bin\Release\Avalonia.SceneGraph.xml $lib -Copy-Item ..\src\Avalonia.Styling\bin\Release\Avalonia.Styling.dll $lib -Copy-Item ..\src\Avalonia.Styling\bin\Release\Avalonia.Styling.xml $lib -Copy-Item ..\src\Avalonia.Themes.Default\bin\Release\Avalonia.Themes.Default.dll $lib -Copy-Item ..\src\Avalonia.Themes.Default\bin\Release\Avalonia.Themes.Default.xml $lib -Copy-Item ..\src\Markup\Avalonia.Markup\bin\Release\Avalonia.Markup.dll $lib -Copy-Item ..\src\Markup\Avalonia.Markup\bin\Release\Avalonia.Markup.xml $lib -Copy-Item ..\src\Markup\Avalonia.Markup.Xaml\bin\Release\Avalonia.Markup.Xaml.dll $lib -Copy-Item ..\src\Markup\Avalonia.Markup.Xaml\bin\Release\Avalonia.Markup.Xaml.xml $lib -Copy-Item ..\src\Avalonia.HtmlRenderer\bin\Release\Avalonia.HtmlRenderer.dll $lib -Copy-Item ..\src\Avalonia.ReactiveUI\bin\Release\Avalonia.ReactiveUI.dll $lib - -Copy-Item ..\src\Windows\Avalonia.Direct2D1\bin\Release\Avalonia.Direct2D1.dll $build -Copy-Item ..\src\Windows\Avalonia.Win32\bin\Release\Avalonia.Win32.dll $build -Copy-Item ..\src\Gtk\Avalonia.Gtk\bin\Release\Avalonia.Gtk.dll $build -Copy-Item ..\src\Gtk\Avalonia.Cairo\bin\Release\Avalonia.Cairo.dll $build - -Copy-Item ..\src\Skia\Avalonia.Skia.Desktop\bin\x86\Release\Avalonia.Skia.Desktop.dll $skia_lib - -Copy-Item ..\src\Android\Avalonia.Android\bin\Release\Avalonia.Android.dll $android -Copy-Item ..\src\Skia\Avalonia.Skia.Android\bin\Release\Avalonia.Skia.Android.dll $android - -Copy-Item ..\src\iOS\Avalonia.iOS\bin\iPhone\Release\Avalonia.iOS.dll $ios -Copy-Item ..\src\Skia\Avalonia.Skia.iOS\bin\iPhone\Release\Avalonia.Skia.iOS.dll $ios - -foreach($pkg in $Packages) -{ - (gc Avalonia\$pkg.nuspec).replace('#VERSION#', $args[0]) | sc $pkg\$pkg.nuspec -} - -foreach($pkg in $Packages) -{ - nuget.exe pack $pkg\$pkg.nuspec -} - -foreach($pkg in $Packages) -{ - rm -Force -Recurse .\$pkg -} \ No newline at end of file diff --git a/nuget/build.ps1 b/nuget/build.ps1 deleted file mode 100644 index 43c3748bdf..0000000000 --- a/nuget/build.ps1 +++ /dev/null @@ -1 +0,0 @@ -.\build-version.ps1 0.4.1 \ No newline at end of file diff --git a/nuget/include.ps1 b/nuget/include.ps1 deleted file mode 100644 index bde8ebb731..0000000000 --- a/nuget/include.ps1 +++ /dev/null @@ -1 +0,0 @@ -$Packages = @("Avalonia", "Avalonia.Desktop", "Avalonia.Skia.Desktop", "Avalonia.Android", "Avalonia.iOS") \ No newline at end of file diff --git a/nuget/template/Avalonia.Android.nuspec b/nuget/template/Avalonia.Android.nuspec deleted file mode 100644 index cdba3b5b0e..0000000000 --- a/nuget/template/Avalonia.Android.nuspec +++ /dev/null @@ -1,28 +0,0 @@ - - - - Avalonia.Android - #VERSION# - Avalonia Team - stevenk - http://opensource.org/licenses/MIT - https://github.com/AvaloniaUI/Avalonia/ - false - The Avalonia UI framework - - Copyright 2015 - Avalonia - - - - - - - - - - - - - - \ No newline at end of file diff --git a/nuget/template/Avalonia.Desktop.nuspec b/nuget/template/Avalonia.Desktop.nuspec deleted file mode 100644 index 70bebd3349..0000000000 --- a/nuget/template/Avalonia.Desktop.nuspec +++ /dev/null @@ -1,30 +0,0 @@ - - - - Avalonia.Desktop - #VERSION# - Avalonia Team - stevenk - http://opensource.org/licenses/MIT - https://github.com/AvaloniaUI/Avalonia/ - false - The Avalonia UI framework - - Copyright 2015 - Avalonia - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/nuget/template/Avalonia.Skia.Desktop.nuspec b/nuget/template/Avalonia.Skia.Desktop.nuspec deleted file mode 100644 index 928b6d3e24..0000000000 --- a/nuget/template/Avalonia.Skia.Desktop.nuspec +++ /dev/null @@ -1,20 +0,0 @@ - - - - Avalonia.Skia.Desktop - #VERSION# - Avalonia Team - stevenk - http://opensource.org/licenses/MIT - https://github.com/AvaloniaUI/Avalonia/ - false - The Avalonia UI framework - - Copyright 2015 - Avalonia - - - - - - \ No newline at end of file diff --git a/nuget/template/Avalonia.iOS.nuspec b/nuget/template/Avalonia.iOS.nuspec deleted file mode 100644 index d6b8e3fbe6..0000000000 --- a/nuget/template/Avalonia.iOS.nuspec +++ /dev/null @@ -1,27 +0,0 @@ - - - - Avalonia.iOS - #VERSION# - Avalonia Team - stevenk - http://opensource.org/licenses/MIT - https://github.com/AvaloniaUI/Avalonia/ - false - The Avalonia UI framework - - Copyright 2015 - Avalonia - - - - - - - - - - - - - \ No newline at end of file diff --git a/nuget/template/Avalonia.nuspec b/nuget/template/Avalonia.nuspec deleted file mode 100644 index 55918715a1..0000000000 --- a/nuget/template/Avalonia.nuspec +++ /dev/null @@ -1,26 +0,0 @@ - - - - Avalonia - #VERSION# - Avalonia Team - stevenk - http://opensource.org/licenses/MIT - https://github.com/AvaloniaUI/Avalonia/ - false - The Avalonia UI framework - Initial alpha release. - Copyright 2015 - Avalonia - - - - - - - - - - - - \ No newline at end of file From 7cca79b4352d82e4e2ed407e2d7218c6d9d31978 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wies=C5=82aw=20=C5=A0olt=C3=A9s?= Date: Tue, 16 Aug 2016 16:13:31 +0200 Subject: [PATCH 02/35] Updated projects and packages --- samples/BindingTest/BindingTest.csproj | 8 ++-- samples/BindingTest/packages.config | 5 ++- samples/ControlCatalog.Desktop/App.config | 8 ++-- .../ControlCatalog.Desktop.csproj | 10 ++--- .../ControlCatalog.Desktop/packages.config | 3 +- .../ControlCatalog.iOS.csproj | 10 +++++ samples/ControlCatalog.iOS/packages.config | 17 ++++++++ samples/ControlCatalog/ControlCatalog.csproj | 9 ++++ samples/ControlCatalog/packages.config | 13 +++++- .../TestApplication/TestApplication.csproj | 8 +--- samples/TestApplication/packages.config | 2 +- samples/VirtualizationTest/App.config | 8 ++-- .../VirtualizationTest.csproj | 8 ++-- samples/VirtualizationTest/packages.config | 9 ++-- .../XamlTestApplication.csproj | 12 +++--- samples/XamlTestApplication/packages.config | 5 ++- .../Avalonia.AndroidTestApplication.csproj | 9 ++-- .../packages.config | 8 +++- src/Avalonia.Base/Avalonia.Base.csproj | 4 +- src/Avalonia.Base/packages.config | 2 +- .../Avalonia.Controls.csproj | 4 +- src/Avalonia.Controls/packages.config | 2 +- .../Avalonia.Logging.Serilog.csproj | 18 ++++---- src/Avalonia.Logging.Serilog/packages.config | 13 +++++- src/Avalonia.Styling/Avalonia.Styling.csproj | 1 - .../Avalonia.Markup.Xaml.csproj | 4 +- .../Avalonia.Markup.Xaml/packages.config | 2 +- .../Avalonia.Skia.Android.TestApp.csproj | 4 ++ .../Resources/Resource.Designer.cs | 2 + .../Avalonia.Skia.iOS.TestApp.csproj | 8 +++- .../Avalonia.Designer.csproj | 6 +-- src/Windows/Avalonia.Designer/packages.config | 2 +- .../Avalonia.Base.UnitTests.csproj | 8 +++- tests/Avalonia.Base.UnitTests/packages.config | 3 +- tests/Avalonia.Benchmarks/App.config | 2 +- .../Avalonia.Benchmarks.csproj | 43 +++++++++++++++---- tests/Avalonia.Benchmarks/packages.config | 23 ++++++++-- .../Avalonia.Controls.UnitTests.csproj | 16 ++++--- tests/Avalonia.Controls.UnitTests/app.config | 2 +- .../packages.config | 7 +-- .../App.config | 6 +-- .../Avalonia.DesignerSupport.TestApp.csproj | 4 +- .../Properties/Resources.Designer.cs | 42 ++++++++---------- .../Properties/Settings.Designer.cs | 22 ++++------ .../Avalonia.DesignerSupport.Tests.csproj | 3 +- .../Avalonia.Input.UnitTests.csproj | 8 +++- .../Avalonia.Input.UnitTests/packages.config | 3 +- .../Avalonia.Layout.UnitTests.csproj | 16 ++++--- tests/Avalonia.Layout.UnitTests/app.config | 4 +- .../Avalonia.Layout.UnitTests/packages.config | 7 +-- .../Avalonia.LeakTests.csproj | 18 +++++--- tests/Avalonia.LeakTests/app.config | 4 +- tests/Avalonia.LeakTests/packages.config | 9 ++-- .../Avalonia.Markup.UnitTests.csproj | 19 +++++--- tests/Avalonia.Markup.UnitTests/app.config | 8 ++-- .../Avalonia.Markup.UnitTests/packages.config | 27 ++++++------ .../Avalonia.Markup.Xaml.UnitTests.csproj | 14 +++--- .../Avalonia.Markup.Xaml.UnitTests/app.config | 8 ++-- .../packages.config | 5 ++- .../Avalonia.Cairo.RenderTests.csproj | 2 +- .../Avalonia.Direct2D1.RenderTests.csproj | 2 +- .../Avalonia.Skia.RenderTests.csproj | 2 +- .../Controls/ImageTests.cs | 12 ++++++ .../Media/ImageBrushTests.cs | 8 +++- ...packages.Avalonia.Cairo.RenderTests.config | 2 +- ...ages.Avalonia.Direct2D1.RenderTests.config | 2 +- .../packages.Avalonia.Skia.RenderTests.config | 2 +- .../Avalonia.SceneGraph.UnitTests.csproj | 8 +++- .../packages.config | 3 +- .../Avalonia.Styling.UnitTests.csproj | 8 +++- .../packages.config | 3 +- .../Avalonia.UnitTests.csproj | 8 +++- tests/Avalonia.UnitTests/packages.config | 3 +- 73 files changed, 396 insertions(+), 224 deletions(-) create mode 100644 samples/ControlCatalog.iOS/packages.config diff --git a/samples/BindingTest/BindingTest.csproj b/samples/BindingTest/BindingTest.csproj index 3ed2671d0a..5940f358ed 100644 --- a/samples/BindingTest/BindingTest.csproj +++ b/samples/BindingTest/BindingTest.csproj @@ -37,12 +37,12 @@ - - ..\..\packages\Serilog.1.5.14\lib\net45\Serilog.dll + + ..\..\packages\Serilog.2.1.0\lib\net45\Serilog.dll True - - ..\..\packages\Serilog.1.5.14\lib\net45\Serilog.FullNetFx.dll + + ..\..\packages\Serilog.Sinks.Trace.2.0.0\lib\net45\Serilog.Sinks.Trace.dll True diff --git a/samples/BindingTest/packages.config b/samples/BindingTest/packages.config index 3c5f85de81..96d41d13ba 100644 --- a/samples/BindingTest/packages.config +++ b/samples/BindingTest/packages.config @@ -1,7 +1,8 @@  - - + + + \ No newline at end of file diff --git a/samples/ControlCatalog.Desktop/App.config b/samples/ControlCatalog.Desktop/App.config index 7ef9d715f8..2231c71e63 100644 --- a/samples/ControlCatalog.Desktop/App.config +++ b/samples/ControlCatalog.Desktop/App.config @@ -1,13 +1,13 @@ - + - + - - + + diff --git a/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj b/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj index f42902b534..e363bea129 100644 --- a/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj +++ b/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj @@ -34,12 +34,12 @@ 4 - - ..\..\packages\Serilog.1.5.14\lib\net45\Serilog.dll + + ..\..\packages\Serilog.2.1.0\lib\net45\Serilog.dll True - - ..\..\packages\Serilog.1.5.14\lib\net45\Serilog.FullNetFx.dll + + ..\..\packages\Serilog.Sinks.Trace.2.0.0\lib\net45\Serilog.Sinks.Trace.dll True @@ -54,10 +54,10 @@ - + diff --git a/samples/ControlCatalog.Desktop/packages.config b/samples/ControlCatalog.Desktop/packages.config index b3abe6f487..9f7215928e 100644 --- a/samples/ControlCatalog.Desktop/packages.config +++ b/samples/ControlCatalog.Desktop/packages.config @@ -1,4 +1,5 @@  - + + \ No newline at end of file diff --git a/samples/ControlCatalog.iOS/ControlCatalog.iOS.csproj b/samples/ControlCatalog.iOS/ControlCatalog.iOS.csproj index 0e85a4e865..73d430e2b6 100644 --- a/samples/ControlCatalog.iOS/ControlCatalog.iOS.csproj +++ b/samples/ControlCatalog.iOS/ControlCatalog.iOS.csproj @@ -90,8 +90,18 @@ + + + + ..\..\packages\Serilog.2.0.0\lib\netstandard1.3\Serilog.dll + True + + + ..\..\packages\Serilog.Sinks.Trace.2.0.0\lib\netstandard1.3\Serilog.Sinks.Trace.dll + True + diff --git a/samples/ControlCatalog.iOS/packages.config b/samples/ControlCatalog.iOS/packages.config new file mode 100644 index 0000000000..7c0b68fc9a --- /dev/null +++ b/samples/ControlCatalog.iOS/packages.config @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/samples/ControlCatalog/ControlCatalog.csproj b/samples/ControlCatalog/ControlCatalog.csproj index daa8b0901a..c8da292ad5 100644 --- a/samples/ControlCatalog/ControlCatalog.csproj +++ b/samples/ControlCatalog/ControlCatalog.csproj @@ -215,6 +215,15 @@ Designer + + + + + + ..\..\packages\Serilog.2.1.0\lib\netstandard1.0\Serilog.dll + True + + + \ No newline at end of file diff --git a/Avalonia.DotNetFrameworkRuntime/Properties/AssemblyInfo.cs b/Avalonia.DotNetFrameworkRuntime/Properties/AssemblyInfo.cs new file mode 100644 index 0000000000..f55d3056f6 --- /dev/null +++ b/Avalonia.DotNetFrameworkRuntime/Properties/AssemblyInfo.cs @@ -0,0 +1,36 @@ +using System.Reflection; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; + +// General Information about an assembly is controlled through the following +// set of attributes. Change these attribute values to modify the information +// associated with an assembly. +[assembly: AssemblyTitle("Avalonia.DotNetFrameworkRuntime")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("Avalonia.DotNetFrameworkRuntime")] +[assembly: AssemblyCopyright("Copyright © 2016")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// Setting ComVisible to false makes the types in this assembly not visible +// to COM components. If you need to access a type in this assembly from +// COM, set the ComVisible attribute to true on that type. +[assembly: ComVisible(false)] + +// The following GUID is for the ID of the typelib if this project is exposed to COM +[assembly: Guid("4a1abb09-9047-4bd5-a4ad-a055e52c5ee0")] + +// Version information for an assembly consists of the following four values: +// +// Major Version +// Minor Version +// Build Number +// Revision +// +// You can specify all the values or you can default the Build and Revision Numbers +// by using the '*' as shown below: +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/Avalonia.DotNetFrameworkRuntime/packages.config b/Avalonia.DotNetFrameworkRuntime/packages.config new file mode 100644 index 0000000000..1e93a8c9e7 --- /dev/null +++ b/Avalonia.DotNetFrameworkRuntime/packages.config @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/Avalonia.sln b/Avalonia.sln index a67f75991a..d2b5d9c0d6 100644 --- a/Avalonia.sln +++ b/Avalonia.sln @@ -163,6 +163,8 @@ Project("{D954291E-2A0B-460D-934E-DC6B0785DB48}") = "Avalonia.RenderTests", "tes EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "VirtualizationTest", "samples\VirtualizationTest\VirtualizationTest.csproj", "{FBCAF3D0-2808-4934-8E96-3F607594517B}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Avalonia.DotNetFrameworkRuntime", "Avalonia.DotNetFrameworkRuntime\Avalonia.DotNetFrameworkRuntime.csproj", "{4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}" +EndProject Global GlobalSection(SharedMSBuildProjectFiles) = preSolution src\Skia\Avalonia.Skia\Avalonia.Skia.projitems*{2f59f3d0-748d-4652-b01e-e0d954756308}*SharedItemsImports = 13 @@ -172,10 +174,9 @@ Global src\Shared\RenderHelpers\RenderHelpers.projitems*{47be08a7-5985-410b-9ffc-2264b8ea595f}*SharedItemsImports = 4 src\Skia\Avalonia.Skia\Avalonia.Skia.projitems*{47be08a7-5985-410b-9ffc-2264b8ea595f}*SharedItemsImports = 4 tests\Avalonia.RenderTests\Avalonia.RenderTests.projitems*{48840edd-24bf-495d-911e-2eb12ae75d3b}*SharedItemsImports = 13 - src\Shared\PlatformSupport\PlatformSupport.projitems*{54f237d5-a70a-4752-9656-0c70b1a7b047}*SharedItemsImports = 4 + src\Shared\PlatformSupport\PlatformSupport.projitems*{4a1abb09-9047-4bd5-a4ad-a055e52c5ee0}*SharedItemsImports = 4 samples\TestApplicationShared\TestApplicationShared.projitems*{78345174-5b52-4a14-b9fd-d5f2428137f0}*SharedItemsImports = 13 src\Shared\PlatformSupport\PlatformSupport.projitems*{7b92af71-6287-4693-9dcb-bd5b6e927e23}*SharedItemsImports = 4 - src\Shared\PlatformSupport\PlatformSupport.projitems*{811a76cf-1cf6-440f-963b-bbe31bd72a82}*SharedItemsImports = 4 src\Shared\PlatformSupport\PlatformSupport.projitems*{88060192-33d5-4932-b0f9-8bd2763e857d}*SharedItemsImports = 4 samples\TestApplicationShared\TestApplicationShared.projitems*{8c923867-8a8f-4f6b-8b80-47d9e8436166}*SharedItemsImports = 4 src\Shared\RenderHelpers\RenderHelpers.projitems*{925dd807-b651-475f-9f7c-cbeb974ce43d}*SharedItemsImports = 4 @@ -2242,6 +2243,46 @@ Global {FBCAF3D0-2808-4934-8E96-3F607594517B}.Release|Mono.Build.0 = Release|Any CPU {FBCAF3D0-2808-4934-8E96-3F607594517B}.Release|x86.ActiveCfg = Release|Any CPU {FBCAF3D0-2808-4934-8E96-3F607594517B}.Release|x86.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|Any CPU.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|Any CPU.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|iPhone.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|iPhone.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|iPhoneSimulator.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|iPhoneSimulator.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|Mono.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|Mono.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|x86.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Ad-Hoc|x86.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|Any CPU.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|Any CPU.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|iPhone.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|iPhone.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|iPhoneSimulator.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|iPhoneSimulator.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|Mono.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|Mono.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|x86.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.AppStore|x86.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|Any CPU.Build.0 = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|iPhone.ActiveCfg = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|iPhone.Build.0 = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|iPhoneSimulator.ActiveCfg = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|iPhoneSimulator.Build.0 = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|Mono.ActiveCfg = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|Mono.Build.0 = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|x86.ActiveCfg = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Debug|x86.Build.0 = Debug|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|Any CPU.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|Any CPU.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|iPhone.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|iPhone.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|iPhoneSimulator.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|iPhoneSimulator.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|Mono.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|Mono.Build.0 = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|x86.ActiveCfg = Release|Any CPU + {4A1ABB09-9047-4BD5-A4AD-A055E52C5EE0}.Release|x86.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/samples/BindingTest/BindingTest.csproj b/samples/BindingTest/BindingTest.csproj index 3ed2671d0a..1587f42ad5 100644 --- a/samples/BindingTest/BindingTest.csproj +++ b/samples/BindingTest/BindingTest.csproj @@ -93,6 +93,10 @@ + + {4a1abb09-9047-4bd5-a4ad-a055e52c5ee0} + Avalonia.DotNetFrameworkRuntime + {3e53a01a-b331-47f3-b828-4a5717e77a24} Avalonia.Markup.Xaml diff --git a/samples/ControlCatalog.Desktop/App.config b/samples/ControlCatalog.Desktop/App.config index 7ef9d715f8..2231c71e63 100644 --- a/samples/ControlCatalog.Desktop/App.config +++ b/samples/ControlCatalog.Desktop/App.config @@ -1,13 +1,13 @@ - + - + - - + + diff --git a/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj b/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj index f42902b534..18a52743e3 100644 --- a/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj +++ b/samples/ControlCatalog.Desktop/ControlCatalog.Desktop.csproj @@ -60,6 +60,10 @@ + + {4a1abb09-9047-4bd5-a4ad-a055e52c5ee0} + Avalonia.DotNetFrameworkRuntime + {799a7bb5-3c2c-48b6-85a7-406a12c420da} Avalonia.DesignerSupport diff --git a/samples/TestApplication/TestApplication.csproj b/samples/TestApplication/TestApplication.csproj index bb18d97766..21594da6d0 100644 --- a/samples/TestApplication/TestApplication.csproj +++ b/samples/TestApplication/TestApplication.csproj @@ -83,6 +83,10 @@ + + {4a1abb09-9047-4bd5-a4ad-a055e52c5ee0} + Avalonia.DotNetFrameworkRuntime + {FB05AC90-89BA-4F2F-A924-F37875FB547C} Avalonia.Cairo diff --git a/samples/VirtualizationTest/App.config b/samples/VirtualizationTest/App.config index 7ef9d715f8..2231c71e63 100644 --- a/samples/VirtualizationTest/App.config +++ b/samples/VirtualizationTest/App.config @@ -1,13 +1,13 @@ - + - + - - + + diff --git a/samples/VirtualizationTest/VirtualizationTest.csproj b/samples/VirtualizationTest/VirtualizationTest.csproj index 98ca3ab970..8b81a012c1 100644 --- a/samples/VirtualizationTest/VirtualizationTest.csproj +++ b/samples/VirtualizationTest/VirtualizationTest.csproj @@ -83,6 +83,10 @@ + + {4a1abb09-9047-4bd5-a4ad-a055e52c5ee0} + Avalonia.DotNetFrameworkRuntime + {d211e587-d8bc-45b9-95a4-f297c8fa5200} Avalonia.Animation diff --git a/samples/XamlTestApplication/XamlTestApplication.csproj b/samples/XamlTestApplication/XamlTestApplication.csproj index f70928c398..d07f22cffb 100644 --- a/samples/XamlTestApplication/XamlTestApplication.csproj +++ b/samples/XamlTestApplication/XamlTestApplication.csproj @@ -91,6 +91,10 @@ + + {4a1abb09-9047-4bd5-a4ad-a055e52c5ee0} + Avalonia.DotNetFrameworkRuntime + {6417e941-21bc-467b-a771-0de389353ce6} Avalonia.Markup diff --git a/src/Android/Avalonia.Android/AndroidPlatform.cs b/src/Android/Avalonia.Android/AndroidPlatform.cs index 1840e90886..7ab6bf8a3c 100644 --- a/src/Android/Avalonia.Android/AndroidPlatform.cs +++ b/src/Android/Avalonia.Android/AndroidPlatform.cs @@ -49,7 +49,7 @@ namespace Avalonia.Android public void Init(Type applicationType) { - SharedPlatform.Register(applicationType.Assembly); + StandardRuntimePlatformServices.Register(applicationType.Assembly); } public IWindowImpl CreateWindow() diff --git a/src/Avalonia.Base/Avalonia.Base.csproj b/src/Avalonia.Base/Avalonia.Base.csproj index 107c0e7071..1dfc5cf65b 100644 --- a/src/Avalonia.Base/Avalonia.Base.csproj +++ b/src/Avalonia.Base/Avalonia.Base.csproj @@ -85,7 +85,7 @@ - + diff --git a/src/Avalonia.Base/AvaloniaDisposable.cs b/src/Avalonia.Base/AvaloniaDisposable.cs index 773c7a6e67..9e43a65f26 100644 --- a/src/Avalonia.Base/AvaloniaDisposable.cs +++ b/src/Avalonia.Base/AvaloniaDisposable.cs @@ -20,7 +20,7 @@ namespace Avalonia { IsDisposed = true; #if DEBUG_DISPOSE - DisposedAt = AvaloniaLocator.Current.GetService().GetStackTrace(); + DisposedAt = AvaloniaLocator.Current.GetService().GetStackTrace(); #endif DoDispose(); } diff --git a/src/Avalonia.Base/Platform/IPclPlatformWrapper.cs b/src/Avalonia.Base/Platform/IRuntimePlatform.cs similarity index 90% rename from src/Avalonia.Base/Platform/IPclPlatformWrapper.cs rename to src/Avalonia.Base/Platform/IRuntimePlatform.cs index 2a21f20f91..63a4795a74 100644 --- a/src/Avalonia.Base/Platform/IPclPlatformWrapper.cs +++ b/src/Avalonia.Base/Platform/IRuntimePlatform.cs @@ -7,7 +7,7 @@ using System.Threading.Tasks; namespace Avalonia.Platform { - public interface IPclPlatformWrapper + public interface IRuntimePlatform { Assembly[] GetLoadedAssemblies(); void PostThreadPoolItem(Action cb); diff --git a/src/Avalonia.Base/Threading/SingleThreadDispatcher.cs b/src/Avalonia.Base/Threading/SingleThreadDispatcher.cs index 815d95ac6e..76d47b30b0 100644 --- a/src/Avalonia.Base/Threading/SingleThreadDispatcher.cs +++ b/src/Avalonia.Base/Threading/SingleThreadDispatcher.cs @@ -33,7 +33,7 @@ namespace Avalonia.Threading } public IDisposable StartTimer(TimeSpan interval, Action tick) - => AvaloniaLocator.Current.GetService().StartSystemTimer(interval, + => AvaloniaLocator.Current.GetService().StartSystemTimer(interval, () => _timerJobRunner.Post(tick, DispatcherPriority.Normal)); public void Signal() => _evnt.Set(); @@ -50,7 +50,7 @@ namespace Avalonia.Threading public static Dispatcher StartNew(CancellationToken token) { var dispatcher = new SingleThreadDispatcher(); - AvaloniaLocator.Current.GetService().PostThreadPoolItem(() => + AvaloniaLocator.Current.GetService().PostThreadPoolItem(() => { dispatcher.MainLoop(token); }); diff --git a/src/Avalonia.Controls/AppBuilder.cs b/src/Avalonia.Controls/AppBuilder.cs index 8b3e0e731a..82698acde7 100644 --- a/src/Avalonia.Controls/AppBuilder.cs +++ b/src/Avalonia.Controls/AppBuilder.cs @@ -3,14 +3,25 @@ using System; using System.Reflection; +using Avalonia.Platform; namespace Avalonia.Controls { /// /// Initializes up platform-specific services for an . /// - public class AppBuilder + public abstract class AppBuilderBase where AppBuilder : AppBuilderBase, new() { + /// + /// Gets or sets the instance. + /// + public IRuntimePlatform RuntimePlatform { get; set; } + + /// + /// Gets or sets a method to call the initialize the runtime platform services (e. g. AssetLoader) + /// + public Action RuntimePlatformServices { get; set; } + /// /// Gets or sets the instance being initialized. /// @@ -32,6 +43,12 @@ namespace Avalonia.Controls /// public Action BeforeStartCallback { get; set; } + protected AppBuilderBase(IRuntimePlatform platform, Action platformSevices) + { + RuntimePlatform = platform; + RuntimePlatformServices = platformSevices; + } + /// /// Begin configuring an . /// @@ -57,6 +74,8 @@ namespace Avalonia.Controls }; } + protected AppBuilder Self => (AppBuilder) this; + /// /// Registers a callback to call before is called on the /// . @@ -66,7 +85,7 @@ namespace Avalonia.Controls public AppBuilder BeforeStarting(Action callback) { BeforeStartCallback = callback; - return this; + return Self; } /// @@ -77,7 +96,7 @@ namespace Avalonia.Controls where TMainWindow : Window, new() { Setup(); - BeforeStartCallback?.Invoke(this); + BeforeStartCallback?.Invoke(Self); var window = new TMainWindow(); window.Show(); @@ -91,7 +110,7 @@ namespace Avalonia.Controls public AppBuilder SetupWithoutStarting() { Setup(); - return this; + return Self; } /// @@ -102,7 +121,7 @@ namespace Avalonia.Controls public AppBuilder UseWindowingSubsystem(Action initializer) { WindowingSubsystem = initializer; - return this; + return Self; } /// @@ -120,7 +139,7 @@ namespace Avalonia.Controls public AppBuilder UseRenderingSubsystem(Action initializer) { RenderingSubsystem = initializer; - return this; + return Self; } /// @@ -140,23 +159,6 @@ namespace Avalonia.Controls init.Invoke(null, null); }; - public AppBuilder UsePlatformDetect() - { - var platformId = (int) - ((dynamic) Type.GetType("System.Environment").GetRuntimeProperty("OSVersion").GetValue(null)).Platform; - if (platformId == 4 || platformId == 6) - { - UseRenderingSubsystem("Avalonia.Cairo"); - UseWindowingSubsystem("Avalonia.Gtk"); - } - else - { - UseRenderingSubsystem("Avalonia.Direct2D1"); - UseWindowingSubsystem("Avalonia.Win32"); - } - return this; - } - /// /// Sets up the platform-speciic services for the . /// @@ -167,6 +169,11 @@ namespace Avalonia.Controls throw new InvalidOperationException("No App instance configured."); } + if (RuntimePlatformServices == null) + { + throw new InvalidOperationException("No runtime platform services configured."); + } + if (WindowingSubsystem == null) { throw new InvalidOperationException("No windowing system configured."); @@ -178,6 +185,7 @@ namespace Avalonia.Controls } Instance.RegisterServices(); + RuntimePlatformServices(); WindowingSubsystem(); RenderingSubsystem(); Instance.Initialize(); diff --git a/src/Avalonia.DesignerSupport/DesignerAssist.cs b/src/Avalonia.DesignerSupport/DesignerAssist.cs index 8787144665..95e7345227 100644 --- a/src/Avalonia.DesignerSupport/DesignerAssist.cs +++ b/src/Avalonia.DesignerSupport/DesignerAssist.cs @@ -37,8 +37,11 @@ namespace Avalonia.DesignerSupport { Design.IsDesignMode = true; Api = new DesignerApi(shared) {UpdateXaml = UpdateXaml, UpdateXaml2 = UpdateXaml2, SetScalingFactor = SetScalingFactor}; - var plat = (IPclPlatformWrapper) Activator.CreateInstance(Assembly.Load(new AssemblyName("Avalonia.Win32")) - .DefinedTypes.First(typeof (IPclPlatformWrapper).GetTypeInfo().IsAssignableFrom).AsType()); + + var runtimeAssembly = Assembly.Load(new AssemblyName("Avalonia.DotNetFrameworkRuntime")); + + var plat = (IRuntimePlatform) Activator.CreateInstance(runtimeAssembly + .DefinedTypes.First(typeof (IRuntimePlatform).GetTypeInfo().IsAssignableFrom).AsType()); TypeInfo app = null; var asms = plat.GetLoadedAssemblies(); @@ -58,7 +61,12 @@ namespace Avalonia.DesignerSupport //Ignore, Assembly.DefinedTypes threw an exception, we can't do anything about that } } - AppBuilder.Configure(app == null ? new DesignerApp() : (Application) Activator.CreateInstance(app.AsType())) + + var builderType = runtimeAssembly.GetType("Avalonia.AppBuilder"); + + var builder = (dynamic)Activator.CreateInstance(builderType, + app == null ? new DesignerApp() : (Application) Activator.CreateInstance(app.AsType())); + builder .UseWindowingSubsystem("Avalonia.Win32") .UseRenderingSubsystem("Avalonia.Direct2D1") .SetupWithoutStarting(); diff --git a/src/Gtk/Avalonia.Cairo/CairoPlatform.cs b/src/Gtk/Avalonia.Cairo/CairoPlatform.cs index 5b85e6c68f..3b0d7d08da 100644 --- a/src/Gtk/Avalonia.Cairo/CairoPlatform.cs +++ b/src/Gtk/Avalonia.Cairo/CairoPlatform.cs @@ -12,7 +12,7 @@ namespace Avalonia { public static class GtkApplicationExtensions { - public static AppBuilder UseCairo(this AppBuilder builder) + public static T UseCairo(this T builder) where T : AppBuilderBase, new() { builder.RenderingSubsystem = Avalonia.Cairo.CairoPlatform.Initialize; return builder; diff --git a/src/Gtk/Avalonia.Gtk/Avalonia.Gtk.csproj b/src/Gtk/Avalonia.Gtk/Avalonia.Gtk.csproj index fe075bca77..2a47aa99fa 100644 --- a/src/Gtk/Avalonia.Gtk/Avalonia.Gtk.csproj +++ b/src/Gtk/Avalonia.Gtk/Avalonia.Gtk.csproj @@ -95,5 +95,4 @@ - \ No newline at end of file diff --git a/src/Gtk/Avalonia.Gtk/GtkPlatform.cs b/src/Gtk/Avalonia.Gtk/GtkPlatform.cs index 4169f5949d..c8246fc9f5 100644 --- a/src/Gtk/Avalonia.Gtk/GtkPlatform.cs +++ b/src/Gtk/Avalonia.Gtk/GtkPlatform.cs @@ -8,14 +8,13 @@ using Avalonia.Controls.Platform; using Avalonia.Input.Platform; using Avalonia.Input; using Avalonia.Platform; -using Avalonia.Shared.PlatformSupport; using Avalonia.Controls; namespace Avalonia { public static class GtkApplicationExtensions { - public static AppBuilder UseGtk(this AppBuilder builder) + public static T UseGtk(this T builder) where T : AppBuilderBase, new() { builder.WindowingSubsystem = Avalonia.Gtk.GtkPlatform.Initialize; return builder; @@ -56,7 +55,6 @@ namespace Avalonia.Gtk .Bind().ToConstant(s_instance) .Bind().ToSingleton() .Bind().ToConstant(s_instance); - SharedPlatform.Register(); _uiThread = Thread.CurrentThread; } diff --git a/src/Markup/Avalonia.Markup.Xaml/Context/AvaloniaNamespaceRegistry.cs b/src/Markup/Avalonia.Markup.Xaml/Context/AvaloniaNamespaceRegistry.cs index 11205972fe..b591654621 100644 --- a/src/Markup/Avalonia.Markup.Xaml/Context/AvaloniaNamespaceRegistry.cs +++ b/src/Markup/Avalonia.Markup.Xaml/Context/AvaloniaNamespaceRegistry.cs @@ -168,7 +168,7 @@ namespace Avalonia.Markup.Xaml.Context private void ScanNewAssemblies() { IEnumerable assemblies = AvaloniaLocator.Current - .GetService() + .GetService() ?.GetLoadedAssemblies(); if (assemblies != null) diff --git a/src/Shared/PlatformSupport/PlatformSupport.projitems b/src/Shared/PlatformSupport/PlatformSupport.projitems index 0bf2184e09..a9b6a8fa2a 100644 --- a/src/Shared/PlatformSupport/PlatformSupport.projitems +++ b/src/Shared/PlatformSupport/PlatformSupport.projitems @@ -1,4 +1,4 @@ - + $(MSBuildAllProjects);$(MSBuildThisFileFullPath) @@ -10,7 +10,7 @@ - - + + \ No newline at end of file diff --git a/src/Shared/PlatformSupport/PclPlatformWrapper.cs b/src/Shared/PlatformSupport/StandardRuntimePlatform.cs similarity index 93% rename from src/Shared/PlatformSupport/PclPlatformWrapper.cs rename to src/Shared/PlatformSupport/StandardRuntimePlatform.cs index ba705c7634..9c0b7bcc73 100644 --- a/src/Shared/PlatformSupport/PclPlatformWrapper.cs +++ b/src/Shared/PlatformSupport/StandardRuntimePlatform.cs @@ -10,7 +10,7 @@ using Avalonia.Platform; namespace Avalonia.Shared.PlatformSupport { - internal class PclPlatformWrapper : IPclPlatformWrapper + internal class StandardRuntimePlatform : IRuntimePlatform { public Assembly[] GetLoadedAssemblies() => AppDomain.CurrentDomain.GetAssemblies(); public void PostThreadPoolItem(Action cb) => ThreadPool.UnsafeQueueUserWorkItem(_ => cb(), null); @@ -23,6 +23,8 @@ namespace Avalonia.Shared.PlatformSupport return Disposable.Create(() => timer.Dispose()); } + + public string GetStackTrace() => Environment.StackTrace; } } \ No newline at end of file diff --git a/src/Shared/PlatformSupport/SharedPlatform.cs b/src/Shared/PlatformSupport/StandardRuntimePlatformServices.cs similarity index 74% rename from src/Shared/PlatformSupport/SharedPlatform.cs rename to src/Shared/PlatformSupport/StandardRuntimePlatformServices.cs index 0db01367bb..70601fdf4a 100644 --- a/src/Shared/PlatformSupport/SharedPlatform.cs +++ b/src/Shared/PlatformSupport/StandardRuntimePlatformServices.cs @@ -6,12 +6,12 @@ using Avalonia.Platform; namespace Avalonia.Shared.PlatformSupport { - static class SharedPlatform + static class StandardRuntimePlatformServices { public static void Register(Assembly assembly = null) { AvaloniaLocator.CurrentMutable - .Bind().ToSingleton() + .Bind().ToSingleton() .Bind().ToConstant(new AssetLoader(assembly)); } } diff --git a/src/Skia/Avalonia.Skia/SkiaPlatform.cs b/src/Skia/Avalonia.Skia/SkiaPlatform.cs index 1d93089e45..3f9e49d3c3 100644 --- a/src/Skia/Avalonia.Skia/SkiaPlatform.cs +++ b/src/Skia/Avalonia.Skia/SkiaPlatform.cs @@ -8,7 +8,7 @@ namespace Avalonia { public static class SkiaApplicationExtensions { - public static AppBuilder UseSkia(this AppBuilder builder) + public static T UseSkia(this T builder) where T : AppBuilderBase, new() { builder.RenderingSubsystem = Avalonia.Skia.SkiaPlatform.Initialize; return builder; diff --git a/src/Windows/Avalonia.Direct2D1/Direct2D1Platform.cs b/src/Windows/Avalonia.Direct2D1/Direct2D1Platform.cs index 6ad64aced1..10f32861e8 100644 --- a/src/Windows/Avalonia.Direct2D1/Direct2D1Platform.cs +++ b/src/Windows/Avalonia.Direct2D1/Direct2D1Platform.cs @@ -12,7 +12,7 @@ namespace Avalonia { public static class Direct2DApplicationExtensions { - public static AppBuilder UseDirect2D1(this AppBuilder builder) + public static T UseDirect2D1(this T builder) where T : AppBuilderBase, new() { builder.RenderingSubsystem = Avalonia.Direct2D1.Direct2D1Platform.Initialize; return builder; diff --git a/src/Windows/Avalonia.Win32/Avalonia.Win32.csproj b/src/Windows/Avalonia.Win32/Avalonia.Win32.csproj index e9627e2033..3fdde9339f 100644 --- a/src/Windows/Avalonia.Win32/Avalonia.Win32.csproj +++ b/src/Windows/Avalonia.Win32/Avalonia.Win32.csproj @@ -114,7 +114,6 @@ - - \ No newline at end of file +