XML language #
The jetbrains.mps.core.xml language is designed to model closely XML documents in MPS. The language aims at being a 1:1 match to plain XML and is generated into textual XML files.
Structure #
The XmlFile root element should be used to represent an XML file.
data:image/s3,"s3://crabby-images/2362b/2362b424d5f37f40951cacece936f1872db585d4" alt="xml1 xml1"
It contains a single XmlDocument node, which itself holds one or more prolog entries and a root xml element:
data:image/s3,"s3://crabby-images/a4a3e/a4a3ef3fb4cb1fb802992eeed67f150eaef41116" alt="xml2 xml2"
There are several types of prolog elements to choose from and customize:
data:image/s3,"s3://crabby-images/95d41/95d410c1654fddb1c7d818a119e805dd9f399418" alt="xml3 xml3"
Use the Enter key to separate entries in the prolog, either within the same line or across multiple lines.
Editing #
The elements, their attributes and values can then be entered naturally. The XML-specific symbols, such as e.g. '<', '>', '=', 'space', "&", are recognized as delimiters and the automatically invoked transformations will correctly insert proper instances of the desired concepts - XmlElement, XmlAttribute, XmlText, XmlTextValue, XmlEntityRef, XmlEntityRefValue, XmlComment and other. Code-completion should assist you to complete unfinished elements with little effort.
data:image/s3,"s3://crabby-images/12600/1260011e1eed441c4d215d66da09e5a35ab31293" alt="xml4 xml4"
Generation #
The language is transformed into textual XML using the TextGen aspect.
data:image/s3,"s3://crabby-images/f3dbc/f3dbca3edfda6f90d89d8ed88f7049c5c13f2cff" alt="xml5 xml5"