… | |
… | |
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))) |
… | |
… | |
948 | else if (expect_true (ch >= 0x20 && ch < 0x80)) |
949 | else if (expect_true (ch >= 0x20 && ch < 0x80)) |
949 | *cur++ = ch; |
950 | *cur++ = ch; |
950 | else if (ch >= 0x80) |
951 | else if (ch >= 0x80) |
951 | { |
952 | { |
952 | STRLEN clen; |
953 | STRLEN clen; |
953 | UV uch; |
|
|
954 | |
954 | |
955 | --dec_cur; |
955 | --dec_cur; |
956 | |
956 | |
957 | uch = decode_utf8 (dec_cur, dec->end - dec_cur, &clen); |
957 | decode_utf8 (dec_cur, dec->end - dec_cur, &clen); |
958 | if (clen == (STRLEN)-1) |
958 | if (clen == (STRLEN)-1) |
959 | ERR ("malformed UTF-8 character in JSON string"); |
959 | ERR ("malformed UTF-8 character in JSON string"); |
960 | |
960 | |
961 | do |
961 | do |
962 | *cur++ = *dec_cur++; |
962 | *cur++ = *dec_cur++; |
… | |
… | |
1655 | json_stash = gv_stashpv ("JSON::XS" , 1); |
1655 | json_stash = gv_stashpv ("JSON::XS" , 1); |
1656 | json_boolean_stash = gv_stashpv ("JSON::XS::Boolean", 1); |
1656 | json_boolean_stash = gv_stashpv ("JSON::XS::Boolean", 1); |
1657 | |
1657 | |
1658 | json_true = get_bool ("JSON::XS::true"); |
1658 | json_true = get_bool ("JSON::XS::true"); |
1659 | json_false = get_bool ("JSON::XS::false"); |
1659 | json_false = get_bool ("JSON::XS::false"); |
|
|
1660 | |
|
|
1661 | CvNODEBUG_on (get_cv ("JSON::XS::incr_text", 0)); /* the debugger completely breaks lvalue subs */ |
1660 | } |
1662 | } |
1661 | |
1663 | |
1662 | PROTOTYPES: DISABLE |
1664 | PROTOTYPES: DISABLE |
1663 | |
1665 | |
1664 | void CLONE (...) |
1666 | void CLONE (...) |