add initial prototype with a few commands
[project/uqmi.git] / data / lib / JSON / backportPP / Compat5006.pm
1 package # This is JSON::backportPP
2 JSON::backportPP56;
3
4 use 5.006;
5 use strict;
6
7 my @properties;
8
9 $JSON::PP56::VERSION = '1.08';
10
11 BEGIN {
12
13 sub utf8::is_utf8 {
14 my $len = length $_[0]; # char length
15 {
16 use bytes; # byte length;
17 return $len != length $_[0]; # if !=, UTF8-flagged on.
18 }
19 }
20
21
22 sub utf8::upgrade {
23 ; # noop;
24 }
25
26
27 sub utf8::downgrade ($;$) {
28 return 1 unless ( utf8::is_utf8( $_[0] ) );
29
30 if ( _is_valid_utf8( $_[0] ) ) {
31 my $downgrade;
32 for my $c ( unpack( "U*", $_[0] ) ) {
33 if ( $c < 256 ) {
34 $downgrade .= pack("C", $c);
35 }
36 else {
37 $downgrade .= pack("U", $c);
38 }
39 }
40 $_[0] = $downgrade;
41 return 1;
42 }
43 else {
44 Carp::croak("Wide character in subroutine entry") unless ( $_[1] );
45 0;
46 }
47 }
48
49
50 sub utf8::encode ($) { # UTF8 flag off
51 if ( utf8::is_utf8( $_[0] ) ) {
52 $_[0] = pack( "C*", unpack( "C*", $_[0] ) );
53 }
54 else {
55 $_[0] = pack( "U*", unpack( "C*", $_[0] ) );
56 $_[0] = pack( "C*", unpack( "C*", $_[0] ) );
57 }
58 }
59
60
61 sub utf8::decode ($) { # UTF8 flag on
62 if ( _is_valid_utf8( $_[0] ) ) {
63 utf8::downgrade( $_[0] );
64 $_[0] = pack( "U*", unpack( "U*", $_[0] ) );
65 }
66 }
67
68
69 *JSON::PP::JSON_PP_encode_ascii = \&_encode_ascii;
70 *JSON::PP::JSON_PP_encode_latin1 = \&_encode_latin1;
71 *JSON::PP::JSON_PP_decode_surrogates = \&JSON::PP::_decode_surrogates;
72 *JSON::PP::JSON_PP_decode_unicode = \&JSON::PP::_decode_unicode;
73
74 unless ( defined &B::SVp_NOK ) { # missing in B module.
75 eval q{ sub B::SVp_NOK () { 0x02000000; } };
76 }
77
78 }
79
80
81
82 sub _encode_ascii {
83 join('',
84 map {
85 $_ <= 127 ?
86 chr($_) :
87 $_ <= 65535 ?
88 sprintf('\u%04x', $_) : sprintf('\u%x\u%x', JSON::PP::_encode_surrogates($_));
89 } _unpack_emu($_[0])
90 );
91 }
92
93
94 sub _encode_latin1 {
95 join('',
96 map {
97 $_ <= 255 ?
98 chr($_) :
99 $_ <= 65535 ?
100 sprintf('\u%04x', $_) : sprintf('\u%x\u%x', JSON::PP::_encode_surrogates($_));
101 } _unpack_emu($_[0])
102 );
103 }
104
105
106 sub _unpack_emu { # for Perl 5.6 unpack warnings
107 return !utf8::is_utf8($_[0]) ? unpack('C*', $_[0])
108 : _is_valid_utf8($_[0]) ? unpack('U*', $_[0])
109 : unpack('C*', $_[0]);
110 }
111
112
113 sub _is_valid_utf8 {
114 my $str = $_[0];
115 my $is_utf8;
116
117 while ($str =~ /(?:
118 (
119 [\x00-\x7F]
120 |[\xC2-\xDF][\x80-\xBF]
121 |[\xE0][\xA0-\xBF][\x80-\xBF]
122 |[\xE1-\xEC][\x80-\xBF][\x80-\xBF]
123 |[\xED][\x80-\x9F][\x80-\xBF]
124 |[\xEE-\xEF][\x80-\xBF][\x80-\xBF]
125 |[\xF0][\x90-\xBF][\x80-\xBF][\x80-\xBF]
126 |[\xF1-\xF3][\x80-\xBF][\x80-\xBF][\x80-\xBF]
127 |[\xF4][\x80-\x8F][\x80-\xBF][\x80-\xBF]
128 )
129 | (.)
130 )/xg)
131 {
132 if (defined $1) {
133 $is_utf8 = 1 if (!defined $is_utf8);
134 }
135 else {
136 $is_utf8 = 0 if (!defined $is_utf8);
137 if ($is_utf8) { # eventually, not utf8
138 return;
139 }
140 }
141 }
142
143 return $is_utf8;
144 }
145
146
147 1;
148 __END__
149
150 =pod
151
152 =head1 NAME
153
154 JSON::PP56 - Helper module in using JSON::PP in Perl 5.6
155
156 =head1 DESCRIPTION
157
158 JSON::PP calls internally.
159
160 =head1 AUTHOR
161
162 Makamaka Hannyaharamitu, E<lt>makamaka[at]cpan.orgE<gt>
163
164
165 =head1 COPYRIGHT AND LICENSE
166
167 Copyright 2007-2009 by Makamaka Hannyaharamitu
168
169 This library is free software; you can redistribute it and/or modify
170 it under the same terms as Perl itself.
171
172 =cut
173