Browse Source

Merge branch 'AvaloniaUI:master' into master

feature/pen-eraser-detection
Krzysztof Krysiński 4 months ago
committed by GitHub
parent
commit
a4e514e1e4
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 5
      src/Avalonia.Controls/Notifications/ReversibleStackPanel.cs
  2. 2
      src/Markup/Avalonia.Markup.Xaml.Loader/CompilerExtensions/Transformers/AvaloniaXamlIlQueryTransformer.cs
  3. 4
      src/Markup/Avalonia.Markup/Markup/Parsers/ContainerQueryGrammar.cs
  4. 48
      tests/Avalonia.Controls.UnitTests/ReversibleStackPanelTests.cs

5
src/Avalonia.Controls/Notifications/ReversibleStackPanel.cs

@ -24,6 +24,11 @@ namespace Avalonia.Controls
set => SetValue(ReverseOrderProperty, value); set => SetValue(ReverseOrderProperty, value);
} }
static ReversibleStackPanel()
{
AffectsArrange<ReversibleStackPanel>(ReverseOrderProperty);
}
/// <inheritdoc/> /// <inheritdoc/>
protected override Size ArrangeOverride(Size finalSize) protected override Size ArrangeOverride(Size finalSize)
{ {

2
src/Markup/Avalonia.Markup.Xaml.Loader/CompilerExtensions/Transformers/AvaloniaXamlIlQueryTransformer.cs

@ -98,7 +98,7 @@ namespace Avalonia.Markup.Xaml.XamlIl.CompilerExtensions.Transformers
} }
catch (Exception e) catch (Exception e)
{ {
throw new XamlParseException("Unable to parse query: " + e.Message, node); throw new XamlParseException("Unable to parse query: " + e, node);
} }
var query = Create(parsed); var query = Create(parsed);

4
src/Markup/Avalonia.Markup/Markup/Parsers/ContainerQueryGrammar.cs

@ -84,7 +84,7 @@ namespace Avalonia.Markup.Parsers
if (identifier.SequenceEqual(MinWidthKeyword.AsSpan()) || identifier.SequenceEqual(MaxWidthKeyword.AsSpan()) || identifier.SequenceEqual(WidthKeyword.AsSpan())) if (identifier.SequenceEqual(MinWidthKeyword.AsSpan()) || identifier.SequenceEqual(MaxWidthKeyword.AsSpan()) || identifier.SequenceEqual(WidthKeyword.AsSpan()))
{ {
if (!r.TakeIf(':')) if (!r.TakeIf(':'))
throw new ExpressionParseException(r.Position, "Expected ':' after 'orientation'."); throw new ExpressionParseException(r.Position, $"Expected ':' after '{identifier}'.");
double val = ParseDecimal(ref r); double val = ParseDecimal(ref r);
var syntax = new WidthSyntax() var syntax = new WidthSyntax()
@ -101,7 +101,7 @@ namespace Avalonia.Markup.Parsers
if (identifier.SequenceEqual(MinHeightKeyword.AsSpan()) || identifier.SequenceEqual(MaxHeightKeyword.AsSpan()) || identifier.SequenceEqual(HeightKeyword.AsSpan())) if (identifier.SequenceEqual(MinHeightKeyword.AsSpan()) || identifier.SequenceEqual(MaxHeightKeyword.AsSpan()) || identifier.SequenceEqual(HeightKeyword.AsSpan()))
{ {
if (!r.TakeIf(':')) if (!r.TakeIf(':'))
throw new ExpressionParseException(r.Position, "Expected ':' after 'orientation'."); throw new ExpressionParseException(r.Position, $"Expected ':' after '{identifier}'.");
double val = ParseDecimal(ref r); double val = ParseDecimal(ref r);
var syntax = new HeightSyntax() var syntax = new HeightSyntax()

48
tests/Avalonia.Controls.UnitTests/ReversibleStackPanelTests.cs

@ -0,0 +1,48 @@
using Avalonia.UnitTests;
using Xunit;
namespace Avalonia.Controls.UnitTests
{
public class ReversibleStackPanelTests : ScopedTestBase
{
[Fact]
public void Arranges_In_Reverse_Order()
{
var target = new ReversibleStackPanel
{
ReverseOrder = true,
Children =
{
new Border { Height = 30, Width = 10 },
new Border { Height = 50 },
}
};
target.Measure(Size.Infinity);
target.Arrange(new Rect(target.DesiredSize));
Assert.Equal(new Rect(0, 50, 10, 30), target.Children[0].Bounds);
Assert.Equal(new Rect(0, 0, 10, 50), target.Children[1].Bounds);
}
[Fact]
public void Invalidates_Arrange_On_Reverse_Order_Change()
{
var target = new ReversibleStackPanel
{
Children =
{
new Border(),
new Border(),
}
};
target.Measure(Size.Infinity);
target.Arrange(new Rect(target.DesiredSize));
target.ReverseOrder = true;
Assert.True(target.IsMeasureValid);
Assert.False(target.IsArrangeValid);
}
}
}
Loading…
Cancel
Save