sclable / xml-lint
A php cli tool to lint and validate xml files.
Installs: 514 093
Dependents: 18
Suggesters: 0
Security: 0
Stars: 19
Watchers: 5
Forks: 9
Open Issues: 7
Requires
- php: 8.0.*|8.1.*|8.2.*|8.3.*
- ext-dom: *
- ext-libxml: *
- symfony/console: 5.3.*|5.4.*|6.*|7.*
- symfony/finder: 5.3.*|5.4.*|6.*|7.*
Requires (Dev)
- behat/behat: ^3.0
- phpunit/phpunit: ^9.1
README
A php tool to lint and validate xml files from the commandline.
XML Lint checks the syntax of any xml files and validates the file against the XSD schema defined in the file.
Usage
Installation with Composer
If you'd like to include this library in your project with composer, simply run:
composer require "sclable/xml-lint"
Command Line Usage
To lint a single xml file:
vendor/bin/xmllint path/to/file.xml
To lint a directory and all its subdirectories:
vendor/bin/xmllint path/to/dir
Help
xmllint
has built in cli help screen:
vendor/bin/xmllint --help
Options
-v
be verbose, display the filename of the current file to lint-r 0
don't search recursive (if the argument is a directory)-e name
exclude files or directories containing 'name'-s
skip the xsd validation
Development
Run tests
# check code style php tools/php-cs-fixer/vendor/bin/php-cs-fixer fix --dry-run -v # run tests php vendor/bin/phpunit php vendor/bin/behat
Using docker:
# Example docker build -t xml-lint:php-8.3 --build-arg=PHP_VERSION="8.3" . # PHP_VERSION: choose between 8.0, 8.1, 8.2 and 8.3 docker build -t xml-lint:php-8.0 --build-arg=PHP_VERSION="8.0" . docker build -t xml-lint:php-8.1 --build-arg=PHP_VERSION="8.1" . docker build -t xml-lint:php-8.2 --build-arg=PHP_VERSION="8.2" . docker build -t xml-lint:php-8.3 --build-arg=PHP_VERSION="8.3" . # Run with code style check docker build -t xml-lint:php-8.3 --build-arg=PHP_VERSION="8.3" --build-arg=PHP_CS_FIXER=true . # Use this image to run xml-lint: cd tests/functional/_testdata docker run -it --rm -v "$PWD":/var/src -w /var/src xml-lint:php-8.3 -r -v -- ./
Changelog
For the changelog see the CHANGELOG file
License
For the license and copyright see the LICENSE file