| OLD | NEW |
| (Empty) |
| 1 #!/usr/bin/perl | |
| 2 | |
| 3 use strict; | |
| 4 use warnings; | |
| 5 use Benchmark qw( cmpthese timethese ); | |
| 6 | |
| 7 our $VERSION = '1.00'; | |
| 8 | |
| 9 my $wanttime = $ARGV[1] || 5; | |
| 10 | |
| 11 use JSON qw( -support_by_pp -no_export ); # for JSON::PP::Boolean inheritance | |
| 12 use JSON::PP (); | |
| 13 use JSON::XS (); | |
| 14 use utf8; | |
| 15 | |
| 16 my $pp = JSON::PP->new->utf8; | |
| 17 my $xs = JSON::XS->new->utf8; | |
| 18 | |
| 19 local $/; | |
| 20 | |
| 21 my $json = <>; | |
| 22 my $perl = JSON::XS::decode_json $json; | |
| 23 my $result; | |
| 24 | |
| 25 | |
| 26 printf( "JSON::PP %s\n", JSON::PP->VERSION ); | |
| 27 printf( "JSON::XS %s\n", JSON::XS->VERSION ); | |
| 28 | |
| 29 | |
| 30 print "-----------------------------------\n"; | |
| 31 print "->decode()\n"; | |
| 32 print "-----------------------------------\n"; | |
| 33 | |
| 34 $result = timethese( -$wanttime, | |
| 35 { | |
| 36 'JSON::PP' => sub { $pp->decode( $json ) }, | |
| 37 'JSON::XS' => sub { $xs->decode( $json ) }, | |
| 38 }, | |
| 39 'none' | |
| 40 ); | |
| 41 cmpthese( $result ); | |
| 42 | |
| 43 print "-----------------------------------\n"; | |
| 44 | |
| 45 | |
| 46 __END__ | |
| 47 | |
| 48 =pod | |
| 49 | |
| 50 =head1 SYNOPSYS | |
| 51 | |
| 52 bench_decode.pl json-file | |
| 53 # or | |
| 54 bench_decode.pl json-file minimum-time | |
| 55 | |
| 56 =head1 DESCRIPTION | |
| 57 | |
| 58 L<JSON::PP> and L<JSON::XS> decoding benchmark. | |
| 59 | |
| 60 =head1 AUTHOR | |
| 61 | |
| 62 makamaka | |
| 63 | |
| 64 =head1 LISENCE | |
| 65 | |
| 66 This library is free software; you can redistribute it and/or modify it | |
| 67 under the same terms as Perl itself. | |
| 68 | |
| 69 =cut | |
| 70 | |
| OLD | NEW |