2001-05-23 15:02:58 +00:00
|
|
|
|
2001-10-17 11:51:02 +00:00
|
|
|
#use strict;
|
2001-05-23 15:02:58 +00:00
|
|
|
|
|
|
|
my @xml;
|
|
|
|
|
2002-01-08 09:32:10 +00:00
|
|
|
my $warning=0;
|
|
|
|
my $trace=0;
|
|
|
|
|
2001-05-28 21:49:45 +00:00
|
|
|
sub getpartattr {
|
2002-05-21 22:20:52 +00:00
|
|
|
# if $part is undefined (ie only one argument) then
|
|
|
|
# return the attributes of the section
|
|
|
|
|
2001-05-28 21:49:45 +00:00
|
|
|
my ($section, $part)=@_;
|
|
|
|
|
|
|
|
my %hash;
|
|
|
|
my $inside=0;
|
|
|
|
|
|
|
|
# print "Section: $section, part: $part\n";
|
|
|
|
|
|
|
|
for(@xml) {
|
|
|
|
# print "$inside: $_";
|
|
|
|
if(!$inside && ($_ =~ /^ *\<$section/)) {
|
|
|
|
$inside++;
|
|
|
|
}
|
2002-05-21 22:20:52 +00:00
|
|
|
if((1 ==$inside) && ( ($_ =~ /^ *\<$part([^>]*)/) ||
|
|
|
|
!(defined($part)) )
|
|
|
|
) {
|
2001-05-28 21:49:45 +00:00
|
|
|
$inside++;
|
|
|
|
my $attr=$1;
|
2004-04-30 08:03:07 +00:00
|
|
|
my @p=split("[\t]", $attr);
|
2001-05-28 21:49:45 +00:00
|
|
|
my $assign;
|
|
|
|
|
|
|
|
foreach $assign (@p) {
|
|
|
|
# $assign is a 'name="contents"' pair
|
|
|
|
|
|
|
|
if($assign =~ / *([^=]*)=\"([^\"]*)\"/) {
|
|
|
|
# *with* quotes
|
|
|
|
$hash{$1}=$2;
|
|
|
|
}
|
|
|
|
elsif($assign =~ / *([^=]*)=([^\"]*)/) {
|
|
|
|
# *without* quotes
|
|
|
|
$hash{$1}=$2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
elsif((2 ==$inside) && ($_ =~ /^ *\<\/$part/)) {
|
|
|
|
$inside--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return %hash;
|
|
|
|
}
|
|
|
|
|
2001-05-23 15:02:58 +00:00
|
|
|
sub getpart {
|
|
|
|
my ($section, $part)=@_;
|
|
|
|
|
|
|
|
my @this;
|
|
|
|
my $inside=0;
|
|
|
|
|
|
|
|
# print "Section: $section, part: $part\n";
|
|
|
|
|
|
|
|
for(@xml) {
|
|
|
|
# print "$inside: $_";
|
|
|
|
if(!$inside && ($_ =~ /^ *\<$section/)) {
|
|
|
|
$inside++;
|
|
|
|
}
|
2001-05-28 21:49:45 +00:00
|
|
|
elsif((1 ==$inside) && ($_ =~ /^ *\<$part[ \>]/)) {
|
2001-05-23 15:02:58 +00:00
|
|
|
$inside++;
|
|
|
|
}
|
|
|
|
elsif((2 ==$inside) && ($_ =~ /^ *\<\/$part/)) {
|
|
|
|
$inside--;
|
|
|
|
}
|
|
|
|
elsif((1==$inside) && ($_ =~ /^ *\<\/$section/)) {
|
2002-01-08 09:32:10 +00:00
|
|
|
if($trace) {
|
|
|
|
print STDERR "*** getpart.pm: $section/$part returned data!\n";
|
|
|
|
}
|
|
|
|
if(!@this && $warning) {
|
|
|
|
print STDERR "*** getpart.pm: $section/$part returned empty!\n";
|
|
|
|
}
|
2001-05-23 15:02:58 +00:00
|
|
|
return @this;
|
|
|
|
}
|
|
|
|
elsif(2==$inside) {
|
|
|
|
push @this, $_;
|
|
|
|
}
|
|
|
|
}
|
2002-01-08 09:32:10 +00:00
|
|
|
if($warning) {
|
|
|
|
print STDERR "*** getpart.pm: $section/$part returned empty!\n";
|
|
|
|
}
|
2001-05-23 15:02:58 +00:00
|
|
|
return @this; #empty!
|
|
|
|
}
|
|
|
|
|
|
|
|
sub loadtest {
|
|
|
|
my ($file)=@_;
|
|
|
|
|
|
|
|
undef @xml;
|
2004-02-26 09:19:16 +00:00
|
|
|
|
|
|
|
if(open(XML, "<$file")) {
|
|
|
|
binmode XML; # for crapage systems, use binary
|
|
|
|
while(<XML>) {
|
|
|
|
push @xml, $_;
|
|
|
|
}
|
|
|
|
close(XML);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
# failure
|
2004-02-26 22:56:32 +00:00
|
|
|
if($warning) {
|
|
|
|
print STDERR "file $file wouldn't open!\n";
|
|
|
|
}
|
2004-02-26 09:19:16 +00:00
|
|
|
return 1;
|
2001-05-23 15:02:58 +00:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Strip off all lines that match the specified pattern and return
|
|
|
|
# the new array.
|
|
|
|
#
|
|
|
|
|
|
|
|
sub striparray {
|
|
|
|
my ($pattern, $arrayref) = @_;
|
|
|
|
|
|
|
|
my @array;
|
|
|
|
|
|
|
|
for(@$arrayref) {
|
|
|
|
if($_ !~ /$pattern/) {
|
|
|
|
push @array, $_;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return @array;
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# pass array *REFERENCES* !
|
|
|
|
#
|
|
|
|
sub compareparts {
|
|
|
|
my ($firstref, $secondref)=@_;
|
|
|
|
|
|
|
|
my $sizefirst=scalar(@$firstref);
|
|
|
|
my $sizesecond=scalar(@$secondref);
|
|
|
|
|
|
|
|
if($sizefirst != $sizesecond) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
for(1 .. $sizefirst) {
|
|
|
|
my $index = $_ - 1;
|
|
|
|
if($firstref->[$index] ne $secondref->[$index]) {
|
2001-10-10 21:59:10 +00:00
|
|
|
(my $aa = $firstref->[$index]) =~ s/\r+\n$/\n/;
|
|
|
|
(my $bb = $secondref->[$index]) =~ s/\r+\n$/\n/;
|
|
|
|
if($aa ne $bb) {
|
|
|
|
return 1+$index;
|
|
|
|
}
|
2001-05-23 15:02:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Write a given array to the specified file
|
|
|
|
#
|
|
|
|
sub writearray {
|
|
|
|
my ($filename, $arrayref)=@_;
|
|
|
|
|
|
|
|
open(TEMP, ">$filename");
|
2001-10-10 21:59:10 +00:00
|
|
|
binmode(TEMP,":raw"); # cygwin fix by Kevin Roth
|
2001-05-23 15:02:58 +00:00
|
|
|
for(@$arrayref) {
|
|
|
|
print TEMP $_;
|
|
|
|
}
|
|
|
|
close(TEMP);
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Load a specified file an return it as an array
|
|
|
|
#
|
|
|
|
sub loadarray {
|
|
|
|
my ($filename)=@_;
|
|
|
|
my @array;
|
|
|
|
|
|
|
|
open(TEMP, "<$filename");
|
|
|
|
while(<TEMP>) {
|
|
|
|
push @array, $_;
|
|
|
|
}
|
|
|
|
close(TEMP);
|
|
|
|
return @array;
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Given two array references, this function will store them in two
|
|
|
|
# temporary files, run 'diff' on them, store the result, remove the
|
|
|
|
# temp files and return the diff output!
|
|
|
|
#
|
|
|
|
sub showdiff {
|
|
|
|
my ($firstref, $secondref)=@_;
|
|
|
|
|
2003-04-30 17:15:00 +00:00
|
|
|
my $file1=".generated";
|
|
|
|
my $file2=".expected";
|
2001-05-23 15:02:58 +00:00
|
|
|
|
|
|
|
open(TEMP, ">$file1");
|
|
|
|
for(@$firstref) {
|
|
|
|
print TEMP $_;
|
|
|
|
}
|
|
|
|
close(TEMP);
|
|
|
|
|
|
|
|
open(TEMP, ">$file2");
|
|
|
|
for(@$secondref) {
|
|
|
|
print TEMP $_;
|
|
|
|
}
|
|
|
|
close(TEMP);
|
2003-04-30 17:15:00 +00:00
|
|
|
my @out = `diff -u $file2 $file1`;
|
2001-05-23 15:02:58 +00:00
|
|
|
|
|
|
|
unlink $file1, $file2;
|
|
|
|
return @out;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
1;
|