"""
Various XML-related utilities
"""
from __future__ import division, absolute_import
# ASTROPY
from ...utils.xml import check as xml_check
from ...utils.xml import validate
# LOCAL
from .exceptions import (warn_or_raise, vo_warn,
W02, W03, W04, W05)
from ...utils import data
__all__ = [
'check_id', 'fix_id', 'check_token', 'check_mime_content_type',
'check_anyuri', 'validate_schema'
]
[docs]def check_id(ID, name='ID', config={}, pos=None):
"""
Raises a `~astropy.io.votable.exceptions.VOTableSpecError` if *ID*
is not a valid XML ID_.
*name* is the name of the attribute being checked (used only for
error messages).
"""
if (ID is not None and not xml_check.check_id(ID)):
warn_or_raise(W02, W02, (name, ID), config, pos)
return False
return True
[docs]def fix_id(ID, config={}, pos=None):
"""
Given an arbitrary string, create one that can be used as an xml id.
This is rather simplistic at the moment, since it just replaces
non-valid characters with underscores.
"""
if ID is None:
return None
corrected = xml_check.fix_id(ID)
if corrected != ID:
vo_warn(W03, (ID, corrected), config, pos)
return corrected
_token_regex = r"(?![\r\l\t ])[^\r\l\t]*(?![\r\l\t ])"
[docs]def check_token(token, attr_name, config={}, pos=None):
"""
Raises a `ValueError` if *token* is not a valid XML token.
As defined by XML Schema Part 2.
"""
if (token is not None and not xml_check.check_token(token)):
return False
return True
[docs]def check_mime_content_type(content_type, config={}, pos=None):
"""
Raises a `~astropy.io.votable.exceptions.VOTableSpecError` if
*content_type* is not a valid MIME content type.
As defined by RFC 2045 (syntactically, at least).
"""
if (content_type is not None and
not xml_check.check_mime_content_type(content_type)):
warn_or_raise(W04, W04, content_type, config, pos)
return False
return True
[docs]def check_anyuri(uri, config={}, pos=None):
"""
Raises a `~astropy.io.votable.exceptions.VOTableSpecError` if
*uri* is not a valid URI.
As defined in RFC 2396.
"""
if (uri is not None and not xml_check.check_anyuri(uri)):
warn_or_raise(W05, W05, uri, config, pos)
return False
return True
[docs]def validate_schema(filename, version='1.2'):
"""
Validates the given file against the appropriate VOTable schema.
Parameters
----------
filename : str
The path to the XML file to validate
version : str
The VOTABLE version to check, which must be a string \"1.0\",
\"1.1\", or \"1.2\".
For version \"1.0\", it is checked against a DTD, since that
version did not have an XML Schema.
Returns
-------
returncode, stdout, stderr : int, str, str
Returns the returncode from xmllint and the stdout and stderr
as strings
"""
assert version in ('1.0', '1.1', '1.2')
if version in ('1.1', '1.2'):
schema_path = data.get_pkg_data_filename(
'data/VOTable.v{0}.xsd'.format(version))
else:
schema_path = data.get_pkg_data_filename(
'data/VOTable.dtd')
return validate.validate_schema(filename, schema_path)