Code Inspection and Quick-Fixes in XAML
The key features of ReSharper's code analysis are also supported in XAML. You can find the detailed information on these features in the corresponding topics of the Code analysis section. In the main topic of the section, you can also find the feature matrix and check what exactly is supported in XAML.
In this topic, you can find some examples of using code analysis features in XAML.
ReSharper detects various problems in XAML files, such as unresolved symbols, incorrect document structure, unused import directives, and so on. Whenever a problem is encountered, ReSharper highlights it and displays some description in a tooltip. In the example below, ReSharper warns that the namespace alias is not used inside the current file and highlights it in grey:
data:image/s3,"s3://crabby-images/06343/063435ce7968a35945952fc71924bf2b1d788631" alt="ReSharper: XAML code highlighting ReSharper: XAML code highlighting"
In the following example, ReSharper highlights a problem with resolving a method inside an event subscription:
data:image/s3,"s3://crabby-images/f52cf/f52cfd156a3ec9ea7f081a360cdf20fe86f21384" alt="ReSharper: XAML code highlighting ReSharper: XAML code highlighting"
The analysis is performed by applying code inspections to the current document or in any specified scope.
To look through the list of available inspections for XAML, open the Code Inspection | Inspection Severity page of ReSharper options Alt+R, O, and then expand the XAML node.
ReSharper does not only analyze errors in the current XAML file, but also inspects all files in the whole solution and shows the results of the analysis in the Errors in Solution window . It takes dependencies between files into account and updates the results when you change code.
data:image/s3,"s3://crabby-images/8246b/8246bd65d44d59219c52e2b56ab5beefccfd1a4d" alt="ReSharper: XAML errors in solution ReSharper: XAML errors in solution"
For more information, refer to Solution-wide analysis.
To change visibility of a field declared in XAML, use the appropriate quick-fix.
data:image/s3,"s3://crabby-images/bb8bd/bb8bd994e07be5cefdb8c0e48480957881f0c2ef" alt="ReSharper: Make field private quick-fix in XAML ReSharper: Make field private quick-fix in XAML"
After applying the quick-fix, the value of FieldModifier
is changed to private
.
data:image/s3,"s3://crabby-images/724b0/724b00964a03b7184207bb48bc1c8be2af910b05" alt="ReSharper: Make field private quick-fix in XAML ReSharper: Make field private quick-fix in XAML"
To remove a redundant namespace alias, use the appropriate quick-fix.
data:image/s3,"s3://crabby-images/de995/de995eb1ea376d97008d746ab30623a9fb7db2fd" alt="ReSharper: Remove redundant namespace alias quick-fix in XAML ReSharper: Remove redundant namespace alias quick-fix in XAML"
After applying the quick-fix, the namespace alias directive is removed.
data:image/s3,"s3://crabby-images/18b25/18b2552775f42731ed430f2aa18bee79a141ef77" alt="ReSharper: Remove redundant namespace alias quick-fix in XAML ReSharper: Remove redundant namespace alias quick-fix in XAML"
tip
You can also remove all redundant namespace aliases in the entire solution with code cleanup.
When the type, to which the style should be applied, is specified in the TargetType
attribute, there is no need to add a qualifier for each property of the Button
class. ReSharper detects such cases and offers the quick-fix.
data:image/s3,"s3://crabby-images/0364f/0364f02fafcf159cdcb86421d77b455fd2cd8539" alt="ReSharper: Remove type qualifier quick-fix in XAML ReSharper: Remove type qualifier quick-fix in XAML"