X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FSQL%2FTranslator%2FProducer%2FXML.pm;h=3cc8bdb7389717b4e952b25d85a67db74fec5c40;hb=41c5ac17e47b48ba9d95bec28823fb67e0198966;hp=66b3e88d42573d092cb99395a5b06140aad2a78b;hpb=61745327179965ba143356ac46c3e0ce37cc60a8;p=dbsrgits%2FSQL-Translator.git diff --git a/lib/SQL/Translator/Producer/XML.pm b/lib/SQL/Translator/Producer/XML.pm index 66b3e88..3cc8bdb 100644 --- a/lib/SQL/Translator/Producer/XML.pm +++ b/lib/SQL/Translator/Producer/XML.pm @@ -1,10 +1,9 @@ package SQL::Translator::Producer::XML; # ------------------------------------------------------------------- -# $Id: XML.pm,v 1.4 2002-11-28 04:21:07 kycl4rk Exp $ +# $Id: XML.pm,v 1.14 2003-08-21 01:06:52 kycl4rk Exp $ # ------------------------------------------------------------------- -# Copyright (C) 2002 Ken Y. Clark , -# darren chamberlain +# Copyright (C) 2003 Ken Y. Clark . # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as @@ -21,118 +20,31 @@ package SQL::Translator::Producer::XML; # 02111-1307 USA # ------------------------------------------------------------------- +=pod + =head1 NAME -SQL::Translator::Producer::XML - XML output +SQL::Translator::Producer::XML - Alias to XML::SQLFairy producer =head1 SYNOPSIS - use SQL::Translator::Producer::XML; +Previous versions of SQL::Translator included an XML producer, but the +namespace has since been further subdivided. Therefore, this module is +now just just an alias to the XML::SQLFairy producer. -=head1 DESCRIPTION +=head1 AUTHOR -Meant to create some sort of usable XML output. +Ken Y. Clark Ekclark@cpan.orgE. =cut use strict; -use vars qw[ $VERSION $XML ]; -$VERSION = sprintf "%d.%02d", q$Revision: 1.4 $ =~ /(\d+)\.(\d+)/; - -# ------------------------------------------------------------------- -sub produce { - my ( $translator, $data ) = @_; - my $indent = 0; - aggregate( '', $indent ); - - $indent++; - for my $table ( - map { $_->[1] } - sort { $a->[0] <=> $b->[0] } - map { [ $_->{'order'}, $_ ] } - values %$data - ) { - aggregate( '', $indent ); - $indent++; - - aggregate( "$table->{'table_name'}", $indent ); - aggregate( "$table->{'order'}", $indent ); - - # - # Fields - # - aggregate( '', $indent ); - for my $field ( - map { $_->[1] } - sort { $a->[0] <=> $b->[0] } - map { [ $_->{'order'}, $_ ] } - values %{ $table->{'fields'} } - ) { - aggregate( '', ++$indent ); - $indent++; +use vars qw[ $VERSION $DEBUG ]; +$VERSION = sprintf "%d.%02d", q$Revision: 1.14 $ =~ /(\d+)\.(\d+)/; +$DEBUG = 1 unless defined $DEBUG; - for my $key ( keys %$field ) { - my $val = defined $field->{ $key } ? $field->{ $key } : ''; - $val = ref $val eq 'ARRAY' ? join(',', @$val) : $val; - aggregate( "<$key>$val", $indent ); - } +use SQL::Translator::Producer::XML::SQLFairy; - $indent--; - aggregate( "", $indent-- ); - } - aggregate( "", $indent ); - - # - # Indices - # - aggregate( '', $indent ); - for my $index ( @{ $table->{'indices'} } ) { - aggregate( '', ++$indent ); - $indent++; - - for my $key ( keys %$index ) { - my $val = defined $index->{ $key } ? $index->{ $key } : ''; - $val = ref $val eq 'ARRAY' ? join(',', @$val) : $val; - aggregate( "<$key>$val", $indent ); - } - - $indent--; - aggregate( "", $indent-- ); - } - aggregate( "", $indent ); - - $indent--; - aggregate( "
", $indent ); - } - - $indent--; - aggregate( '
', $indent ); - - return $XML; -} - -# ------------------------------------------------------------------- -sub aggregate { - my ( $text, $indent ) = @_; - $XML .= (' ' x $indent) . "$text\n"; -} +*produce = \&SQL::Translator::Producer::XML::SQLFairy::produce; 1; - -# ------------------------------------------------------------------- -# The eyes of fire, the nostrils of air, -# The mouth of water, the beard of earth. -# William Blake -# ------------------------------------------------------------------- - -=pod - -=head1 AUTHOR - -Ken Y. Clark Ekclark@cpan.orgE - -=head1 SEE ALSO - -XML::Dumper; - -=cut