Browse Source

Add some missing TypeConverters

add-missing-type-converters
Max Katz 3 years ago
parent
commit
f5e3a56ff1
  1. 2
      src/Avalonia.Base/CornerRadius.cs
  2. 21
      src/Avalonia.Base/CornerRadiusConverter.cs
  3. 2
      src/Avalonia.Base/Matrix.cs
  4. 21
      src/Avalonia.Base/MatrixConverter.cs
  5. 2
      src/Avalonia.Base/Media/Color.cs
  6. 21
      src/Avalonia.Base/Media/ColorConverter.cs
  7. 2
      src/Avalonia.Base/Point.cs
  8. 21
      src/Avalonia.Base/PointConverter.cs
  9. 2
      src/Avalonia.Base/Rect.cs
  10. 21
      src/Avalonia.Base/RectConverter.cs
  11. 2
      src/Avalonia.Base/RelativePoint.cs
  12. 21
      src/Avalonia.Base/RelativePointConverter.cs
  13. 2
      src/Avalonia.Base/Size.cs
  14. 21
      src/Avalonia.Base/SizeConverter.cs
  15. 2
      src/Avalonia.Base/Thickness.cs
  16. 21
      src/Avalonia.Base/ThicknessConverter.cs
  17. 2
      src/Avalonia.Controls/GridLength.cs
  18. 21
      src/Avalonia.Controls/GridLengthConverter.cs

2
src/Avalonia.Base/CornerRadius.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
#if !BUILDTASK #if !BUILDTASK
using Avalonia.Animation.Animators; using Avalonia.Animation.Animators;
@ -11,6 +12,7 @@ namespace Avalonia
/// Represents the radii of a rectangle's corners. /// Represents the radii of a rectangle's corners.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(CornerRadiusConverter))]
public public
#endif #endif
readonly struct CornerRadius : IEquatable<CornerRadius> readonly struct CornerRadius : IEquatable<CornerRadius>

21
src/Avalonia.Base/CornerRadiusConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="CornerRadius"/> from a string representation.
/// </summary>
public class CornerRadiusConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? CornerRadius.Parse(s) : null;
}
}

2
src/Avalonia.Base/Matrix.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
using System.Linq; using System.Linq;
using System.Numerics; using System.Numerics;
@ -18,6 +19,7 @@ namespace Avalonia
/// Note: Skia.SkMatrix uses a transposed layout (where for example skewX/skewY and persp0/transX are swapped). /// Note: Skia.SkMatrix uses a transposed layout (where for example skewX/skewY and persp0/transX are swapped).
/// </remarks> /// </remarks>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(MatrixConverter))]
public public
#endif #endif
readonly struct Matrix : IEquatable<Matrix> readonly struct Matrix : IEquatable<Matrix>

21
src/Avalonia.Base/MatrixConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="Matrix"/> from a string representation.
/// </summary>
public class MatrixConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? Matrix.Parse(s) : null;
}
}

2
src/Avalonia.Base/Media/Color.cs

@ -6,6 +6,7 @@
// Licensed to The Avalonia Project under MIT License, courtesy of The .NET Foundation. // Licensed to The Avalonia Project under MIT License, courtesy of The .NET Foundation.
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
#if !BUILDTASK #if !BUILDTASK
using Avalonia.Animation.Animators; using Avalonia.Animation.Animators;
@ -18,6 +19,7 @@ namespace Avalonia.Media
/// An ARGB color. /// An ARGB color.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(ColorConverter))]
public public
#endif #endif
readonly struct Color : IEquatable<Color> readonly struct Color : IEquatable<Color>

21
src/Avalonia.Base/Media/ColorConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia.Media;
/// <summary>
/// Creates a <see cref="Color"/> from a string representation.
/// </summary>
public class ColorConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? Color.Parse(s) : null;
}
}

2
src/Avalonia.Base/Point.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
using System.Numerics; using System.Numerics;
#if !BUILDTASK #if !BUILDTASK
@ -12,6 +13,7 @@ namespace Avalonia
/// Defines a point. /// Defines a point.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(PointConverter))]
public public
#endif #endif
readonly struct Point : IEquatable<Point> readonly struct Point : IEquatable<Point>

