X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FSQL%2FTranslator%2FProducer%2FXML.pm;h=ce60e656ee274fca95d5f12952612a99cce27f7f;hb=821a0fde221f5accf93e3f65efa77b5a6733cb5e;hp=01727ac565595925511111df68b8e91e41ca18e8;hpb=b8792a9734a466b0fef65f7f6281677a64e77c33;p=dbsrgits%2FSQL-Translator.git diff --git a/lib/SQL/Translator/Producer/XML.pm b/lib/SQL/Translator/Producer/XML.pm index 01727ac..ce60e65 100644 --- a/lib/SQL/Translator/Producer/XML.pm +++ b/lib/SQL/Translator/Producer/XML.pm @@ -1,11 +1,9 @@ package SQL::Translator::Producer::XML; # ------------------------------------------------------------------- -# $Id: XML.pm,v 1.7 2003-05-03 15:21:12 kycl4rk Exp $ +# $Id$ # ------------------------------------------------------------------- -# Copyright (C) 2003 Ken Y. Clark , -# darren chamberlain , -# Chris Mungall +# Copyright (C) 2002-4 SQLFairy Authors # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as @@ -22,180 +20,37 @@ package SQL::Translator::Producer::XML; # 02111-1307 USA # ------------------------------------------------------------------- -use strict; -use vars qw[ $VERSION $XML ]; -$VERSION = sprintf "%d.%02d", q$Revision: 1.7 $ =~ /(\d+)\.(\d+)/; - -use SQL::Translator::Utils qw(header_comment); - -# ------------------------------------------------------------------- -sub produce { - my ( $translator, $data ) = @_; - my $prargs = $translator->producer_args; - my $indent = 0; - aggregate('', $indent); - aggregate('', $indent); - aggregate(''); - - $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++; - - for my $key ( keys %$field ) { - my $val = defined $field->{ $key } ? $field->{ $key } : ''; - $val = ref $val eq 'ARRAY' ? join(',', @$val) : $val; - aggregate("<$key>$val", $indent) - if ($val || (!$val && $prargs->{'emit_empty_tags'})); - } - - $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 = shift or return; - my $indent = shift || 0; - $XML .= (' ' x $indent) . "$text\n"; -} - -1; -__END__ - -# ------------------------------------------------------------------- -# The eyes of fire, the nostrils of air, -# The mouth of water, the beard of earth. -# William Blake -# ------------------------------------------------------------------- +=pod =head1 NAME -SQL::Translator::Producer::XML - XML output - -=head1 SYNOPSIS - - use SQL::Translator::Producer::XML; +SQL::Translator::Producer::XML - Alias to XML::SQLFairy producer =head1 DESCRIPTION -Meant to create some sort of usable XML output. - -=head1 ARGS - -Takes the following optional C: +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. -=over 4 - -=item emit_empty_tags - -If this is set to a true value, then tags corresponding to value-less -elements will be emitted. For example, take this schema: - - CREATE TABLE random ( - id int auto_increment PRIMARY KEY, - foo varchar(255) not null default '', - updated timestamp - ); - -With C = 1, this will be dumped with XML similar to: - - - random - 1 - - - 1 - - 1 - int - id - - 1 - 1 - - field - - -With C = 0, you'd get: +=head1 SEE ALSO -
- random - 1 - - - 1 - 1 - int - id - 1 - 1 - field - +SQL::Translator::Producer::XML::SQLFairy. -This can lead to dramatic size savings. +=head1 AUTHOR -=back +Ken Y. Clark Ekclark@cpan.orgE. -=pod +=cut -=head1 AUTHOR +# ------------------------------------------------------------------- -Ken Y. Clark Ekclark@cpan.orgE +use strict; +use vars qw[ $VERSION $DEBUG ]; +$VERSION = sprintf "%d.%02d", q$Revision$ =~ /(\d+)\.(\d+)/; +$DEBUG = 1 unless defined $DEBUG; -=head1 SEE ALSO +use SQL::Translator::Producer::XML::SQLFairy; -XML::Dumper; +*produce = \&SQL::Translator::Producer::XML::SQLFairy::produce; -=cut +1;