Windsor ships for both .NET and Silverlight. However working with the codebase in such a way that we can target both runtimes at the same time with the least amount of friction possible proved to be quite a challenge.
Problem
We’re using single .sln and .csproj files to target both runtimes (actually 5 of them, as we ship for 3 versions of .NET and 2 versions of Silverlight, but I digress) with some heavy (and I mean- really heavy) Jedi trickery in MsBuild by Roelof.
We’re using conditional compilation to cater for incompatibilities between frameworks. For example, SerializableAttribute and NonSerializedAttribute are not present in Silverlight, so many of our classes look like this:
#if !SILVERLIGHT
[Serializable]
#endif
public class ParameterModel
{
// some code here
}
This is quite cluttering the code making it harder to read. It adds friction to the process, since I have to remember each time to exclude the attribute from Silverlight build. Even more annoying is the fact, that ReSharper is not very fond of pre-processor directives in code, and certain features, like code clean up and reordering don’t really work the way they should.
Solution
I figured out a way to cut the need to use conditional compilation in this case. So that I can write the code like this:
[Serializable]
public class ParameterModel
{
// some code here
}
and still have it compile properly under Silverlight, outputting exactly the same code as the first sample. How you ask? – using a not very well known feature of .NET BCL – ConditionalAttribute.
Read more: Krzysztof Kozmic
Problem
We’re using single .sln and .csproj files to target both runtimes (actually 5 of them, as we ship for 3 versions of .NET and 2 versions of Silverlight, but I digress) with some heavy (and I mean- really heavy) Jedi trickery in MsBuild by Roelof.
We’re using conditional compilation to cater for incompatibilities between frameworks. For example, SerializableAttribute and NonSerializedAttribute are not present in Silverlight, so many of our classes look like this:
#if !SILVERLIGHT
[Serializable]
#endif
public class ParameterModel
{
// some code here
}
This is quite cluttering the code making it harder to read. It adds friction to the process, since I have to remember each time to exclude the attribute from Silverlight build. Even more annoying is the fact, that ReSharper is not very fond of pre-processor directives in code, and certain features, like code clean up and reordering don’t really work the way they should.
Solution
I figured out a way to cut the need to use conditional compilation in this case. So that I can write the code like this:
[Serializable]
public class ParameterModel
{
// some code here
}
and still have it compile properly under Silverlight, outputting exactly the same code as the first sample. How you ask? – using a not very well known feature of .NET BCL – ConditionalAttribute.
Read more: Krzysztof Kozmic