21
src/Avalonia.Base/PointConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="Thickness"/> from a string representation.
/// </summary>
public class PointConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? Point.Parse(s) : null;
}
}

2
src/Avalonia.Base/Rect.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
using Avalonia.Animation.Animators; using Avalonia.Animation.Animators;
using Avalonia.Utilities; using Avalonia.Utilities;
@ -8,6 +9,7 @@ namespace Avalonia
/// <summary> /// <summary>
/// Defines a rectangle. /// Defines a rectangle.
/// </summary> /// </summary>
[TypeConverter(typeof(RectConverter))]
public readonly struct Rect : IEquatable<Rect> public readonly struct Rect : IEquatable<Rect>
{ {
static Rect() static Rect()

21
src/Avalonia.Base/RectConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="Rect"/> from a string representation.
/// </summary>
public class RectConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? Rect.Parse(s) : null;
}
}

2
src/Avalonia.Base/RelativePoint.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
#if !BUILDTASK #if !BUILDTASK
using Avalonia.Animation.Animators; using Avalonia.Animation.Animators;
@ -12,6 +13,7 @@ namespace Avalonia
/// <see cref="RelativeRect"/>. /// <see cref="RelativeRect"/>.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(RelativePointConverter))]
public public
#endif #endif
enum RelativeUnit enum RelativeUnit

21
src/Avalonia.Base/RelativePointConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="RelativePoint"/> from a string representation.
/// </summary>
public class RelativePointConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? RelativePoint.Parse(s) : null;
}
}

2
src/Avalonia.Base/Size.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
#if !BUILDTASK #if !BUILDTASK
using Avalonia.Animation.Animators; using Avalonia.Animation.Animators;
@ -11,6 +12,7 @@ namespace Avalonia
/// Defines a size. /// Defines a size.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(SizeConverter))]
public public
#endif #endif
readonly struct Size : IEquatable<Size> readonly struct Size : IEquatable<Size>

21
src/Avalonia.Base/SizeConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="Size"/> from a string representation.
/// </summary>
public class SizeConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? Size.Parse(s) : null;
}
}

2
src/Avalonia.Base/Thickness.cs

@ -1,4 +1,5 @@
using System; using System;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
#if !BUILDTASK #if !BUILDTASK
using Avalonia.Animation.Animators; using Avalonia.Animation.Animators;
@ -11,6 +12,7 @@ namespace Avalonia
/// Describes the thickness of a frame around a rectangle. /// Describes the thickness of a frame around a rectangle.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(ThicknessConverter))]
public public
#endif #endif
readonly struct Thickness : IEquatable<Thickness> readonly struct Thickness : IEquatable<Thickness>

21
src/Avalonia.Base/ThicknessConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia;
/// <summary>
/// Creates a <see cref="Thickness"/> from a string representation.
/// </summary>
public class ThicknessConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? Thickness.Parse(s) : null;
}
}

2
src/Avalonia.Controls/GridLength.cs

@ -1,5 +1,6 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.ComponentModel;
using System.Globalization; using System.Globalization;
using Avalonia.Utilities; using Avalonia.Utilities;
@ -33,6 +34,7 @@ namespace Avalonia.Controls
/// Holds the width or height of a <see cref="Grid"/>'s column and row definitions. /// Holds the width or height of a <see cref="Grid"/>'s column and row definitions.
/// </summary> /// </summary>
#if !BUILDTASK #if !BUILDTASK
[TypeConverter(typeof(GridLengthConverter))]
public public
#endif #endif
struct GridLength : IEquatable<GridLength> struct GridLength : IEquatable<GridLength>

21
src/Avalonia.Controls/GridLengthConverter.cs

@ -0,0 +1,21 @@
using System;
using System.ComponentModel;
using System.Globalization;
namespace Avalonia.Controls;
/// <summary>
/// Creates a <see cref="GridLength"/> from a string representation.
/// </summary>
public class GridLengthConverter : TypeConverter
{
public override bool CanConvertFrom(ITypeDescriptorContext? context, Type sourceType)
{
return sourceType == typeof(string);
}
public override object? ConvertFrom(ITypeDescriptorContext? context, CultureInfo? culture, object? value)
{
return value is string s ? GridLength.Parse(s) : null;
}
}
Loading…
Cancel
Save