NAME

XML::Validate::MSXML - Interface to MSXML validator

SYNOPSIS

my $validator = new XML::Validate::MSXML(%options);
if ($doc = $validator->validate($xml)) {
  ... Do stuff with $doc ...
} else {
  print "Document is invalid\n";
}

DESCRIPTION

XML::Validate::MSXML is an interface to Microsoft's MSXML parser (often available in Windows environments) which can be used with the XML::Validate module.

METHODS

new(%options)

Returns a new XML::Validate::MSXML instance using the specified options. (See OPTIONS below.)

validate($xml)

Returns true if $xml could be successfully parsed, undef otherwise.

last_dom()

Returns the MSXML DOM object of the document last validated.

last_error()

Returns the error from the last validate call. This is a hash ref with the following fields:

  • message

  • line

  • column

Note that the error gets cleared at the beginning of each validate call.

version()

Returns the version of the MSXML component that is installed

OPTIONS

XML::Validate::MSXML takes the following options:

strict_validation

If this boolean value is true, the document will be validated during parsing. Otherwise it will only be checked for well-formedness. Defaults to true.

ERROR REPORTING

When a call to validate fails to parse the document, the error may be retrieved using last_error.

On errors not related to the XML parsing, these methods will throw exceptions. Wrap calls with eval to catch them.

PACKAGE GLOBALS

$XML::Validate::MSXML::MSXML_VERSION contains the version number of MSXML.

DEPENDENCIES

Win32::OLE, MSXML 4.0 or 5.0

VERSION

$Revision: 1.17 $ on $Date: 2005/10/07 07:59:53 $ by $Author: johna $

AUTHOR

Nathan Carr, Colin Robertson

<cpan _at_ bbc _dot_ co _dot_ uk>

COPYRIGHT

(c) BBC 2005. This program is free software; you can redistribute it and/or modify it under the GNU GPL. See the file COPYING in this distribution, or http://www.gnu.org/licenses/gpl.txt