package XML::Hash::XS; use 5.008008; use strict; no strict 'refs'; use warnings; use base 'Exporter'; our @EXPORT_OK = our @EXPORT = qw( hash2xml ); our $VERSION = '0.10'; require XSLoader; XSLoader::load('XML::Hash::XS', $VERSION); our $root = 'root'; our $version = '1.0'; our $encoding = 'utf-8'; our $indent = 0; our $canonical = 0; our $use_attr = 0; our $content = undef; our $xml_decl = 1; my @OPTIONS_LIST = qw/ root version encoding indent canonical use_attr content xml_decl /; sub hash2xml { my ($hash, @options) = @_; my %options = ( (map {$_ => ${$_}} @OPTIONS_LIST), output => 'string', @options, ); my $output = $options{output}; if ( $output eq 'string' ) { _hash2xml2string( $hash, @options{@OPTIONS_LIST} ); } elsif ( ref($output) ) { _hash2xml2fh( $output, $hash, @options{@OPTIONS_LIST} ); } else { die "Invalid output type"; } } 1; __END__ =head1 NAME XML::Hash::XS - Simple and fast hash to XML conversion =head1 SYNOPSIS use XML::Hash::XS; my $xmlstr = hash2xml \%hash; hash2xml \%hash, output => $FH; =head1 DESCRIPTION This module implements simple hash to XML converter written in C using libxml2 library. =head1 FUNCTIONS =head2 hash2xml $hash, [ %options ] $hash is reference to hash hash2xml { node1 => 'value1', node2 => [ 'value21', { node22 => 'value22' } ], node3 => \'value3', node4 => sub { return 'value4' }, node5 => sub { return { node51 => 'value51' } }, }, canonical => 1, indent => 2, ; will convert to: value1 value21 value22 value3 value4 value51 and (use_attr=1): hash2xml { node1 => 'value1', node2 => [ 'value21', { node22 => 'value22' } ], node3 => \'value3', node4 => sub { return 'value4' }, node5 => sub { return { node51 => 'value51' } }, }, use_attr => 1, canonical => 1, indent => 2, ; will convert to: value21 =head1 OPTIONS =over 4 =item root [ = 'root' ] Root node name. =item version [ = '1.0' ] XML document version =item encoding [ = 'utf-8' ] XML output encoding =item indent [ = 0 ] if indent great than "0", XML output should be indented according to its hierarchic structure. This value determines the number of spaces. if indent is "0", XML output will all be on one line. =item output [ = undef ] XML output method if output is undefined, XML document dumped into string. if output is FH, XML document writes directly to a filehandle or a stream. =item canonical [ = 0 ] if canonical is "1", converter will be write hashes sorted by key. if canonical is "0", order of the element will be pseudo-randomly. =item use_attr [ = 0 ] if use_attr is "1", converter will be use the attributes. if use_attr is "0", converter will be use tags only. =item content [ = undef ] if defined that the key name for the text content(used only if use_attr=1). =item xml_decl [ = 1 ] if xml_decl is "1", output will start with the XML declaration ''. if xml_decl is "0", XML declaration will not be output. =back =head1 AUTHOR =over 4 Yuriy Ustushenko, EE =back =head1 COPYRIGHT AND LICENSE Copyright (C) 2012 Yuriy Ustushenko This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut