Pretty XML
What is it?
Features
1. Prettify XML (XML Formatting)
2. Pretty XML: Minimize
Keyboard Shortcuts
Settings
Requirements
Installation
Known Issues
Change Log
For more information
What is it?
Pretty XML is a XML formatter extension for Visual Studio Code and VSCodium. It formats XML documents just like Visual Studio on Windows.
Supported file extensions:
- xml
- xaml
- axml
- xsd
- xsl
- plist
- mobileconfig
- config
- csproj
- svg
- resx and all other XML type of files.
There is also Visual Studio for Mac version of this extension. Check it out at PrettyXML.VSMac
Suggestions, improvement PRs are welcome.
data:image/s3,"s3://crabby-images/ab304/ab304d8b54a9c244a01e13e23ec07fd72ad478f8" alt="License"
data:image/s3,"s3://crabby-images/e84a1/e84a13d4618655573a553c4524a365443b98cef6" alt="Deploy"
data:image/s3,"s3://crabby-images/3b90b/3b90b1e801e260e05d8cd3df2d7750ddf602976b" alt="Visual Studio Marketplace Version"
data:image/s3,"s3://crabby-images/f9a19/f9a19e282c50ae77d1fa851ea8587d122c8d5252" alt="Visual Studio Marketplace Installs"
data:image/s3,"s3://crabby-images/9ff5a/9ff5ab0b8699f24b1a41268688673425f6c5c926" alt="Visual Studio Marketplace Downloads"
data:image/s3,"s3://crabby-images/813f2/813f2b721efe1132b3900ab7be48c4e657a3fb74" alt="Visual Studio Marketplace Rating"
data:image/s3,"s3://crabby-images/325ef/325ef236b5f1d6dad4c7ffe6a6d36dccb9415fc4" alt="Open VSX"
data:image/s3,"s3://crabby-images/abe64/abe6456437e827be94fcea1ce1b0b30613246dea" alt="Open VSX Downloads"
data:image/s3,"s3://crabby-images/89d5c/89d5c022e13d7e3970602bd2ec38f854ab329ff3" alt="Open VSX Rating"
data:image/s3,"s3://crabby-images/d5ebb/d5ebbdbfd4149dd90d2cebe2095c1ef9d70e94e4" alt="prettify gif."
Features
Right Click and Select Prettify XML or use shortcut
- Position each attribute on a separate line.
- First attribute on same line as start element start tag.
- All attributes indented aligning with first attribute.
- If no child for an element then close inline end tag.
- No empty lines.
- Supports
'
and whitespace unicodes in attribute value for XAML parser compatibility.
Before
data:image/s3,"s3://crabby-images/710e6/710e65a5128321184277b960bee6e15d05ea6704" alt="Before."
After
data:image/s3,"s3://crabby-images/36dad/36dadf4ae3b6f2b44fcfed2069b55d5abe2b478d" alt="After."
2. Pretty XML: Minimize
Minimizes XML.
data:image/s3,"s3://crabby-images/bf2e7/bf2e7ae9e5daf2e2c739e41fcdbf5b11eee07ec0" alt="minimize gif."
Keyboard Shortcuts
Command |
Platform |
Shortcut |
Prettify XML |
Mac |
Cmd+K L |
Prettify XML |
Windows, Linux |
Control+K L |
PrettyXML: Minimize |
Mac |
Cmd+K ` |
PrettyXML: Minimize |
Windows, Linux |
Control+K ` |
Note
You can change these in Preferences → Keyboard Shortcuts if you want.
Settings
These will be for Prettify XML command.
Setting Key |
Default Value |
Description |
prettyxml.settings.indentSpaceLength |
4 |
No. of spaces for indentation. |
prettyxml.settings.useSingleQuotes |
false |
Use ' instead of " |
prettyxml.settings.useSelfClosingTag |
true |
If no child nodes then self closing tag /> |
prettyxml.settings.formatOnSave |
false |
Enable format on save |
prettyxml.settings.allowSingleQuoteInAttributeValue |
true |
Allows ' in attribute values instead of ' |
prettyxml.settings.addSpaceBeforeSelfClosingTag |
true |
Adds space before self closing tag |
prettyxml.settings.wrapCommentTextWithSpaces |
true |
Wraps comment text with a single space |
prettyxml.settings.allowWhiteSpaceUnicodesInAttributeValues |
true |
Allows white space unicodes in attribute values |
prettyxml.settings.positionFirstAttributeOnSameLine |
true |
Position first attribute on same line. |
prettyxml.settings.positionAllAttributesOnFirstLine |
false |
Position all attributes on first line |
prettyxml.settings.preserveWhiteSpacesInComment |
false |
Preserves whitespaces in a comment. |
prettyxml.settings.addSpaceBeforeEndOfXmlDeclaration |
false |
Add space before end of XML declaration. |
prettyxml.settings.attributesInNewlineThreshold |
1 |
Attributes count threshold to position attributes in newlines. |
prettyxml.settings.enableLogs |
false |
Enables logs |
prettyxml.settings.wildCardedExceptionsForPositionAllAttributesOnFirstLine |
Array<string> |
Wild card exceptions for elements to ignore positionAllAttributesOnFirstLine |
prettyxml.settings.addEmptyLineBetweenElements |
false |
Add empty line between elements if the child count is greater than 2 |
data:image/s3,"s3://crabby-images/5dbf7/5dbf761c8a924619270199758a84465758df50fd" alt="Settings Image."
Attributes In Newline Threshold
Example:
Value = 2
<Element Attribute1="Value1" Attribute2="Value2" />
Output#1
<Element Attribute1="Value1" Attribute2="Value2" />
<Element Attribute1="Value1" Attribute2="Value2" Attribute3="Value3" />
Output#2
<Element Attribute1="Value1"
Attribute2="Value2"
Attribute3="Value3"/>
Wild Carded Exceptions For Position All Attributes On First Line
List of element names to ignore Position All Attributes On First Line setting. Include element names or patterns here.
Example:
"prettyxml.settings.wildCardedExceptionsForPositionAllAttributesOnFirstLine": ["Content*"]
<View>
<Content X="X"
Y="Y" Z="Z">
<Label text="{i18>LabelText}" />
<Input id="Input1"
value="{service>description}" />
</Content>
</View>
Ouput
<View>
<Content X="X"
Y="Y"
Z="Z">
<Label text="{i18>LabelText}" />
<Input id="Input1" value="{service>description}" />
</Content>
</View>
Add Empty Line Between Elements
If enabled, and child elements count is greater than 2 then adds empty line between elements.
[!NOTE]
Please note it wont add empty element before first element and after last element.
<Root>
<Element1>Text1</Element1>
<Element2>Text2</Element2>
<Element3>Text3</Element3>
</Root>
Output 1
<Root>
<Element1>Text1</Element1>
<Element2>Text2</Element2>
<Element3>Text3</Element3>
</Root>
Requirements
Installation
Visual Studio Code - Visual Studio MarketPlace
For VSCodium - open-vsx.org
Known Issues
- Limited DTD support.
- Formats valid XML files only. Syntax errors are displayed.
Issues can be reported at issues section