… | |
… | |
12 | #if defined(__BORLANDC__) || defined(_MSC_VER) |
12 | #if defined(__BORLANDC__) || defined(_MSC_VER) |
13 | # define snprintf _snprintf // C compilers have this in stdio.h |
13 | # define snprintf _snprintf // C compilers have this in stdio.h |
14 | #endif |
14 | #endif |
15 | |
15 | |
16 | // some old perls do not have this, try to make it work, no |
16 | // some old perls do not have this, try to make it work, no |
17 | // guarentees, though. if it breaks, you get to keep the pieces. |
17 | // guarantees, though. if it breaks, you get to keep the pieces. |
18 | #ifndef UTF8_MAXBYTES |
18 | #ifndef UTF8_MAXBYTES |
19 | # define UTF8_MAXBYTES 13 |
19 | # define UTF8_MAXBYTES 13 |
20 | #endif |
20 | #endif |
21 | |
21 | |
22 | #define IVUV_MAXCHARS (sizeof (UV) * CHAR_BIT * 28 / 93 + 2) |
22 | #define IVUV_MAXCHARS (sizeof (UV) * CHAR_BIT * 28 / 93 + 2) |
… | |
… | |
471 | |
471 | |
472 | // for canonical output we have to sort by keys first |
472 | // for canonical output we have to sort by keys first |
473 | // actually, this is mostly due to the stupid so-called |
473 | // actually, this is mostly due to the stupid so-called |
474 | // security workaround added somewhere in 5.8.x |
474 | // security workaround added somewhere in 5.8.x |
475 | // that randomises hash orderings |
475 | // that randomises hash orderings |
476 | if (enc->json.flags & F_CANONICAL) |
476 | if (enc->json.flags & F_CANONICAL && !SvRMAGICAL (hv)) |
477 | { |
477 | { |
478 | int count = hv_iterinit (hv); |
478 | int count = hv_iterinit (hv); |
479 | |
479 | |
480 | if (SvMAGICAL (hv)) |
480 | if (SvMAGICAL (hv)) |
481 | { |
481 | { |
… | |
… | |
759 | : enc.json.flags & F_LATIN1 ? 0x000100UL |
759 | : enc.json.flags & F_LATIN1 ? 0x000100UL |
760 | : 0x110000UL; |
760 | : 0x110000UL; |
761 | |
761 | |
762 | SvPOK_only (enc.sv); |
762 | SvPOK_only (enc.sv); |
763 | encode_sv (&enc, scalar); |
763 | encode_sv (&enc, scalar); |
|
|
764 | encode_nl (&enc); |
764 | |
765 | |
765 | SvCUR_set (enc.sv, enc.cur - SvPVX (enc.sv)); |
766 | SvCUR_set (enc.sv, enc.cur - SvPVX (enc.sv)); |
766 | *SvEND (enc.sv) = 0; // many xs functions expect a trailing 0 for text strings |
767 | *SvEND (enc.sv) = 0; // many xs functions expect a trailing 0 for text strings |
767 | |
768 | |
768 | if (!(enc.json.flags & (F_ASCII | F_LATIN1 | F_UTF8))) |
769 | if (!(enc.json.flags & (F_ASCII | F_LATIN1 | F_UTF8))) |
… | |
… | |
1084 | |
1085 | |
1085 | // special case the rather common 1..5-digit-int case |
1086 | // special case the rather common 1..5-digit-int case |
1086 | if (*start == '-') |
1087 | if (*start == '-') |
1087 | switch (len) |
1088 | switch (len) |
1088 | { |
1089 | { |
1089 | case 2: return newSViv (-( start [1] - '0' * 1)); |
1090 | case 2: return newSViv (-(IV)( start [1] - '0' * 1)); |
1090 | case 3: return newSViv (-( start [1] * 10 + start [2] - '0' * 11)); |
1091 | case 3: return newSViv (-(IV)( start [1] * 10 + start [2] - '0' * 11)); |
1091 | case 4: return newSViv (-( start [1] * 100 + start [2] * 10 + start [3] - '0' * 111)); |
1092 | case 4: return newSViv (-(IV)( start [1] * 100 + start [2] * 10 + start [3] - '0' * 111)); |
1092 | case 5: return newSViv (-( start [1] * 1000 + start [2] * 100 + start [3] * 10 + start [4] - '0' * 1111)); |
1093 | case 5: return newSViv (-(IV)( start [1] * 1000 + start [2] * 100 + start [3] * 10 + start [4] - '0' * 1111)); |
1093 | case 6: return newSViv (-(start [1] * 10000 + start [2] * 1000 + start [3] * 100 + start [4] * 10 + start [5] - '0' * 11111)); |
1094 | case 6: return newSViv (-(IV)(start [1] * 10000 + start [2] * 1000 + start [3] * 100 + start [4] * 10 + start [5] - '0' * 11111)); |
1094 | } |
1095 | } |
1095 | else |
1096 | else |
1096 | switch (len) |
1097 | switch (len) |
1097 | { |
1098 | { |
1098 | case 1: return newSViv ( start [0] - '0' * 1); |
1099 | case 1: return newSViv ( start [0] - '0' * 1); |
1099 | case 2: return newSViv ( start [0] * 10 + start [1] - '0' * 11); |
1100 | case 2: return newSViv ( start [0] * 10 + start [1] - '0' * 11); |
1100 | case 3: return newSViv ( start [0] * 100 + start [1] * 10 + start [2] - '0' * 111); |
1101 | case 3: return newSViv ( start [0] * 100 + start [1] * 10 + start [2] - '0' * 111); |
1101 | case 4: return newSViv ( start [0] * 1000 + start [1] * 100 + start [2] * 10 + start [3] - '0' * 1111); |
1102 | case 4: return newSViv ( start [0] * 1000 + start [1] * 100 + start [2] * 10 + start [3] - '0' * 1111); |
1102 | case 5: return newSViv ( start [0] * 10000 + start [1] * 1000 + start [2] * 100 + start [3] * 10 + start [4] - '0' * 11111); |
1103 | case 5: return newSViv ( start [0] * 10000 + start [1] * 1000 + start [2] * 100 + start [3] * 10 + start [4] - '0' * 11111); |
1103 | } |
1104 | } |
1104 | |
1105 | |
1105 | { |
1106 | { |
1106 | UV uv; |
1107 | UV uv; |
1107 | int numtype = grok_number (start, len, &uv); |
1108 | int numtype = grok_number (start, len, &uv); |
… | |
… | |
1655 | json_stash = gv_stashpv ("JSON::XS" , 1); |
1656 | json_stash = gv_stashpv ("JSON::XS" , 1); |
1656 | json_boolean_stash = gv_stashpv ("JSON::XS::Boolean", 1); |
1657 | json_boolean_stash = gv_stashpv ("JSON::XS::Boolean", 1); |
1657 | |
1658 | |
1658 | json_true = get_bool ("JSON::XS::true"); |
1659 | json_true = get_bool ("JSON::XS::true"); |
1659 | json_false = get_bool ("JSON::XS::false"); |
1660 | json_false = get_bool ("JSON::XS::false"); |
|
|
1661 | |
|
|
1662 | CvNODEBUG_on (get_cv ("JSON::XS::incr_text", 0)); /* the debugger completely breaks lvalue subs */ |
1660 | } |
1663 | } |
1661 | |
1664 | |
1662 | PROTOTYPES: DISABLE |
1665 | PROTOTYPES: DISABLE |
1663 | |
1666 | |
1664 | void CLONE (...) |
1667 | void CLONE (...) |