diff options
author | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 13:02:25 -0700 |
---|---|---|
committer | Jason Smith <jason.smith@xamarin.com> | 2016-03-22 16:13:41 -0700 |
commit | 17fdde66d94155fc62a034fa6658995bef6fd6e5 (patch) | |
tree | b5e5073a2a7b15cdbe826faa5c763e270a505729 /Xamarin.Forms.Core/LayoutOptionsConverter.cs | |
download | xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.gz xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.tar.bz2 xamarin-forms-17fdde66d94155fc62a034fa6658995bef6fd6e5.zip |
Initial import
Diffstat (limited to 'Xamarin.Forms.Core/LayoutOptionsConverter.cs')
-rw-r--r-- | Xamarin.Forms.Core/LayoutOptionsConverter.cs | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/Xamarin.Forms.Core/LayoutOptionsConverter.cs b/Xamarin.Forms.Core/LayoutOptionsConverter.cs new file mode 100644 index 00000000..746e56ce --- /dev/null +++ b/Xamarin.Forms.Core/LayoutOptionsConverter.cs @@ -0,0 +1,25 @@ +using System; +using System.Linq; +using System.Reflection; + +namespace Xamarin.Forms +{ + public sealed class LayoutOptionsConverter : TypeConverter + { + public override object ConvertFromInvariantString(string value) + { + if (value != null) + { + string[] parts = value.Split('.'); + if (parts.Length > 2 || (parts.Length == 2 && parts[0] != "LayoutOptions")) + throw new InvalidOperationException(string.Format("Cannot convert \"{0}\" into {1}", value, typeof(LayoutOptions))); + value = parts[parts.Length - 1]; + FieldInfo field = typeof(LayoutOptions).GetFields().FirstOrDefault(fi => fi.IsStatic && fi.Name == value); + if (field != null) + return (LayoutOptions)field.GetValue(null); + } + + throw new InvalidOperationException(string.Format("Cannot convert \"{0}\" into {1}", value, typeof(LayoutOptions))); + } + } +}
\ No newline at end of file |