Well, hope that you were aware of Silverlight 5 Beta release announcement today and its latest feature, if not make sure to have a look at my earlier post here. In this post, we will discuss about XAML binding debugging, a new feature available in Silverlight 5. Be sure that you read my last line carefully - it's XAML Data Binding debugging, not XAML debugging.
For any data driven application with declarative data binding, within XAML, this brand new feature is significant in many ways. Personally, I remember most of the time I used to skip XAML way of binding as it lacked the debugging feature. Now with Silverlight 5, my previous approach will surely take a back seat and will allow me to consider both ways equally.
Prerequisites
Make sure that you have downloaded the latest version of Silverlight Toolkit SDK. If not, download it from here. Also, make sure that you are running on Visual Studio SP1.
The XAML Data Binding
The example demonstrated here implements basic XAML data binding with DomainDataSource
control, let's look at the XAML binding of one of the controls.
data:image/s3,"s3://crabby-images/caa83/caa83ccd2ed79b8e4bdb17f3c90bc5649e2eb533" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging - Click to enlarge image"
Nothing fancy, simple binding.
The XAML Debugging
Setting Up Breakpoint
As of now, the XAML allows to apply breakpoint on Binding syntax only. Once the break point is applied, it hits the breakpoint whenever push and pull is triggered for that control. The image below shows the breakpoint within XAML.
data:image/s3,"s3://crabby-images/bc5f1/bc5f163943eb9d5530164ab7b77fb6a8da4425bd" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging - Click to enlarge image"
The XAML editor will not allow you to set breakpoint anywhere else other than Binding syntax.
The Debug Information
Once Breakpoint is set, start the application and wait for the compiler to hit it .
data:image/s3,"s3://crabby-images/325a0/325a0941c3abf7a8a3633815934e6a248918251c" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging - Click to enlarge image"
You can find the debug information from Local tab.
data:image/s3,"s3://crabby-images/4e2a7/4e2a7becb4bdcdf6c9b1fde05872c18f127798d4" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging - Click to enlarge image"
The information shows up a BindingState
object holding complete binding context information of the control. As in the above image, the BindingState
value is UpdatingTarget
so this way it shows that the binding is pushing data to control.
data:image/s3,"s3://crabby-images/a93e8/a93e8c3c6f90b477cb5be97de48cde0f5e8ca7ef" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging"
Going deeper into the debugging information, it shows the complete picture on the nature of data and binding.
data:image/s3,"s3://crabby-images/cb841/cb8411f8cc3172be5ff056e536391205b810afd5" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging - Click to enlarge image"
Now another interesting fact, on TwoWay
binding scenario once you change the data, for e.g., the FirstName
control:
data:image/s3,"s3://crabby-images/aabca/aabca2879c1b43154050df8ce8a8638c029831e8" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging"
The breakpoint again gets a hit as the binding source is getting updated. And the debug information shows the Binding
state as Updating Source status.
data:image/s3,"s3://crabby-images/1c30a/1c30ac0e25f953dcac18d9e699fed47cf08d15a1" alt="image image - Click to enlarge image"
and the CurrentItem
Information shows up the editing item detail and its properties.
data:image/s3,"s3://crabby-images/68fde/68fde3db95867ece107ceb068601b533b4a228a3" alt="Silverlight5 XAML Debugging Silverlight5 XAML Debugging - Click to enlarge image"
Conclusion
Hope this post helps you to know the cool new feature of Silverlight 5. Try it
and extract information you need to know right from XAML.
Keep commenting and keep your suggestions flowing. More to follow on Silverlight 5 Beta new features as I explore
.