summaryrefslogtreecommitdiffstats
path: root/textproc/intltool/files
diff options
context:
space:
mode:
Diffstat (limited to 'textproc/intltool/files')
-rw-r--r--textproc/intltool/files/OrigTree.pm91
-rw-r--r--textproc/intltool/files/patch-configure14
2 files changed, 105 insertions, 0 deletions
diff --git a/textproc/intltool/files/OrigTree.pm b/textproc/intltool/files/OrigTree.pm
new file mode 100644
index 000000000..16a02bfdd
--- /dev/null
+++ b/textproc/intltool/files/OrigTree.pm
@@ -0,0 +1,91 @@
+# $Id: OrigTree.pm,v 1.5 2008-06-05 12:50:44 kwm Exp $
+
+package XML::Parser::Style::OrigTree;
+$XML::Parser::Built_In_Styles{OrigTree} = 1;
+
+sub Init {
+ my $expat = shift;
+ $expat->{Lists} = [];
+ $expat->{Curlist} = $expat->{OrigTree} = [];
+}
+
+sub Start {
+ my $expat = shift;
+ my $tag = shift;
+ my $newlist = [ { @_ } ];
+ push @{ $expat->{Lists} }, $expat->{Curlist};
+ push @{ $expat->{Curlist} }, $tag => $newlist;
+ $expat->{Curlist} = $newlist;
+}
+
+sub End {
+ my $expat = shift;
+ my $tag = shift;
+ $expat->{Curlist} = pop @{ $expat->{Lists} };
+}
+
+sub Char {
+ my $expat = shift;
+ my $text = shift;
+ my $clist = $expat->{Curlist};
+ my $pos = $#$clist;
+
+ if ($pos > 0 and $clist->[$pos - 1] eq '0') {
+ $clist->[$pos] .= $expat->original_string();
+ } else {
+ push @$clist, 0 => $expat->original_string();
+ }
+}
+
+sub Final {
+ my $expat = shift;
+ delete $expat->{Curlist};
+ delete $expat->{Lists};
+ $expat->{OrigTree};
+}
+
+1;
+__END__
+
+=head1 NAME
+
+XML::Parser::Style::OrigTree
+
+=head1 SYNOPSIS
+
+ use XML::Parser;
+ my $p = XML::Parser->new(Style => 'OrigTree');
+ my $tree = $p->parsefile('foo.xml');
+
+=head1 DESCRIPTION
+
+This module is a variant of the XML::Parser's Tree style parser. It
+uses original_string, so that Entities are not converted.
+
+When parsing a document, C<parse()> will return a parse tree for the
+document. Each node in the tree
+takes the form of a tag, content pair. Text nodes are represented with
+a pseudo-tag of "0" and the string that is their content. For elements,
+the content is an array reference. The first item in the array is a
+(possibly empty) hash reference containing attributes. The remainder of
+the array is a sequence of tag-content pairs representing the content
+of the element.
+
+So for example the result of parsing:
+
+ <foo><head id="a">Hello <em>there</em></head><bar>Howdy<ref/></bar>do</foo>
+
+would be:
+ Tag Content
+ ==================================================================
+ [foo, [{}, head, [{id => "a"}, 0, "Hello ", em, [{}, 0, "there"]],
+ bar, [ {}, 0, "Howdy", ref, [{}]],
+ 0, "do"
+ ]
+ ]
+
+The root document "foo", has 3 children: a "head" element, a "bar"
+element and the text "do". After the empty attribute hash, these are
+represented in it's contents by 3 tag-content pairs.
+
+=cut
diff --git a/textproc/intltool/files/patch-configure b/textproc/intltool/files/patch-configure
new file mode 100644
index 000000000..7c8e7f99e
--- /dev/null
+++ b/textproc/intltool/files/patch-configure
@@ -0,0 +1,14 @@
+
+$FreeBSD: ports/textproc/intltool/files/patch-configure,v 1.5 2008/03/24 03:50:21 marcus Exp $
+
+--- configure.orig Mon May 20 01:34:39 2002
++++ configure Fri May 24 10:52:12 2002
+@@ -1452,7 +1452,7 @@
+ echo "$as_me: error: perl not found" >&2;}
+ { (exit 1); exit 1; }; }
+ fi
+-if test -z "`$PERL -v | fgrep 'v5.' 2> /dev/null`" -a -z "`$PERL -v | fgrep 'version 5.' 2> /dev/null`"; then
++if test -z "`$PERL -v | fgrep '5.' 2> /dev/null`" -a -z "`$PERL -v | fgrep 'version 5.' 2> /dev/null`"; then
+ { { echo "$as_me:$LINENO: error: perl 5.x required for intltool" >&5
+ echo "$as_me: error: perl 5.x required for intltool" >&2;}
+ { (exit 1); exit 1; }; }