diff --git a/lib/YAML/PP/Schema/Perl.pm b/lib/YAML/PP/Schema/Perl.pm index 5f0cc309..d716cdc1 100644 --- a/lib/YAML/PP/Schema/Perl.pm +++ b/lib/YAML/PP/Schema/Perl.pm @@ -23,12 +23,14 @@ sub new { my $dumpcode = $args{dumpcode}; $dumpcode = 1 unless defined $dumpcode; my $classes = $args{classes}; + my $serializer = $args{serializer}; my $self = bless { tags => $tags, loadcode => $loadcode, dumpcode => $dumpcode, classes => $classes, + serializer => $serializer, }, $class; } @@ -40,12 +42,14 @@ sub register { my $loadcode = 0; my $dumpcode = 1; my $classes; + my $serializer; if (blessed($self)) { $tags = $self->{tags}; @$tags = ('!perl') unless @$tags; $loadcode = $self->{loadcode}; $dumpcode = $self->{dumpcode}; $classes = $self->{classes}; + $serializer = $self->{serializer}; } else { my $options = $args{options}; @@ -383,6 +387,13 @@ sub register { my ($rep, $node) = @_; my $blessed = blessed $node->{value}; my $tag_blessed = ":$blessed"; + if (defined $serializer and $node->{value}->can($serializer)) { + my $data = $node->{value}->$serializer; + $node->{value} = $data; + my $r = $rep->represent_node($node); + return $r; + + } if ($blessed !~ m/^$class_regex$/) { $tag_blessed = ''; } diff --git a/t/37.schema-perl.t b/t/37.schema-perl.t index 32805caa..926c8567 100644 --- a/t/37.schema-perl.t +++ b/t/37.schema-perl.t @@ -376,4 +376,43 @@ EOM is $yaml, $exp, "Use -loadcode"; }; +subtest serializer => sub { + *Dice::TO_JSON = sub { + my ($self) = @_; + my $str = join 'd', @$self; + return $str; + }; + my $perl = YAML::PP::Schema::Perl->new( + classes => [], + serializer => 'TO_JSON', + ); + my $yp = YAML::PP::Perl->new( + schema => [qw/ + /, $perl], + ); + my $o = bless [3,4], "Dice"; + my $data = { dice => $o }; + my $yaml = $yp->dump_string($data); + my $exp = <<'EOM'; +--- +dice: 3d4 +EOM + is $yaml, $exp, "TO_JSON returns string"; + + no warnings 'redefine'; + *Dice::TO_JSON = sub { + my ($self) = @_; + my $data = { '__dice__' => [@$self] }; + return $data; + }; + $yaml = $yp->dump_string($data); + $exp = <<'EOM'; +--- +dice: + __dice__: + - 3 + - 4 +EOM + is $yaml, $exp, "TO_JSON returns hash"; +}; + done_testing;