--- nfo/perl/libs/Data/Mungle/Transform/Deep.pm 2003/05/10 17:09:18 1.22 +++ nfo/perl/libs/Data/Mungle/Transform/Deep.pm 2004/06/07 16:44:54 1.24 @@ -1,7 +1,13 @@ ## --------------------------------------------------------------------------- -## $Id: Deep.pm,v 1.22 2003/05/10 17:09:18 jonen Exp $ +## $Id: Deep.pm,v 1.24 2004/06/07 16:44:54 joko Exp $ ## --------------------------------------------------------------------------- ## $Log: Deep.pm,v $ +## Revision 1.24 2004/06/07 16:44:54 joko +## sub expand: Now also converts hash-keys to/from utf-8 +## +## Revision 1.23 2003/05/13 07:39:22 joko +## new option 'define' for "sub expand": set value to empty string if desired +## ## Revision 1.22 2003/05/10 17:09:18 jonen ## + added keep of empty arrays/hashes if 'expand' for php ## @@ -169,6 +175,7 @@ # convert values in hash to utf8 (and back) to be ready for (e.g.) encapsulation in XML # but still using the known latin locale stuff +# TODO: Review: Could this be revamped using Clone.pm? sub expand { my $obj = shift; @@ -207,6 +214,8 @@ $item = latin_to_utf8_scalar($item) if ($item && $options->{utf8}); $item = utf8_to_latin_scalar($item) if ($item && $options->{to_latin}); } + + $item = '' if $options->{define} and not defined $item; #push(@{$result}, $item) if $item; # use item only if not undef (TODO: make configurable via $options) push(@{$result}, $item); # use item in any case @@ -226,8 +235,13 @@ $result = $obj; } else { IterHash %$obj, sub { + my $key = $_[0]; my $item; - + + # conversions/encodings + $key = latin_to_utf8_scalar($key) if ($key && $options->{utf8}); + $key = utf8_to_latin_scalar($key) if ($key && $options->{to_latin}); + # if current item is a reference ... if (ref $_[1]) { $item = $_[1]; @@ -250,8 +264,10 @@ $item = latin_to_utf8_scalar($item) if ($item && $options->{utf8}); $item = utf8_to_latin_scalar($item) if ($item && $options->{to_latin}); } + + $item = '' if $options->{define} and not defined $item; #$result->{$_[0]} = $item if $item; # use item only if not undef (TODO: make configurable via $options) - $result->{$_[0]} = $item; # use item in any case + $result->{$key} = $item; # use item in any case } }