Red Hat's XML extension for Visual Studio Code (VS Code) has improved significantly since the last release. This article is an overview of the most notable updates in the vscode-xml
extension 0.14.0 release. Improvements include embedded settings documentation, customizable document outlines, links for seamless XML catalog navigation, and error aggregation for schema validation.
Embedded settings documentation
We've improved the documentation for developers setting up XML document validation. We also added detailed, embedded descriptions for all of the available settings. The embedded documentation is the same documentation that is available from the GitHub repository for vscode-xml. You can now access the documentation directly within VS Code without requiring an internet connection.
To view the documentation in VS Code, open the command palette (Ctrl+Shift+P) and select XML: Open XML Documentation, as shown in Figure 1.
data:image/s3,"s3://crabby-images/9ce13/9ce13d74e2e6b9a0744bb8b8a6b43a046f2ecad1" alt="Open XML Documentation The command palette shows the option to open the documentation homepage."
Figure 2 shows the vscode-xml
documentation homepage.
data:image/s3,"s3://crabby-images/bad02/bad026c11fdf0f4fb33f4296090c176a07212549" alt="XML Documentation Page The documentation home page has links to several pages that describe how to use and configure the extension"
The setting descriptions now contain links to the documentation. As shown in Figure 3, you can use these links to get more information about a particular setting.
data:image/s3,"s3://crabby-images/5b3e1/5b3e1490aa8cacf437e2f9c7b29afb4c863beb0d" alt="Open Empty Elements Documentation There is a link in the description of the Empty Elements XML formatting option in the VS Code settings page. Clicking on it navigates to the related section in the XML Documentation, which provides a more detailed description of the option, along with examples."
The new, embedded documentation should provide a quick start for developers using the vscode-xml
extension.
Show the referenced grammar
If an XML document is associated with one or more XSD or DTD schemas, a Grammars entry now appears in the document outline, as shown in Figure 4.
data:image/s3,"s3://crabby-images/d984d/d984dc5c5eba65dfd25426a4e84593db1104ca49" alt="Show Referenced Grammar The Grammars entry in this screenshot shows information about the referenced schema dressSize.xsd."
The document outline includes the URL location of each schema that is referenced in the document. The outline also lists whether or not the schema is being held within the local cache. As well, the outline lists the binding method that the document uses to associate with the schema. This feature should assist developers with validating XML documents with schemas.
Customize XML symbols outlines
The XML symbols outline displays DOM elements, processing instructions, and declarations for DTD elements, entities, and attribute lists by default. The outline does not automatically display DOM attributes and text nodes. Excluding attributes and text nodes improves performance, but developers sometimes need to see these elements.
With this update, we introduced a new option for configuring the symbols outline. Figure 5 shows a sample Maven POM with the default outline.
data:image/s3,"s3://crabby-images/01fe6/01fe6304c73664d16b3621031366008c9947cc78" alt="SampleMavenOutline Sample Maven document, showing the default outline"
Figure 5: The default outline in a Maven document.">
When viewing a Maven pom.xml
, it is important to be able to see the content of the text nodes. Figure 6 shows the updated document displaying these text elements.
data:image/s3,"s3://crabby-images/48c44/48c44c2f97e4422f1989e45c3fba5f4c64113a54" alt="Sample Maven Outline With Text The outline displays the content of the elements that contain text"
Figure 6: The updated outline showing text elements for the same document.">
Using the new XML symbols filters
The vscode-xml
extension provides a new setting called xml.symbols.filters
, which you can use to select which DOM nodes are displayed as symbols in the outline. The snippet below shows the setting to display text nodes in a pom.xml
files:
"xml.symbols.filters": [ // Declaration of symbols filter for maven 'pom.xml' to show all text nodes in the outline. { "pattern": "pom.xml", "expressions": [ { "xpath": "//text()" } ] } ]
Using xml.symbols.filters for Spring XML
The filter is versatile for different types of files. For example, when editing Spring XML files, you probably want to see the @id
attributes. Here is the configuration to show @id
attributes in a Spring XML file outline:
"xml.symbols.filters": [ // Declaration of symbols filter for Spring beans to show all @id of the elements in the outline. { "pattern": "bean*.xml", "expressions": [ { "xpath": "//@id" } ] } ]
Figure 7 shows an outline displayed in VS Code with the Spring XML @id
attributes.
data:image/s3,"s3://crabby-images/5542d/5542dad461d01e3088df0d8cd100a7da818bd337" alt="Symbols Spring A Spring XML file with id attributes shown."
Figure 7: The outline now includes @id
attributes.">
Note that the pattern
entry is a glob pattern that the extension uses to select the files that it will filter. The expressions
entry is an array of XPaths that the extension uses to filter the symbols. See the symbols filters documentation for more information about the new XML symbols filters.
Aggregate schema errors
If you reference an invalid schema, errors appear in the document that references the schema. In this update, we've grouped these errors. Schema errors are now shown at the range in the document where the schema is referenced. As an example, consider Figure 8, which shows a broken XSD schema.
data:image/s3,"s3://crabby-images/e7d0d/e7d0dc89beb1b8092e81a4f5505a8dbe29dc47d4" alt="Bad Grammar Grocery List The grocery-list element is defined so that several food elements are its children. However, these food item elements themselves are not defined, resulting in the schema being broken."
Figure 8: A broken XSD schema displayed in VS Code.">
Now, if we make an XML document that is associated with the schema using xsi:noNamespaceSchemaLocation
, the errors are reported on the xsi:noNamespaceSchemaLocation
attribute, as shown in Figure 9.
data:image/s3,"s3://crabby-images/a734a/a734a2c29a4cf37a12442171d8792c2b3c289b7b" alt="References Bad Grammar Grocery List Hovering over the reference to the schema shows a popup that lists the 5 errors that the schema has. You can click on the blue text in order to open the schema to the location of the errors."
Figure 9: Hover over a reference to a broken schema to see a list of errors.">
The error aggregation also works for external DTD references, xsi:schemaLocation
, and the xml-model
processing instruction.
Reports and quick fixes for missing closing tag errors
This update improves the diagnostics for missing closing tags in elements. The before-and-after screens in Figure 10 let you see the improvements to error reporting for a closing tag with no corresponding opening tag.
The screens in Figure 11 highlight the difference in error reporting for an opening tag that has no corresponding closing tag.
data:image/s3,"s3://crabby-images/29ba5/29ba5497f97d457dcebcc29b213fdfe85b925c1a" alt="Before After ETag 2 Needs alt text."
The screens in Figure 12 highlight the improvements to error reporting for an incomplete closing tag.
data:image/s3,"s3://crabby-images/0bada/0bada41bd6929c7d2fca4ce4e0296b7438ae4136" alt="Before After ETag 3 Needs alt text."
We also improved quick fixes for missing, incomplete, or invalid closing tags, as shown in Figure 13.
data:image/s3,"s3://crabby-images/5790a/5790a97ef32f7b1dffdef4c56b5ab46432bf9b9f" alt="vscode-quickfixes Quick fixes update incomplete closing tags in a malformed XML document."
Figure 13: A quick fix updates incomplete closing tags in a malformed XML document.">
Document links in catalogs
We added new document links for the uri
and catalog
attributes in XML catalogs. These attributes are used to link catalogs to schemas and other catalogs. The links will point to the correct file if you use the xml:base
attribute with the <group>
element. Figure 14 demonstrates using the new document links between catalogs and entries.
data:image/s3,"s3://crabby-images/bca92/bca92ff900fec2c83462584aa22b553e407cbf03" alt="SeemlessCatalogNavigationOptimized Links create seamless navigation between catalogs and their entries."
New formatting options for xsi:schemaLocation
Inspired by other XML tools, we implemented new formatting styles for xsi:schemaLocation
. You can now choose between three formats shown in Figure 15 through Figure 17.
Figure 15 shows the result of selecting none
for the xsi:schemaLocation
format.
data:image/s3,"s3://crabby-images/4e6fb/4e6fb3c2adbe59fbcdf828b586a2a10996260352" alt="Schema location format: None Selecting 'none' leaves the content unchanged."
Figure 16 shows the result of selecting on element
.
data:image/s3,"s3://crabby-images/3af9a/3af9a5b0e9fc1192bc55cda26a71c99826e7bed4" alt="Schema Location Format On Element The 'on element' format adds new lines after each namespace and URI."
Figure 17 shows the format for on pair
.
data:image/s3,"s3://crabby-images/67b0d/67b0d2dc43627f5a8abf2fbd1b3cbfd73c9637e3" alt="Schema Location Format On Pair The 'on pair' format adds new lines after each namespace-URI pair, so that each line contains one schema reference."
Conclusion
The updated XML extension for VS Code brings many features for editing and navigating XML documents in VS Code. We want to thank the following contributors who worked to make this update amazing:
- Alex Boyko (BoykoAlex)
- Max Hohenegger (Treehopper)
- Ryan Zegray (rzgry)
- tcheng (a2975667)
- Yatao Li (yatli)
- Simon Sobisch (GitMensch)
You can use the following channels to get more information about the XML extension for VS Code and report any issues with the 0.14.0 release:
- Use the vscode-xml GitHub to report an issue.
- See the vscode-xml documentation to learn more about the updates discussed in this article.
- Visit the vscode-xml changelog for a list of the most recent updates.