From: Stephane Delcroix Date: Mon, 18 Jul 2016 08:00:06 +0000 (+0200) Subject: [Xaml] allow the Previewer to provide their own Xaml files for any type X-Git-Tag: beta-2.3.2-pre1~33 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=962c8fd352e32309c9dcb7f8c2f07a335f18fc75;p=platform%2Fupstream%2Fxamarin-forms.git [Xaml] allow the Previewer to provide their own Xaml files for any type --- diff --git a/Xamarin.Forms.Xaml/IXamlFileProvider.cs b/Xamarin.Forms.Xaml/IXamlFileProvider.cs new file mode 100644 index 0000000..7f98901 --- /dev/null +++ b/Xamarin.Forms.Xaml/IXamlFileProvider.cs @@ -0,0 +1,9 @@ +using System; + +namespace Xamarin.Forms.Xaml +{ + public interface IXamlFileProvider + { + string GetXamlFor(Type type); + } +} \ No newline at end of file diff --git a/Xamarin.Forms.Xaml/Xamarin.Forms.Xaml.csproj b/Xamarin.Forms.Xaml/Xamarin.Forms.Xaml.csproj index cb4577c..0081f67 100644 --- a/Xamarin.Forms.Xaml/Xamarin.Forms.Xaml.csproj +++ b/Xamarin.Forms.Xaml/Xamarin.Forms.Xaml.csproj @@ -81,6 +81,7 @@ + diff --git a/Xamarin.Forms.Xaml/XamlLoader.cs b/Xamarin.Forms.Xaml/XamlLoader.cs index 37bea4e..e0dd894 100644 --- a/Xamarin.Forms.Xaml/XamlLoader.cs +++ b/Xamarin.Forms.Xaml/XamlLoader.cs @@ -38,6 +38,8 @@ namespace Xamarin.Forms.Xaml internal static class XamlLoader { static readonly Dictionary XamlResources = new Dictionary(); + internal static bool DoNotThrowOnExceptions { get; set; } + internal static IXamlFileProvider XamlFileProvider { get; set; } public static void Load(object view, Type callingType) { @@ -64,12 +66,16 @@ namespace Xamarin.Forms.Xaml var rootnode = new RuntimeRootNode (new XmlType (reader.NamespaceURI, reader.Name, null), view, (IXmlNamespaceResolver)reader); XamlParser.ParseXaml (rootnode, reader); - Visit (rootnode, new HydratationContext { RootElement = view }); + Visit (rootnode, new HydratationContext { + RootElement = view, + DoNotThrowOnExceptions = XamlLoader.DoNotThrowOnExceptions + }); break; } } } + [Obsolete ("Use the XamlFileProvider to provide xaml files")] public static object Create (string xaml, bool doNotThrow = false) { object inflatedView = null; @@ -113,6 +119,12 @@ namespace Xamarin.Forms.Xaml static string GetXamlForType(Type type) { + string xaml = null; + + //the Previewer might want to provide it's own xaml for this... let them do that + if (XamlFileProvider != null && (xaml = XamlFileProvider.GetXamlFor(type)) != null) + return xaml; + var assembly = type.GetTypeInfo().Assembly; string resourceId; @@ -129,7 +141,6 @@ namespace Xamarin.Forms.Xaml // first pass, pray to find it because the user named it correctly - string xaml = null; foreach (var resource in resourceNames) { if (ResourceMatchesFilename(assembly, resource, likelyResourceName))