1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
|
# /=====================================================================\ #
# | LaTeXML::Common::XML::Parser | #
# | XML Parser (wrapper for XML::LibXML | #
# |=====================================================================| #
# | Part of LaTeXML: | #
# | Public domain software, produced as part of work done by the | #
# | United States Government & not subject to copyright in the US. | #
# |---------------------------------------------------------------------| #
# | Bruce Miller <bruce.miller@nist.gov> #_# | #
# | http://dlmf.nist.gov/LaTeXML/ (o o) | #
# \=========================================================ooo==U==ooo=/ #
package LaTeXML::Common::XML::Parser;
use strict;
use warnings;
use XML::LibXML;
sub new {
my ($class) = @_;
my $parser = XML::LibXML->new();
$parser->validation(0);
return bless { parser => $parser }, $class; }
sub parseFile {
my ($self, $file) = @_;
LaTeXML::Common::XML::initialize_catalogs();
# LaTeXML::Common::XML::initialize_input_callbacks($$self{parser});
if (((-s $file) || 0) > 20_000_000) {
$$self{parser}->set_option('huge', 1); }
return $$self{parser}->parse_file($file); }
sub parseString {
my ($self, $string) = @_;
return $$self{parser}->parse_string($string); }
# Note: This expects only a single node, not a document fragment.
sub parseChunk {
my ($self, $string) = @_;
my $xml = $$self{parser}->parse_string($string);
return $xml && $xml->documentElement; }
#======================================================================
1;
|