diff --git a/docs/CodeLens.md b/docs/CodeLens.md new file mode 100644 index 00000000..00744513 --- /dev/null +++ b/docs/CodeLens.md @@ -0,0 +1,56 @@ + +## Code Lens + +### DTD features + +Code lens is provided in `.dtd` files to show where elements defined in the DTD are referenced. +For instance, in the following code: + +```xml + + + + + +``` + +There will be a code lens entry after the first line that points from the +definition of the element `to` to where it is used in the definition of the +element `letter`. + +Here is a demonstration of the above Code Lens: + +![A letter DTD element is declared, which consists of to, from title, and body elements. The definitions for these sub elements have a code lens above, which allows ofr navigating to the letter element declaration.](./images/code-lens/DTDElementCodeLens.gif) + +### XSD Features + +Code lens is also provided in `.xsd` files. It shows where top level types +and elements are referenced. For instance, in the following code: + +```xml + + + + + + + + + +``` + +There will be a code lens above the line where the `yell` type is defined +that points to where it is referenced when defining the `root-element` element. + +Here is a demonstration of the above Code Lens: + +![The code lens provides the number of references and links to references for an `xs:simpleType`.](./images/code-lens/XSDTypeCodeLens.gif) + +Here is a demonstration of the code lens for `xs:element`: + +![An element root is declared that contains an element boot. Above the declaration of boot, there is a code lens that links to the reference in root.](./images/code-lens/XSDElementCodeLens.gif) diff --git a/docs/Formatting.md b/docs/Formatting.md index bd78c665..e1c40882 100644 --- a/docs/Formatting.md +++ b/docs/Formatting.md @@ -1,283 +1,335 @@ -## Formatting - -### xml.format.enabled - - Set to `false` to disable XML formatting. Defaults to `true`. - -*** - -### xml.format.enforceQuoteStyle - -Enforce `preferred` quote style (set by `xml.preferences.quoteStyle`) or `ignore` quote style when formatting. - -For instance, when set to `preferred` with `xml.preferences.quoteStyle` set to `single`, the following document: - - ```xml - - - - - ``` - -will be formatted to: - - ```xml - - - - - ``` - -No changes to quotes will occur during formatting if `xml.format.enforceQuoteStyle` is set to `ignore`. - -*** - -### xml.format.emptyElements - -Expand/collapse empty elements. Available values are `ignore`, `collapse` and `expand`. Defaults to `ignore`. -An empty element is an element which is empty or which contains only white spaces. - -Set to `collapse` to collapse empty elements during formatting. - - ```xml - - ``` - becomes... - ```xml - - ``` - -Set to `expand` to expand empty elements during formatting. - - ```xml - - ``` - becomes... - ```xml - - ``` -*** - -### xml.format.preserveAttributeLineBreaks - -Preserve line breaks that appear before and after attributes. This setting is overridden if [xml.format.splitAttributes](Formatting#xmlformatsplitattributes-) is set to `true`. Default is `false`. - -If set to `true`, formatting does not change the following document: - - ```xml - - - - - ``` - -If set to `false`, the document above becomes: - - ```xml - - - - - ``` - -*** - -### xml.format.preservedNewlines - -The number of blank lines to leave between tags during formatting. - -The default is 2. This means that if more than two consecutive empty lines are left in a document, then the number of blank lines will become 2. - - For example, this document: - ```xml - - - - - - - - - - - - - - ``` - - Will be replaced with: - ```xml - - - - - - - - - - - ``` - -If this value is set to 0, then all blank lines will be removed during formatting. - - For example, this document: - ```xml - - - - - - - - ``` - - Will be replaced with: - ```xml - - - - - ``` - -*** - -### xml.format.splitAttributes - - Set to `true` to split node attributes onto multiple lines during formatting. Defaults to `false`. - Overrides the behaviour of [xml.format.preserveAttributeLineBreaks](Formatting#xmlformatpreserveattributelinebreaks) - - ```xml - - ``` - becomes... - ```xml - - ``` - -*** - -### xml.format.joinCDATALines - - Set to `true` to join lines in CDATA content during formatting. Defaults to `false`. - ```xml - - ``` - becomes... - ```xml - - ``` -*** - -### xml.format.preserveEmptyContent - - Set to `true` to preserve empty whitespace content. - ```xml - - - - ``` - becomes... - ```xml - - - ``` -*** -### xml.format.joinCommentLines - - Set to `true` to join lines in comments during formatting. Defaults to `false`. - ```xml - - ``` - becomes... - ```xml - - ``` - -*** - -### xml.format.joinContentLines - -Normalize the whitespace of content inside an element. Newlines and excess whitespace are removed. Default is `false`. - -For example, the following document doesn't change if it is set to `false`: - - ```xml - - - Interesting text content - - - - values and 1234 numbers - - - ``` - -If it is set to `true`, the above document becomes: - - ```xml - - Interesting text content values and 1234 numbers - ``` - -*** - -### xml.format.spaceBeforeEmptyCloseTag - - Set to `true` to insert a space before the end of self closing tags. Defaults to `true` - ```xml - - ``` - becomes... - ```xml - - ``` - -*** - -### files.insertFinalNewline - - Set to `true` to insert a final newline at the end of the document. Defaults to `false` - ```xml - - ``` - becomes... - ```xml - - - - ``` - -*** - -### files.trimFinalNewlines - - Set to `true` to trim final newlines at the end of the document. Defaults to `false` - ```xml - - - - - - ``` - becomes... - ```xml - - ``` - -*** \ No newline at end of file +## Formatting + +### xml.format.enabled + + Set to `false` to disable XML formatting. Defaults to `true`. + +*** + +### xml.format.enforceQuoteStyle + +Enforce `preferred` quote style (set by `xml.preferences.quoteStyle`) or `ignore` quote style when formatting. + +For instance, when set to `preferred` with `xml.preferences.quoteStyle` set to `single`, the following document: + + ```xml + + + + + ``` + +will be formatted to: + + ```xml + + + + + ``` + +No changes to quotes will occur during formatting if `xml.format.enforceQuoteStyle` is set to `ignore`. + +*** + +### xml.format.emptyElements + +Expand/collapse empty elements. Available values are `ignore`, `collapse` and `expand`. Defaults to `ignore`. +An empty element is an element which is empty or which contains only white spaces. + +Set to `collapse` to collapse empty elements during formatting. + + ```xml + + ``` + becomes... + ```xml + + ``` + +Set to `expand` to expand empty elements during formatting. + + ```xml + + ``` + becomes... + ```xml + + ``` +*** + +### xml.format.preserveAttributeLineBreaks + +Preserve line breaks that appear before and after attributes. This setting is overridden if [xml.format.splitAttributes](Formatting#xmlformatsplitattributes-) is set to `true`. Default is `false`. + +If set to `true`, formatting does not change the following document: + + ```xml + + + + + ``` + +If set to `false`, the document above becomes: + + ```xml + + + + + ``` + +*** + +### xml.format.preservedNewlines + +The number of blank lines to leave between tags during formatting. + +The default is 2. This means that if more than two consecutive empty lines are left in a document, then the number of blank lines will become 2. + + For example, this document: + ```xml + + + + + + + + + + + + + + ``` + + Will be replaced with: + ```xml + + + + + + + + + + + ``` + +If this value is set to 0, then all blank lines will be removed during formatting. + + For example, this document: + ```xml + + + + + + + + ``` + + Will be replaced with: + ```xml + + + + + ``` + +*** + +### xml.format.splitAttributes + + Set to `true` to split node attributes onto multiple lines during formatting. Defaults to `false`. + Overrides the behaviour of [xml.format.preserveAttributeLineBreaks](Formatting#xmlformatpreserveattributelinebreaks) + + ```xml + + ``` + becomes... + ```xml + + ``` + +*** + +### xml.format.joinCDATALines + + Set to `true` to join lines in CDATA content during formatting. Defaults to `false`. + ```xml + + ``` + becomes... + ```xml + + ``` +*** + +### xml.format.preserveEmptyContent + + Set to `true` to preserve empty whitespace content. + ```xml + + + + ``` + becomes... + ```xml + + + ``` +*** +### xml.format.joinCommentLines + + Set to `true` to join lines in comments during formatting. Defaults to `false`. + ```xml + + ``` + becomes... + ```xml + + ``` + +*** + +### xml.format.joinContentLines + +Normalize the whitespace of content inside an element. Newlines and excess whitespace are removed. Default is `false`. + +For example, the following document doesn't change if it is set to `false`: + + ```xml + + + Interesting text content + + + + values and 1234 numbers + + + ``` + +If it is set to `true`, the above document becomes: + + ```xml + + Interesting text content values and 1234 numbers + ``` + +*** + +### xml.format.spaceBeforeEmptyCloseTag + + Set to `true` to insert a space before the end of self closing tags. Defaults to `true` + ```xml + + ``` + becomes... + ```xml + + ``` + +*** + +### files.insertFinalNewline + + Set to `true` to insert a final newline at the end of the document. Defaults to `false` + ```xml + + ``` + becomes... + ```xml + + + + ``` + +*** + +### files.trimFinalNewlines + + Set to `true` to trim final newlines at the end of the document. Defaults to `false` + ```xml + + + + + + ``` + becomes... + ```xml + + ``` + +*** +### xml.format.xsiSchemaLocationSplit + + Used to configure how to format the content of `xsi:schemaLocation`. + + To explain the different settings, we will use this xml document as an example: + ```xml + + + + ``` + Note that it references two different external schemas. Additionally, the setting `xml.format.splitAttributes` will be set to true for the formatted examples in order to make the formatted result easier to see. + + * When it is set to `none`, the formatter does not change the content of `xsi:schemaLocation`. The above file would not change after formatting. + + * When it is set to `onPair`, the formatter groups the content into pairs of namespace and URI, and inserts a new line after each pair. Assuming the other formatting settings are left at their default, the above file would look like this: + ```xml + + + + ``` + + * When it is set to `onElement`, the formatter inserts a new line after each namespace and each URI. + ```xml + + + + ``` + +*** + diff --git a/docs/Preferences.md b/docs/Preferences.md new file mode 100644 index 00000000..cd1163b0 --- /dev/null +++ b/docs/Preferences.md @@ -0,0 +1,146 @@ +## File Associations + + Can be accessed through `xml.fileAssociations`. + + Provides ability to associate a schema with a file pattern. + + Example: + ```json + [ + { + "systemId": "path/to/file.xsd", + "pattern": "file1.xml" + }, + { + "systemId": "http://www.w3.org/2001/XMLSchema.xsd", + "pattern": "**/*.xsd" + } + ] + ``` + + Please see [XSD file associations](XMLValidation#xml-file-association-with-xsd) and [DTD file associations](XMLValidation#xml-file-association-with-dtd) for more information. + +## Server VM Arguments + + Can be accessed through `xml.server.vmargs`. + + Setting up proxy: + + A proxy can be defined in the following way if there is a system proxy: + + ``` + -Djava.net.useSystemProxies=true -Dhttp.proxyUser= -Dhttp.proxyPassword= + ``` + + or if there is not a system proxy: + + ``` + -Dhttp.proxyHost= -Dhttp.proxyPort= -Dhttp.proxyUser= + -Dhttp.proxyPassword= -Dhttps.proxyHost= -Dhttps.proxyPort= + ``` + +## Catalogs + + Can be accessed through `xml.catalogs`. + + Catalogs describe a mapping between external entity references and locally cached equivalents. + + The format should include local files and look like: + + ```json + "catalogs": [ + "catalog.xml", + "catalog2.xml" + ] + ``` +## Grammar + + Can be accessed through: `xml.problems.noGrammar` + + When there are issues with grammar constraints like (Catalogs or Associations not properly configured) + you can set message severity of the message the client will receive. + + Options: + +* ignore +* hint **(default)** +* info +* warning +* error + +## Server Cache Path + +Set custom path for cached schemas (eg: XSD). +The path must be absolute, and works with the '~' shortcut for the home directory. + +eg: `~/cache/.lemminxCache` + +The default path is: `~/.lemminx`. + +## Formatting + +See the [Formatting page](Formatting). + +## Code Lens + +Use `xml.codeLens.enabled` in order to enable or disable code lens. Please see [the Code Lens page](CodeLens) for more information. + +## Documentation Type + +Use `xml.preferences.showSchemaDocumentationType` in order to control which documentation is presented during completion and hover for XML documents associated with XSD schemas. +When you hover over an element in an XML document, the documentation is pulled from the `xs:documentation` and `xs:appinfo` elements. These elements are nested under the definition of the hovered element in the schema. + +As an example, here is a schema with documentation: + +```xml + + + + + + + + + + + + Used to distinguish boots of different sizes + The size of the boot + This number is not based on metric or imperial units of measurement + + + + + Used to accurately display the boots color + The color of the boot as an RBG hexadecimal number + + + + + + + + Contains the boots + Holds zero or more boots + + + + + + + + +``` + +The different options are: + * `documentation`: Show only the content of `xs:documentation` elements + * `appinfo`: Show only the content of `xs:appinfo` elements + * `all`: Show the content of `xs:appinfo` and `xs:documentation`, separated by subtitles + * `none`: Neither `xs:appinfo` nor `xs:documentation` are shown. + +Here is a demonstration of the effects of the setting on hovering. The above schema is used in the example: + +![Changing the documentation type setting changes which text the hover shows when hovering over an element that is in a schema document](./images/preferences/HoverDocumentationQuickDemo.gif) diff --git a/docs/Validation.md b/docs/Validation.md index 6202cacb..1c61175a 100644 --- a/docs/Validation.md +++ b/docs/Validation.md @@ -1,296 +1,345 @@ -# XML Validation - -## XML Syntax Errors - -[vscode-xml](https://github.com/redhat-developer/vscode-xml) provides the capability to `report XML syntax errors` when the XML is not valid: - -![XML Syntax Error](images/validation/XMLSyntaxError.png) - -For many of the errors, you can use a `Quick Fix` (code action) to help you fix the XML: - -![XML Syntax Error Code Action](images/validation/XMLSyntaxErrorCodeAction.gif) - -## Validation with a given grammar - -You can `validate your XML with a grammar` (XSD, DTD). In order to do so, you must associate your XML document with a grammar. Once you have done this, you will benefit from: - - * XML `validation` based on the grammar. - * XML `completion` based on the grammar. - * XML `hover` based on the grammar in order to show the documentation. - -## Validation with XSD grammar - -In the following sections, we would like to validate the XML `foo.xml` file: - -```xml - - - -``` - -with the XSD `foo.xsd` file (in the same folder as foo.xml) : - -```xml - - - - - - - - - - -``` - -in order to benefit from validation, completion, and hover based on the XSD: - -![XML Grammar Error](images/validation/XMLGrammarError.png) - -To associate your XML document with an XSD grammar, you can use several strategies: - - * [xsi:noNamespaceSchemaLocation](#xsinonamespaceschemalocation) - * [xsi:schemaLocation](#xsischemalocation) - * [xml-model with XSD](#xml-model-with-XSD) processing instruction - * [XML catalog with XSD](#XML-catalog-with-XSD) - * [XML file association](#XML-file-association) - -If you have an XML without an XSD, you can generate the XSD with a `Quick Fix` (code action): - -![Generate XSD](images/validation/GenerateXSD.gif) - -The Quick Fix will generate the XSD file and associate the XML with the XSD using the chosen strategy. - -### xsi:noNamespaceSchemaLocation - -To bind the XML file `foo.xml` with the XSD file `foo.xsd`, you can use the `xsi:noNamespaceSchemaLocation` strategy like this: - -```xml - - - -``` - -### xsi:schemaLocation - -The `xsi:schemaLocation` strategy is used when the XSD file defines a `targetNamespace="http://foo"` in the root element of the XSD: - -```xml - - - - - - - - - - -``` - -You can bind the XSD like this: - -```xml - - - -``` - -### xml-model with XSD - -To bind the XML file `foo.xml` to the XSD file `foo.xsd`, you can use [xml-model](https://www.w3.org/TR/xml-model/) processing instruction strategy like this: - -```xml - - - - -``` - -### XML catalog with XSD - -Using an XML catalog can be helpful when you wish to use elements from a namespace but don't want to set the real path of the XSD file for each XML document. - -In other words you want to write this XML file: - - -```xml - - - -``` - -and validate it with the `foo.xsd` XSD file: - -```xml - - - - - - - - - - -``` - -To do this, you need to write an XML catalog, and an entry for the XSD. In this example, we'll name the catalog `catalog.xml`. The catalog looks like this: - -```xml - - - - - -``` - -You must register your `catalog.xml` in the vscode `settings.json` like this: - -```json -"xml.catalogs": [ - "catalog.xml" -] -``` - -You can also register the catalog using its absolute path: - -| Windows | MacOS | Linux | -| ---------------------------------- | ---------------------------- | --------------------------- | -| `C:\\Users\\path\\to\\catalog.xml` | `/Users/path/to/catalog.xml` | `/home/path/to/catalog.xml` | - -Please note that you can declare your catalog path with `file:///` if you need it. - -### XML file association - -You can use the XML file association strategy to bind the XML file `foo.xml` with the XSD file `foo.xsd` by adding the following into your vscode `settings.json`: - -```json -"xml.fileAssociations": [ - { - "pattern": "foo.xml", - "systemId": "foo.xsd" - } -] -``` - -Please note that you can use wildcards in the pattern (ex: `foo*.xml`): - -```json -"xml.fileAssociations": [ - { - "pattern": "foo*.xml", - "systemId": "foo.xsd" - } -] -``` - -In this case, all XML files that start with foo and end with .xml will be associated with the XSD (foo1.xml, foo2.xml, etc) - -## Validation with DTD grammar - -To associate your XML with a DTD grammar you can use several strategies: - - * [DOCTYPE](#DOCTYPE) - * [xml-model with DTD](#xml-model-with-DTD) processing instruction - * [XML catalog with DTD](#XML-catalog-with-DTD) - * XML file association is not supported for DTD at the moment. Please see [issue 184](https://github.com/redhat-developer/vscode-xml/issues/184)) - -In the following sections we would like to validate the XML `foo.xml` file: - -```xml - - - -``` - -with the DTD `foo.dtd` file: - -```xml - - -``` - -Please note: this DTD file can be generated with the same Quick Fix which generates the XSD. - -### DOCTYPE - -To bind the XML file `foo.xml` with the DTD file `foo.dtd`, you can use the `DOCTYPE` strategy like this: - -```xml - - - - -``` - -### xml-model with DTD - -To bind XML file `foo.xml` with the DTD file `foo.dtd`, you can use [xml-model](https://www.w3.org/TR/xml-model/) processing instruction strategy like this: - -```xml - - - - -``` - -### XML catalog with DTD - -Using an XML catalog can be helpful when you wish to associate to a DTD using a PUBLIC declaration, but don't want to set the real path of the DTD file (SYSTEM). - -In other words you want to write this XML file: - -```xml - - - - -``` - -and validate it with this `foo.dtd` DTD file: - -```xml - - -``` - -The declared `XXXXXXXXXXXXXXX.dtd` in the DOCTYPE is a file which doesn't exist. The `foo.dtd` will be retrieved using the PUBLIC `-//FOO`. - -To do this, you need to write an XML catalog, and an entry for the DTD. In this example, we'll name the catalog `catalog.xml`. The catalog looks like this: - -```xml - - - - - -``` - -and in vscode `settings.json` you must register your `catalog.xml` like this: - -```json -"xml.catalogs": [ - "catalog.xml" -] -``` - -You can also register the catalog using its absolute path: - -| Windows | MacOS | Linux | -| ---------------------------------- | ---------------------------- | --------------------------- | -| `C:\\Users\\path\\to\\catalog.xml` | `/Users/path/to/catalog.xml` | `/home/path/to/catalog.xml` | +# XML Validation + +## XML Syntax Errors + +[vscode-xml](https://github.com/redhat-developer/vscode-xml) provides the capability to `report XML syntax errors` when the XML is not valid: + +![XML Syntax Error](images/validation/XMLSyntaxError.png) + +For many of the errors, you can use a `Quick Fix` (code action) to help you fix the XML: + +![XML Syntax Error Code Action](images/validation/XMLSyntaxErrorCodeAction.gif) + +## Validation with a given grammar + +You can `validate your XML with a grammar` (XSD, DTD). In order to do so, you must associate your XML document with a grammar. Once you have done this, you will benefit from: + + * XML `validation` based on the grammar. + * XML `completion` based on the grammar. + * XML `hover` based on the grammar in order to show the documentation. + +## Validation with XSD grammar + +In the following sections, we would like to validate the XML `foo.xml` file: + +```xml + + + +``` + +with the XSD `foo.xsd` file (in the same folder as foo.xml) : + +```xml + + + + + + + + + + +``` + +in order to benefit from validation, completion, and hover based on the XSD: + +![XML Grammar Error](images/validation/XMLGrammarError.png) + +To associate your XML document with an XSD grammar, you can use several strategies: + + * [xsi:noNamespaceSchemaLocation](#xsinonamespaceschemalocation) + * [xsi:schemaLocation](#xsischemalocation) + * [xml-model with XSD](#xml-model-with-XSD) processing instruction + * [XML catalog with XSD](#XML-catalog-with-XSD) + * [XML file association](#XML-file-association-with-xsd) + +If you have an XML without an XSD, you can generate the XSD with a `Quick Fix` (code action): + +![Generate XSD](images/validation/GenerateXSD.gif) + +The Quick Fix will generate the XSD file and associate the XML with the XSD using the chosen strategy. + +### xsi:noNamespaceSchemaLocation + +To bind the XML file `foo.xml` with the XSD file `foo.xsd`, you can use the `xsi:noNamespaceSchemaLocation` strategy like this: + +```xml + + + +``` + +### xsi:schemaLocation + +The `xsi:schemaLocation` strategy is used when the XSD file defines a `targetNamespace="http://foo"` in the root element of the XSD: + +```xml + + + + + + + + + + +``` + +You can bind the XSD like this: + +```xml + + + +``` + +### xml-model with XSD + +To bind the XML file `foo.xml` to the XSD file `foo.xsd`, you can use [xml-model](https://www.w3.org/TR/xml-model/) processing instruction strategy like this: + +```xml + + + + +``` + +### XML catalog with XSD + +Using an XML catalog can be helpful when you wish to use elements from a namespace but don't want to set the real path of the XSD file for each XML document. + +In other words you want to write this XML file: + + +```xml + + + +``` + +and validate it with the `foo.xsd` XSD file: + +```xml + + + + + + + + + + +``` + +To do this, you need to write an XML catalog, and an entry for the XSD. In this example, we'll name the catalog `catalog.xml`. The catalog looks like this: + +```xml + + + + + +``` + +You must register your `catalog.xml` in the vscode `settings.json` like this: + +```json +"xml.catalogs": [ + "catalog.xml" +] +``` + +You can also register the catalog using its absolute path: + +| Windows | MacOS | Linux | +| ---------------------------------- | ---------------------------- | --------------------------- | +| `C:\\Users\\path\\to\\catalog.xml` | `/Users/path/to/catalog.xml` | `/home/path/to/catalog.xml` | + +Please note that you can declare your catalog path with `file:///` if you need it. + +### XML file association with XSD + +You can use the XML file association strategy to bind the XML file `foo.xml` with the XSD file `foo.xsd` by adding the following into your vscode `settings.json`: + +```json +"xml.fileAssociations": [ + { + "pattern": "foo.xml", + "systemId": "foo.xsd" + } +] +``` + +Please note that you can use wildcards in the pattern (ex: `foo*.xml`): + +```json +"xml.fileAssociations": [ + { + "pattern": "foo*.xml", + "systemId": "foo.xsd" + } +] +``` + +In this case, all XML files that start with foo and end with .xml will be associated with the XSD (foo1.xml, foo2.xml, etc) + +## Validation with DTD grammar + +To associate your XML with a DTD grammar you can use several strategies: + + * [DOCTYPE](#DOCTYPE) + * [xml-model with DTD](#xml-model-with-DTD) processing instruction + * [XML catalog with DTD](#XML-catalog-with-DTD) + * [XML file association with DTD](#xml-file-association-with-DTD) + +In the following sections we would like to validate the XML `foo.xml` file: + +```xml + + + +``` + +with the DTD `foo.dtd` file: + +```xml + + +``` + +Please note: this DTD file can be generated with the same Quick Fix which generates the XSD. + +### DOCTYPE + +To bind the XML file `foo.xml` with the DTD file `foo.dtd`, you can use the `DOCTYPE` strategy like this: + +```xml + + + + +``` + +### xml-model with DTD + +To bind XML file `foo.xml` with the DTD file `foo.dtd`, you can use [xml-model](https://www.w3.org/TR/xml-model/) processing instruction strategy like this: + +```xml + + + + +``` + +### XML catalog with DTD + +Using an XML catalog can be helpful when you wish to associate to a DTD using a PUBLIC declaration, but don't want to set the real path of the DTD file (SYSTEM). + +In other words you want to write this XML file: + +```xml + + + + +``` + +and validate it with this `foo.dtd` DTD file: + +```xml + + +``` + +The declared `XXXXXXXXXXXXXXX.dtd` in the DOCTYPE is a file which doesn't exist. The `foo.dtd` will be retrieved using the PUBLIC `-//FOO`. + +To do this, you need to write an XML catalog, and an entry for the DTD. In this example, we'll name the catalog `catalog.xml`. The catalog looks like this: + +```xml + + + + + +``` + +and in vscode `settings.json` you must register your `catalog.xml` like this: + +```json +"xml.catalogs": [ + "catalog.xml" +] +``` + +You can also register the catalog using its absolute path: + +| Windows | MacOS | Linux | +| ---------------------------------- | ---------------------------- | --------------------------- | +| `C:\\Users\\path\\to\\catalog.xml` | `/Users/path/to/catalog.xml` | `/home/path/to/catalog.xml` | + + +### XML file association with DTD + +You can use the XML file association strategy to bind the XML file `foo.xml` with the DTD file `foo.dtd` by adding the following into your vscode `settings.json`: + +```json +"xml.fileAssociations": [ + { + "pattern": "foo.xml", + "systemId": "foo.dtd" + } +] +``` + +Please note that you can use wildcards in the pattern (ex: `foo*.xml`): + +```json +"xml.fileAssociations": [ + { + "pattern": "foo*.xml", + "systemId": "foo.dtd" + } +] +``` + +In this case, all XML files that start with foo and end with .xml will be associated with the DTD (foo1.xml, foo2.xml, etc) + + + +# Other Validation Settings + +## Disallow Doc Type Declarations + +If `xml.validation.disallowDocTypeDeclaration` is set to `true` (default is `false`), all Doc Type Declarations (DTD) will be marked as errors. The DOCTYPE is marked as an error regardless if the doctype is an internally declared or a reference to an external DTD. Standalone `.dtd` files are not marked as an error. + +Here are some examples of files with `xml.validation.disallowDocTypeDeclaration` set to true: + +![A DOCTYPE declared inline is marked as an error](./images/disallow-doctype/DoctypeError1.png) + +![A reference to an external DOCTYPE is marked as an error](./images/disallow-doctype/DoctypeError2.png) + +## Resolve External Entities + +If `xml.validation.resolveExternalEntities` is set to `true` (default is `false`), then the value of [external entities](https://www.w3schools.com/xml/xml_dtd_entities.asp) are resolved for validation. This means that the file referenced in the external entity declaration will be downloaded. The default is `false` due to [the xml external entity attack](https://en.wikipedia.org/wiki/XML_external_entity_attack). + +Demonstration of the different behaviour: + +![When using the default settings, an external entity that has an XML element as its content will not produce a validation error when nested in an element that expects character content. If `xml.validation.resolveExternalEntities` is enabled, then an error will be produced](./images/validation/ExternalEntityResolvingDemonstration.gif) diff --git a/docs/images/code-lens/DTDElementCodeLens.gif b/docs/images/code-lens/DTDElementCodeLens.gif new file mode 100644 index 00000000..b49eace8 Binary files /dev/null and b/docs/images/code-lens/DTDElementCodeLens.gif differ diff --git a/docs/images/code-lens/XSDElementCodeLens.gif b/docs/images/code-lens/XSDElementCodeLens.gif new file mode 100644 index 00000000..f479b2a5 Binary files /dev/null and b/docs/images/code-lens/XSDElementCodeLens.gif differ diff --git a/docs/images/code-lens/XSDTypeCodeLens.gif b/docs/images/code-lens/XSDTypeCodeLens.gif new file mode 100644 index 00000000..079f9561 Binary files /dev/null and b/docs/images/code-lens/XSDTypeCodeLens.gif differ diff --git a/docs/images/disallow-doctype/DoctypeError1.png b/docs/images/disallow-doctype/DoctypeError1.png new file mode 100644 index 00000000..16a3ad77 Binary files /dev/null and b/docs/images/disallow-doctype/DoctypeError1.png differ diff --git a/docs/images/disallow-doctype/DoctypeError2.png b/docs/images/disallow-doctype/DoctypeError2.png new file mode 100644 index 00000000..daaf6a81 Binary files /dev/null and b/docs/images/disallow-doctype/DoctypeError2.png differ diff --git a/docs/images/preferences/HoverDocumentationQuickDemo.gif b/docs/images/preferences/HoverDocumentationQuickDemo.gif new file mode 100644 index 00000000..74c6cc58 Binary files /dev/null and b/docs/images/preferences/HoverDocumentationQuickDemo.gif differ diff --git a/docs/images/validation/ExternalEntityResolvingDemonstration.gif b/docs/images/validation/ExternalEntityResolvingDemonstration.gif new file mode 100644 index 00000000..f7e2c10c Binary files /dev/null and b/docs/images/validation/ExternalEntityResolvingDemonstration.gif differ diff --git a/package.json b/package.json index e70533d3..11f4ae39 100644 --- a/package.json +++ b/package.json @@ -152,7 +152,7 @@ "pattern" ] }, - "markdownDescription": "Allows XML schemas/ DTD to be associated to file name patterns.\n\nExample:\n```json\n[{\n \"systemId\": \"path/to/file.xsd\",\n \"pattern\": \"file1.xml\"\n},\n{\n \"systemId\": \"http://www.w3.org/2001/XMLSchema.xsd\",\n \"pattern\": \"**/*.xsd\"\n}]\n```", + "markdownDescription": "Allows XML schemas/ DTD to be associated to file name patterns. Please refer to [the validation documentation](command:xml.open.docs?%5B%7B%22page%22%3A%22Validation%22%2C%22section%22%3A%22xml-file-association%22%7D%5D) for more information. \n\nExample:\n```json\n[{\n \"systemId\": \"path/to/file.xsd\",\n \"pattern\": \"file1.xml\"\n},\n{\n \"systemId\": \"http://www.w3.org/2001/XMLSchema.xsd\",\n \"pattern\": \"**/*.xsd\"\n}]\n```", "scope": "window" }, "xml.format.enabled": { @@ -247,7 +247,7 @@ "Ignore `xsi:schemaLocation` content formatting." ], "default": "none", - "markdownDescription": "Split `xsi:schemaLocation` content. Default is `none`", + "markdownDescription": "Split `xsi:schemaLocation` content. Default is `none`. Please see [here](command:xml.open.docs?%5B%7B%22page%22%3A%22Formatting%22%2C%22section%22%3A%22xmlformatxsischemalocationsplit%22%7D%5D) for more information", "scope": "window" }, "xml.format.splitAttributes": { @@ -275,7 +275,7 @@ "xml.codeLens.enabled": { "type": "boolean", "default": false, - "description": "Enable/disable XML CodeLens. Default is `false`." + "markdownDescription": "Enable/disable XML CodeLens. Default is `false`. See [here](command:xml.open.docs?%5B%7B%22page%22%3A%22Code-Lens%22%2C%22section%22%3A%22Code%20Lens%22%7D%5D) for information about CodeLens features" }, "xml.preferences.showSchemaDocumentationType": { "type": "string", @@ -292,7 +292,7 @@ "Documentation comes from the `xs:documentation` and `xs:appinfo` elements.", "Displays no documentation." ], - "markdownDescription": "Specifies the source of the XML schema documentation displayed on hover and completion. Default is `all`.", + "markdownDescription": "Specifies the source of the XML schema documentation displayed on hover and completion. Default is `all`. Please see [here](command:xml.open.docs?%5B%7B%22page%22%3A%22Preferences%22%2C%22section%22%3A%22documentation-type%22%7D%5D) for more information.", "scope": "window" }, "xml.validation.enabled": { @@ -310,13 +310,13 @@ "xml.validation.disallowDocTypeDecl": { "type": "boolean", "default": false, - "markdownDescription": "Enable/disable if a fatal error is thrown if the incoming document contains a DOCTYPE declaration. Default is `false`.", + "markdownDescription": "Enable/disable if a fatal error is thrown if the incoming document contains a DOCTYPE declaration. Default is `false`. See [here](command:xml.open.docs?%5B%7B%22page%22%3A%22Validation%22%2C%22section%22%3A%22disallow-doc-type-declarations%22%7D%5D) for more information", "scope": "window" }, "xml.validation.resolveExternalEntities": { "type": "boolean", "default": false, - "markdownDescription": "Enable/disable resolve of external entities. Default is `false`.", + "markdownDescription": "Enable/disable resolve of external entities. Default is `false`. See [here](command:xml.open.docs?%5B%7B%22page%22%3A%22Validation%22%2C%22section%22%3A%22resolve-external-entities%22%7D%5D) for more information.", "scope": "window" }, "xml.validation.noGrammar": {