Skip to content
This repository has been archived by the owner on May 1, 2024. It is now read-only.

Commit

Permalink
Xamlc compile data triggers (#648)
Browse files Browse the repository at this point in the history
* [Xaml] DataTrigger and PropertyCondition no longer use a ServiceProvider

* [XamlC] avoid generating ServiceProvider for unused ProvideValue

* fix tests
  • Loading branch information
StephaneDelcroix committed Dec 23, 2016
1 parent b96df00 commit c34016d
Show file tree
Hide file tree
Showing 9 changed files with 74 additions and 17 deletions.
@@ -0,0 +1,18 @@
using System.Collections.Generic;

using Mono.Cecil;
using Mono.Cecil.Cil;

using Xamarin.Forms.Xaml;
using Xamarin.Forms.Build.Tasks;

namespace Xamarin.Forms.Core.XamlC
{
class PassthroughValueProvider : ICompiledValueProvider
{
public IEnumerable<Instruction> ProvideValue(VariableDefinitionReference vardefref, ModuleDefinition module, BaseNode node, ILContext context)
{
yield break;
}
}
}
Expand Up @@ -8,7 +8,6 @@

namespace Xamarin.Forms.Core.XamlC
{

class TriggerValueProvider : ICompiledValueProvider
{
public IEnumerable<Instruction> ProvideValue(VariableDefinitionReference vardefref, ModuleDefinition module, BaseNode node, ILContext context)
Expand Down
1 change: 1 addition & 0 deletions Xamarin.Forms.Build.Tasks/Xamarin.Forms.Build.Tasks.csproj
Expand Up @@ -108,6 +108,7 @@
<Compile Include="CompiledValueProviders\SetterValueProvider.cs" />
<Compile Include="CompiledValueProviders\ICompiledValueProvider.cs" />
<Compile Include="CompiledValueProviders\TriggerValueProvider.cs" />
<Compile Include="CompiledValueProviders\PassthroughValueProvider.cs" />
</ItemGroup>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<Target Name="AfterBuild">
Expand Down
14 changes: 14 additions & 0 deletions Xamarin.Forms.Core.UnitTests/DataTriggerTests.cs
Expand Up @@ -6,6 +6,20 @@ namespace Xamarin.Forms.Core.UnitTests
[TestFixture]
public class DataTriggerTests : BaseTestFixture
{
[SetUp]
public override void Setup()
{
Device.PlatformServices = new MockPlatformServices();
base.Setup();
}

[TearDown]
public override void TearDown()
{
base.TearDown();
Device.PlatformServices = null;
}

class MockElement : VisualElement
{
}
Expand Down
14 changes: 14 additions & 0 deletions Xamarin.Forms.Core.UnitTests/MultiTriggerTests.cs
Expand Up @@ -5,6 +5,20 @@ namespace Xamarin.Forms.Core.UnitTests
[TestFixture]
public class MultiTriggerTests : BaseTestFixture
{
[SetUp]
public override void Setup()
{
Device.PlatformServices = new MockPlatformServices();
base.Setup();
}

[TearDown]
public override void TearDown()
{
base.TearDown();
Device.PlatformServices = null;
}

class MockElement : VisualElement
{
}
Expand Down
15 changes: 6 additions & 9 deletions Xamarin.Forms.Core/Interactivity/BindingCondition.cs
Expand Up @@ -3,6 +3,7 @@

namespace Xamarin.Forms
{
[ProvideCompiled("Xamarin.Forms.Core.XamlC.PassthroughValueProvider")]
public sealed class BindingCondition : Condition, IValueProvider
{
readonly BindableProperty _boundProperty;
Expand Down Expand Up @@ -41,15 +42,9 @@ public object Value
}
}

internal IServiceProvider ServiceProvider { get; set; }

internal IValueConverterProvider ValueConverter { get; set; }

object IValueProvider.ProvideValue(IServiceProvider serviceProvider)
{
ValueConverter = serviceProvider.GetService(typeof(IValueConverterProvider)) as IValueConverterProvider;
ServiceProvider = serviceProvider;

//This is no longer required
return this;
}

Expand All @@ -71,14 +66,16 @@ internal override void TearDown(BindableObject bindable)
bindable.ClearValue(_boundProperty);
}

static IValueConverterProvider s_valueConverter = DependencyService.Get<IValueConverterProvider>();

bool EqualsToValue(object other)
{
if ((other == Value) || (other != null && other.Equals(Value)))
return true;

object converted = null;
if (ValueConverter != null)
converted = ValueConverter.Convert(Value, other != null ? other.GetType() : typeof(object), null, ServiceProvider);
if (s_valueConverter != null)
converted = s_valueConverter.Convert(Value, other != null ? other.GetType() : typeof(object), null, null);
else
return false;

Expand Down
5 changes: 2 additions & 3 deletions Xamarin.Forms.Core/Interactivity/DataTrigger.cs
Expand Up @@ -5,6 +5,7 @@
namespace Xamarin.Forms
{
[ContentProperty("Setters")]
[ProvideCompiled("Xamarin.Forms.Core.XamlC.PassthroughValueProvider")]
public sealed class DataTrigger : TriggerBase, IValueProvider
{
public DataTrigger([TypeConverter(typeof(TypeTypeConverter))] [Parameter("TargetType")] Type targetType) : base(new BindingCondition(), targetType)
Expand Down Expand Up @@ -48,9 +49,7 @@ public object Value

object IValueProvider.ProvideValue(IServiceProvider serviceProvider)
{
var valueconverter = serviceProvider.GetService(typeof(IValueConverterProvider)) as IValueConverterProvider;
(Condition as BindingCondition).ValueConverter = valueconverter;

//This is no longer required
return this;
}
}
Expand Down
18 changes: 14 additions & 4 deletions Xamarin.Forms.Xaml.UnitTests/Issues/Bz28719.xaml.cs
@@ -1,8 +1,6 @@
using System;
using System.Collections.Generic;
using NUnit.Framework;

using Xamarin.Forms;
using NUnit.Framework;
using Xamarin.Forms.Core.UnitTests;

namespace Xamarin.Forms.Xaml.UnitTests
{
Expand All @@ -21,6 +19,18 @@ public Bz28719 (bool useCompiledXaml)
[TestFixture]
class Tests
{
[SetUp]
public void Setup()
{
Device.PlatformServices = new MockPlatformServices();
}

[TearDown]
public void TearDown()
{
Device.PlatformServices = null;
}

[TestCase(true)]
[TestCase(false)]
public void DataTriggerInTemplates (bool useCompiledXaml)
Expand Down
5 changes: 5 additions & 0 deletions Xamarin.Forms.Xaml/ValueConverterProvider.cs
@@ -1,6 +1,11 @@
using System;
using System.Reflection;

using Xamarin.Forms;
using Xamarin.Forms.Xaml;

[assembly:Dependency(typeof(ValueConverterProvider))]

namespace Xamarin.Forms.Xaml
{
class ValueConverterProvider : IValueConverterProvider
Expand Down

0 comments on commit c34016d

Please sign in to comment.