]> git.sesse.net Git - xml-template/blob - perl-sax/XML/TemplateSAX.pm
Almost fix cloning. Yay!
[xml-template] / perl-sax / XML / TemplateSAX.pm
1 #! /usr/bin/perl
2
3 #
4 # SAX version of XML::Template. Advantages over DOM: Doesn't have to load
5 # the entire thing into memory, and you can chain filters. Disadvantages:
6 # Slightly kludgier interface.
7 #
8 # Differences from the DOM version:
9
10 # - There is no process(). Instead, it works as a SAX filter, so you put it
11 #   in the stream, usually between a parser and a writer (ie.
12 #   parser -> XML::TemplateSAX::Handler -> writer). process_file works as
13 #   before, but it returns a _string_, not a DOM tree.
14 # - You can no longer insert a DOM tree. Instead, what you have is -- FIXME:
15 #   figure out this :-)
16 #
17
18 use XML::SAX::Expat;
19 use XML::SAX::Writer;
20 use XML::TemplateSAX::Buffer;
21 use XML::TemplateSAX::Cleaner;
22 use XML::TemplateSAX::Handler;
23
24 package XML::TemplateSAX;
25
26 sub process_file {
27         my ($filename, $obj, $clean) = @_;
28         $clean = 1 unless (defined($clean));
29
30         my ($writer, $cleaner, $filter, $parser);
31         my $str = '';
32
33         # FIXME: hardcoding expat = not good?
34         $writer = XML::SAX::Writer->new(Output => \$str);
35
36         if ($clean) {
37                 $cleaner = XML::TemplateSAX::Cleaner->new(Handler => $writer, Content => $obj);
38                 $filter = XML::TemplateSAX::Handler->new(Handler => $cleaner, Content => $obj);
39         } else {
40                 $filter = XML::TemplateSAX::Handler->new(Handler => $writer, Content => $obj);
41         }
42
43         $parser = XML::SAX::Expat->new(Handler => $filter);
44         $parser->parse_file($filename);
45
46         return $str;
47 }
48
49 1;