I have different modules like Author.pm, BillingPeriod.pm, Offer.pm,PaymentMethod.pm etc. now in sax whenever I hit the end element tag I want to create object of module which is equivalent to element value.
How can I achieve this ?
For example if am parsing through XML file and sax parser hit's end element as than it should create object of Offer.pm, similarly if sax parser hit's end element tag as than it should create object of Author.pm
Code
XML: books.xml
<?xml version="1.0" encoding="UTF-8"?>
<!--Sample XML file generated by XMLSpy v2009 sp1 (http://www.altova.com)-->
<bks:books xsi:schemaLocation="urn:books Untitled1.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bks="urn:books">
<book id="String">
<author>String</author>
<authorFirstName>String</authorFirstName>
<authorLastName>String</authorLastName>
<title>String</title>
<titleNo>3</titleNo>
<genre>String</genre>
<offer>String</offer>
<pub_date>1967-08-13</pub_date>
<review>String</review>
<reviewsratings></reviewratings>
</book>
</bks:books>
sax: perlsaxparsing.pl
#!usr/bin/perl -w
use XML::SAX::ParserFactory;
use MySaxHandler;
my $handler = MySaxHandler->new();
my $parser = XML::SAX::ParserFactory->parser(Handler => $handler);
$parser->parse_uri("books.xml")
For example in below example, assuming that sax is hitting Offer end element tag
so am creating object of Offer.pm
I want to create object of modules, for e.g, Offer.pm
in this case when sax hits end element of Offer element tag.
package Offer;
use strict;
# This class depicts the product_offer details
sub new {
my $class = shift;
my $self = {
_objectId => shift,
_price => shift
};
bless $self, $class;
return $self;
}
# Returns the ObjectID
sub getObjectId {
my ($self) = @_;
return $self->{_objectId};
}
# Returns the Price
sub getprice {
my ($self) = @_;
return $self->{_price};
}
# Check for undefined values and build a insert mapping table
sub doPreInsetCheck() {
my ($self) = @_;
my %refTable;
if ( defined $self->getObjectId == 1 ) {
$refTable{'object_id'} = $self->getObjectId;
}
if ( defined $self->getprice == 1 ) {
$refTable{'fk2_price'} = $self->getprice;
}
return %refTable;
}
# Returns the SQL Statement
sub getSQLScript {
my $tableName = 'product_offer';
my ($self) = @_;
my $sqlOutput = "Insert into " . $tableName . "(";
my %refTable = $self->doPreInsetCheck();
my @colNames = keys %refTable;
my $ctr;
foreach ( $ctr = 0 ; $ctr < ( $#colNames + 1 ) ; $ctr++ ) {
$sqlOutput .= $colNames[$ctr];
if ( $ctr < $#colNames ) {
$sqlOutput .= ",";
}
}
$sqlOutput .= ") values (";
my @colVals = values %refTable;
foreach ( $ctr = 0 ; $ctr < ( $#colVals + 1 ) ; $ctr++ ) {
$sqlOutput .= $colVals[$ctr];
if ( $ctr < $#colVals ) {
$sqlOutput .= ",";
}
}
$sqlOutput .= ");";
return $sqlOutput;
}
1;
SAX Parser Handler Module: MySaxHander.pm
sub end_element {
my($self,$data) = @_;
print "\t Ending element:".$data->{Name}."\n";
my $obj = new Price("1","2","NL","ENUM","DESCRIPTION","2008-01-01 10:00:00","2009-01-01 10:00:00","2008-01-01 10:00:00","USER");
print $obj->getSQLScript."\n";
$in_books--;
}
Question: While Parsing through XML file using SAX, How can I create object of module which is equivalent to element value ?