A script to validate XML files for the game 'The Binding of Isaac: Repentance'
Project description
isaac-xml-validator
This repo contains:
- A collection of XSD files used to validate XML files for mods of the game The Binding of Isaac: Repentance. (They were generated with the
online-xml-to-xsd-converter
tool.) - A website that allows end-users to copy paste arbitrary XML data to validate it.
- A Python script which allows you to lint all the XML files in the repository for your mod.
Using the Website
You can view the website here.
Usage in VSCode and Other IDEs
Most people create Binding of Isaac mods (and other software) using VSCode, which is a very nice text editor / IDE.
If you make a typo (or some other error) in your XML file, you can get VSCode to automatically show you the error with a little red squiggly line, which is really helpful. This is accomplished by specifying a link to the corresponding schema at the top of the file.
First, make sure that you have the XML extension by Red Hat installed. Next, add the following to the top of your XML file:
<?xml-model href="https://wofsauge.github.io/isaac-xml-validator/xsd/[NAME OF THE FILE].xsd" ?>
For example, this is how it would look for a "babies.xml" file:
<?xml-model href="https://wofsauge.github.io/isaac-xml-validator/xsd/babies.xsd" ?>
<babies root="gfx/Characters/Player2/">
<baby id="0" name="Spider Baby" skin="000_Baby_Spider.png" />
<baby id="1" name="Love Baby" skin="001_Baby_Love.pngz" /> <!-- shows an error, because the "skin" attribute doesn't contain a .png file, but a .pngz-->
<baby id="2" name="Bloat Baby" skin="002_Baby_Bloat.png" />
</babies>
Note that by default, the XML extension caches the XSD files in the following location:
C:\Users\%USERNAME%\.lemminx\cache\https\wofsauge.github.io\isaac-xml-validator
You can remove this directory if you want to purge the cache to download any potentially updated XSD files.
Using the Python Script
The tool is published to PyPI, so you can install it via:
pip install isaac-xml-validator
Then, you can run it via:
isaac-xml-validator
By default, it will recursively scan for all XML files in the current working directory.
You will likely want to set up your repository so that the script runs in CI (e.g. GitHub Actions).
Usage in GitHub Actions
For most users, you will probably want to manually integrate the Python script into your existing lint routine. Alternatively, you can use a GitHub action that automatically invokes the script.
Usage with Docker
For most users, you will probably want to manually integrate the Python script into your existing lint routine. Alternatively, you can use a Docker Image that contains the script and its dependencies.
Creating New XSD Files
If you need to create new XSD files, you can import our common XML schema like this:
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsisaac="https://wofsauge.github.io/isaac-xml-validator">
<xs:import schemaLocation="https://wofsauge.github.io/isaac-xml-validator/xsd/isaacTypes.xsd" namespace="https://wofsauge.github.io/isaac-xml-validator" />
<xs:element name="Test">
<xs:complexType>
<xs:attribute name="root" type="xsisaac:pngFile" />
</xs:complexType>
</xs:element>
</xs:schema>
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file isaac-xml-validator-1.13.1.tar.gz
.
File metadata
- Download URL: isaac-xml-validator-1.13.1.tar.gz
- Upload date:
- Size: 14.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bbe40749db084dc853bb35088f0e298a55155dfc5f6cfa68a7c27708300bf585 |
|
MD5 | 8a059342abd5fb8f1016586e708eb41c |
|
BLAKE2b-256 | 18ca4cbb0bd0ba2f7f98bb2d7586abaa8089df5ad09d1b40f09a0402ed14d8a1 |
File details
Details for the file isaac_xml_validator-1.13.1-py3-none-any.whl
.
File metadata
- Download URL: isaac_xml_validator-1.13.1-py3-none-any.whl
- Upload date:
- Size: 28.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bdaf71b6ff688e6db01143702b137a2d05b0d8410db87eaf31b68a93ca7f307b |
|
MD5 | 18d0544b17496dad7d95e480c4b367fc |
|
BLAKE2b-256 | d43351b4f5bddbae8ae04a2e298357bc2367a92f5a9053fe4773a7a85e780c83 |