@port-labs/jq-node-bindings 0.0.4 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/binding.gyp +3 -3
- package/configure +8 -6
- package/deps/jq/.travis.yml +184 -35
- package/deps/jq/AUTHORS +31 -30
- package/deps/jq/COPYING +2 -2
- package/deps/jq/KEYS +8 -0
- package/deps/jq/Makefile.am +85 -70
- package/deps/jq/NEWS +5 -4
- package/deps/jq/README.md +18 -9
- package/deps/jq/appveyor.yml +53 -0
- package/deps/jq/compile-ios.sh +5 -5
- package/deps/jq/config/m4/check-math-func.m4 +7 -2
- package/deps/jq/configure.ac +130 -68
- package/deps/jq/docs/Rakefile +14 -135
- package/deps/jq/docs/Rakefile.manual +49 -0
- package/deps/jq/docs/Rakefile.website +76 -0
- package/deps/jq/docs/content/2.download/default.yml +115 -39
- package/deps/jq/docs/content/3.manual/manual.yml +641 -231
- package/deps/jq/docs/content/3.manual/v1.3/manual.yml +130 -130
- package/deps/jq/docs/content/3.manual/v1.4/manual.yml +160 -160
- package/deps/jq/docs/content/3.manual/v1.5/manual.yml +2878 -0
- package/deps/jq/docs/content/3.manual/v1.6/manual.yml +3287 -0
- package/deps/jq/docs/content/index/index.yml +28 -6
- package/deps/jq/docs/public/.htaccess +2 -2
- package/deps/jq/docs/public/css/base.scss +141 -59
- package/deps/jq/docs/public/js/manual-search.js +52 -0
- package/deps/jq/docs/site.yml +1 -10
- package/deps/jq/docs/templates/default.liquid +10 -10
- package/deps/jq/docs/templates/index.liquid +45 -32
- package/deps/jq/docs/templates/manual.liquid +67 -90
- package/deps/jq/docs/templates/shared/_footer.liquid +10 -5
- package/deps/jq/docs/templates/shared/_head.liquid +17 -12
- package/deps/jq/docs/templates/shared/_navbar.liquid +27 -0
- package/deps/jq/jq.1.prebuilt +523 -139
- package/deps/jq/modules/oniguruma/AUTHORS +1 -0
- package/deps/jq/modules/oniguruma/CMakeLists.txt +86 -0
- package/deps/jq/modules/oniguruma/COPYING +28 -0
- package/deps/jq/modules/oniguruma/ChangeLog +0 -0
- package/deps/jq/modules/oniguruma/HISTORY +2138 -0
- package/deps/jq/modules/oniguruma/Makefile.am +33 -0
- package/deps/jq/modules/oniguruma/NEWS +0 -0
- package/deps/jq/modules/oniguruma/README +189 -0
- package/deps/jq/modules/oniguruma/README.ja +195 -0
- package/deps/jq/modules/oniguruma/README.md +203 -0
- package/deps/jq/modules/oniguruma/cmake/dist.cmake +321 -0
- package/deps/jq/modules/oniguruma/compile +348 -0
- package/deps/jq/modules/oniguruma/config.guess +1754 -0
- package/deps/jq/modules/oniguruma/config.sub +1890 -0
- package/deps/jq/modules/oniguruma/configure.ac +87 -0
- package/deps/jq/modules/oniguruma/contributed/libfuzzer-onig.cpp +31 -0
- package/deps/jq/modules/oniguruma/depcomp +791 -0
- package/deps/jq/modules/oniguruma/dist.info +10 -0
- package/deps/jq/modules/oniguruma/doc/API +660 -0
- package/deps/jq/modules/oniguruma/doc/API.ja +667 -0
- package/deps/jq/modules/oniguruma/doc/FAQ +12 -0
- package/deps/jq/modules/oniguruma/doc/FAQ.ja +22 -0
- package/deps/jq/modules/oniguruma/doc/RE +436 -0
- package/deps/jq/modules/oniguruma/doc/RE.ja +448 -0
- package/deps/jq/modules/oniguruma/doc/UNICODE_PROPERTIES +698 -0
- package/deps/jq/modules/oniguruma/index.html +181 -0
- package/deps/jq/modules/oniguruma/index_ja.html +184 -0
- package/deps/jq/modules/oniguruma/install-sh +541 -0
- package/deps/jq/modules/oniguruma/m4/.whatever +0 -0
- package/deps/jq/modules/oniguruma/make_win32.bat +3 -0
- package/deps/jq/modules/oniguruma/make_win64.bat +3 -0
- package/deps/jq/modules/oniguruma/missing +215 -0
- package/deps/jq/modules/oniguruma/onig-config.in +78 -0
- package/deps/jq/modules/oniguruma/oniguruma.pc.cmake.in +13 -0
- package/deps/jq/modules/oniguruma/oniguruma.pc.in +14 -0
- package/deps/jq/modules/oniguruma/sample/CMakeLists.txt +28 -0
- package/deps/jq/modules/oniguruma/sample/Makefile.am +34 -0
- package/deps/jq/modules/oniguruma/sample/bug_fix.c +131 -0
- package/deps/jq/modules/oniguruma/sample/crnl.c +127 -0
- package/deps/jq/modules/oniguruma/sample/encode.c +308 -0
- package/deps/jq/modules/oniguruma/sample/listcap.c +110 -0
- package/deps/jq/modules/oniguruma/sample/names.c +75 -0
- package/deps/jq/modules/oniguruma/sample/posix.c +96 -0
- package/deps/jq/modules/oniguruma/sample/scan.c +88 -0
- package/deps/jq/modules/oniguruma/sample/simple.c +59 -0
- package/deps/jq/modules/oniguruma/sample/sql.c +76 -0
- package/deps/jq/modules/oniguruma/sample/syntax.c +76 -0
- package/deps/jq/modules/oniguruma/sample/user_property.c +87 -0
- package/deps/jq/modules/oniguruma/src/Makefile.am +58 -0
- package/deps/jq/modules/oniguruma/src/Makefile.windows +183 -0
- package/deps/jq/modules/oniguruma/src/ascii.c +61 -0
- package/deps/jq/modules/oniguruma/src/big5.c +190 -0
- package/deps/jq/modules/oniguruma/src/config.h.cmake.in +71 -0
- package/deps/jq/modules/oniguruma/src/config.h.win32 +84 -0
- package/deps/jq/modules/oniguruma/src/config.h.win64 +84 -0
- package/deps/jq/modules/oniguruma/src/cp1251.c +203 -0
- package/deps/jq/modules/oniguruma/src/euc_jp.c +310 -0
- package/deps/jq/modules/oniguruma/src/euc_jp_prop.c +158 -0
- package/deps/jq/modules/oniguruma/src/euc_jp_prop.gperf +27 -0
- package/deps/jq/modules/oniguruma/src/euc_kr.c +188 -0
- package/deps/jq/modules/oniguruma/src/euc_tw.c +171 -0
- package/deps/jq/modules/oniguruma/src/gb18030.c +538 -0
- package/deps/jq/modules/oniguruma/src/gperf_fold_key_conv.py +67 -0
- package/deps/jq/modules/oniguruma/src/gperf_unfold_key_conv.py +55 -0
- package/deps/jq/modules/oniguruma/src/iso8859_1.c +275 -0
- package/deps/jq/modules/oniguruma/src/iso8859_10.c +242 -0
- package/deps/jq/modules/oniguruma/src/iso8859_11.c +99 -0
- package/deps/jq/modules/oniguruma/src/iso8859_13.c +231 -0
- package/deps/jq/modules/oniguruma/src/iso8859_14.c +244 -0
- package/deps/jq/modules/oniguruma/src/iso8859_15.c +238 -0
- package/deps/jq/modules/oniguruma/src/iso8859_16.c +240 -0
- package/deps/jq/modules/oniguruma/src/iso8859_2.c +238 -0
- package/deps/jq/modules/oniguruma/src/iso8859_3.c +238 -0
- package/deps/jq/modules/oniguruma/src/iso8859_4.c +240 -0
- package/deps/jq/modules/oniguruma/src/iso8859_5.c +229 -0
- package/deps/jq/modules/oniguruma/src/iso8859_6.c +99 -0
- package/deps/jq/modules/oniguruma/src/iso8859_7.c +225 -0
- package/deps/jq/modules/oniguruma/src/iso8859_8.c +99 -0
- package/deps/jq/modules/oniguruma/src/iso8859_9.c +231 -0
- package/deps/jq/modules/oniguruma/src/koi8.c +253 -0
- package/deps/jq/modules/oniguruma/src/koi8_r.c +215 -0
- package/deps/jq/modules/oniguruma/src/make_unicode_fold.sh +22 -0
- package/deps/jq/modules/oniguruma/src/make_unicode_fold_data.py +306 -0
- package/deps/jq/modules/oniguruma/src/make_unicode_property.sh +18 -0
- package/deps/jq/modules/oniguruma/src/make_unicode_property_data.py +545 -0
- package/deps/jq/modules/oniguruma/src/mktable.c +1184 -0
- package/deps/jq/modules/oniguruma/src/onig_init.c +45 -0
- package/deps/jq/modules/oniguruma/src/oniggnu.h +85 -0
- package/deps/jq/modules/oniguruma/src/onigposix.h +169 -0
- package/deps/jq/modules/oniguruma/src/oniguruma.h +841 -0
- package/deps/jq/modules/oniguruma/src/regcomp.c +6300 -0
- package/deps/jq/modules/oniguruma/src/regenc.c +917 -0
- package/deps/jq/modules/oniguruma/src/regenc.h +243 -0
- package/deps/jq/modules/oniguruma/src/regerror.c +393 -0
- package/deps/jq/modules/oniguruma/src/regexec.c +3856 -0
- package/deps/jq/modules/oniguruma/src/regext.c +202 -0
- package/deps/jq/modules/oniguruma/src/reggnu.c +147 -0
- package/deps/jq/modules/oniguruma/src/regint.h +779 -0
- package/deps/jq/modules/oniguruma/src/regparse.c +5403 -0
- package/deps/jq/modules/oniguruma/src/regparse.h +351 -0
- package/deps/jq/modules/oniguruma/src/regposerr.c +105 -0
- package/deps/jq/modules/oniguruma/src/regposix.c +306 -0
- package/deps/jq/modules/oniguruma/src/regsyntax.c +315 -0
- package/deps/jq/modules/oniguruma/src/regtrav.c +76 -0
- package/deps/jq/modules/oniguruma/src/regversion.c +57 -0
- package/deps/jq/modules/oniguruma/src/sjis.c +341 -0
- package/deps/jq/modules/oniguruma/src/sjis_prop.c +158 -0
- package/deps/jq/modules/oniguruma/src/sjis_prop.gperf +27 -0
- package/deps/jq/modules/oniguruma/src/st.c +589 -0
- package/deps/jq/modules/oniguruma/src/st.h +68 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold1_key.c +2250 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold2_key.c +203 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold3_key.c +113 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_fold_data.c +1225 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_property_data.c +24742 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_property_data_posix.c +4846 -0
- package/deps/jq/modules/oniguruma/src/unicode-7.0/unicode_unfold_key.c +2571 -0
- package/deps/jq/modules/oniguruma/src/unicode.c +664 -0
- package/deps/jq/modules/oniguruma/src/unicode_fold1_key.c +2548 -0
- package/deps/jq/modules/oniguruma/src/unicode_fold2_key.c +203 -0
- package/deps/jq/modules/oniguruma/src/unicode_fold3_key.c +113 -0
- package/deps/jq/modules/oniguruma/src/unicode_fold_data.c +1366 -0
- package/deps/jq/modules/oniguruma/src/unicode_property_data.c +25306 -0
- package/deps/jq/modules/oniguruma/src/unicode_property_data_posix.c +4940 -0
- package/deps/jq/modules/oniguruma/src/unicode_unfold_key.c +2854 -0
- package/deps/jq/modules/oniguruma/src/utf16_be.c +235 -0
- package/deps/jq/modules/oniguruma/src/utf16_le.c +245 -0
- package/deps/jq/modules/oniguruma/src/utf32_be.c +194 -0
- package/deps/jq/modules/oniguruma/src/utf32_le.c +194 -0
- package/deps/jq/modules/oniguruma/src/utf8.c +335 -0
- package/deps/jq/modules/oniguruma/test/Makefile.am +28 -0
- package/deps/jq/modules/oniguruma/test/testc.c +874 -0
- package/deps/jq/modules/oniguruma/test/testu.c +916 -0
- package/deps/jq/modules/oniguruma/test-driver +153 -0
- package/deps/jq/modules/oniguruma/windows/testc.c +869 -0
- package/deps/jq/scripts/crosscompile +2 -1
- package/deps/jq/scripts/gen_utf8_tables.py +2 -3
- package/deps/jq/scripts/update-website +29 -0
- package/deps/jq/scripts/version +7 -2
- package/deps/jq/sig/jq-release.key +41 -0
- package/deps/jq/sig/v1.3/jq-linux-x86.asc +17 -0
- package/deps/jq/sig/v1.3/jq-linux-x86_64.asc +17 -0
- package/deps/jq/sig/v1.3/jq-osx-x86.asc +17 -0
- package/deps/jq/sig/v1.3/jq-osx-x86_64.asc +17 -0
- package/deps/jq/sig/v1.3/jq-win32.exe.asc +17 -0
- package/deps/jq/sig/v1.3/jq-win64.exe.asc +17 -0
- package/deps/jq/sig/v1.3/sha256sum.txt +6 -0
- package/deps/jq/sig/v1.4/jq-linux-x86.asc +17 -0
- package/deps/jq/sig/v1.4/jq-linux-x86_64.asc +17 -0
- package/deps/jq/sig/v1.4/jq-osx-x86.asc +17 -0
- package/deps/jq/sig/v1.4/jq-osx-x86_64.asc +17 -0
- package/deps/jq/sig/v1.4/jq-solaris11-32.asc +17 -0
- package/deps/jq/sig/v1.4/jq-solaris11-64.asc +17 -0
- package/deps/jq/sig/v1.4/jq-win32.exe.asc +17 -0
- package/deps/jq/sig/v1.4/jq-win64.exe.asc +17 -0
- package/deps/jq/sig/v1.4/sha256sum.txt +8 -0
- package/deps/jq/sig/v1.5/jq-linux32-no-oniguruma.asc +17 -0
- package/deps/jq/sig/v1.5/jq-linux32.asc +17 -0
- package/deps/jq/sig/v1.5/jq-linux64.asc +17 -0
- package/deps/jq/sig/v1.5/jq-osx-amd64.asc +17 -0
- package/deps/jq/sig/v1.5/jq-win32.exe.asc +17 -0
- package/deps/jq/sig/v1.5/jq-win64.exe.asc +17 -0
- package/deps/jq/sig/v1.5/sha256sum.txt +5 -0
- package/deps/jq/sig/v1.5rc1/jq-linux-x86_64-static.asc +17 -0
- package/deps/jq/sig/v1.5rc1/jq-win32.exe.asc +17 -0
- package/deps/jq/sig/v1.5rc1/jq-win64.exe.asc +17 -0
- package/deps/jq/sig/v1.5rc1/sha256sum.txt +3 -0
- package/deps/jq/sig/v1.5rc2/jq-linux-x86.asc +17 -0
- package/deps/jq/sig/v1.5rc2/jq-linux-x86_64.asc +17 -0
- package/deps/jq/sig/v1.5rc2/jq-osx-x86_64.asc +17 -0
- package/deps/jq/sig/v1.5rc2/jq-win32.exe.asc +17 -0
- package/deps/jq/sig/v1.5rc2/jq-win64.exe.asc +17 -0
- package/deps/jq/sig/v1.5rc2/sha256sum.txt +5 -0
- package/deps/jq/sig/v1.6/jq-linux32.asc +16 -0
- package/deps/jq/sig/v1.6/jq-linux64.asc +16 -0
- package/deps/jq/sig/v1.6/jq-osx-amd64.asc +16 -0
- package/deps/jq/sig/v1.6/jq-win32.exe.asc +16 -0
- package/deps/jq/sig/v1.6/jq-win64.exe.asc +16 -0
- package/deps/jq/sig/v1.6/sha256sum.txt +5 -0
- package/deps/jq/{builtin.c → src/builtin.c} +449 -344
- package/deps/jq/{builtin.h → src/builtin.h} +0 -0
- package/deps/jq/src/builtin.jq +311 -0
- package/deps/jq/{bytecode.c → src/bytecode.c} +0 -0
- package/deps/jq/{bytecode.h → src/bytecode.h} +0 -0
- package/deps/jq/{compile.c → src/compile.c} +213 -37
- package/deps/jq/{compile.h → src/compile.h} +7 -2
- package/deps/jq/{exec_stack.h → src/exec_stack.h} +0 -0
- package/deps/jq/{execute.c → src/execute.c} +127 -24
- package/deps/jq/{inject_errors.c → src/inject_errors.c} +0 -0
- package/deps/jq/{jq.h → src/jq.h} +13 -2
- package/deps/jq/{jq_parser.h → src/jq_parser.h} +0 -0
- package/deps/jq/{jq_test.c → src/jq_test.c} +1 -1
- package/deps/jq/{jv.c → src/jv.c} +24 -5
- package/deps/jq/{jv.h → src/jv.h} +46 -11
- package/deps/jq/{jv_alloc.c → src/jv_alloc.c} +0 -0
- package/deps/jq/{jv_alloc.h → src/jv_alloc.h} +0 -0
- package/deps/jq/{jv_aux.c → src/jv_aux.c} +38 -14
- package/deps/jq/{jv_dtoa.c → src/jv_dtoa.c} +4 -5
- package/deps/jq/{jv_dtoa.h → src/jv_dtoa.h} +0 -0
- package/deps/jq/src/jv_file.c +81 -0
- package/deps/jq/{jv_parse.c → src/jv_parse.c} +8 -2
- package/deps/jq/{jv_print.c → src/jv_print.c} +80 -27
- package/deps/jq/{jv_unicode.c → src/jv_unicode.c} +28 -4
- package/deps/jq/{jv_unicode.h → src/jv_unicode.h} +1 -0
- package/deps/jq/{jv_utf8_tables.h → src/jv_utf8_tables.h} +0 -0
- package/deps/jq/{lexer.c → src/lexer.c} +317 -292
- package/deps/jq/{lexer.h → src/lexer.h} +16 -12
- package/deps/jq/{lexer.l → src/lexer.l} +5 -4
- package/deps/jq/src/libm.h +291 -0
- package/deps/jq/{linker.c → src/linker.c} +5 -3
- package/deps/jq/{linker.h → src/linker.h} +0 -0
- package/deps/jq/{locfile.c → src/locfile.c} +1 -1
- package/deps/jq/{locfile.h → src/locfile.h} +0 -0
- package/deps/jq/{main.c → src/main.c} +202 -100
- package/deps/jq/{opcode_list.h → src/opcode_list.h} +4 -0
- package/deps/jq/{parser.c → src/parser.c} +1149 -1069
- package/deps/jq/{parser.h → src/parser.h} +28 -24
- package/deps/jq/{parser.y → src/parser.y} +108 -52
- package/deps/jq/{util.c → src/util.c} +12 -9
- package/deps/jq/{util.h → src/util.h} +0 -0
- package/deps/jq/tests/base64.test +35 -0
- package/deps/jq/tests/base64test +5 -0
- package/deps/jq/tests/jq-f-test.sh +4 -0
- package/deps/jq/tests/jq.test +305 -21
- package/deps/jq/tests/jqtest +1 -1
- package/deps/jq/tests/mantest +1 -1
- package/deps/jq/tests/onig.test +13 -0
- package/deps/jq/tests/onigtest +1 -1
- package/deps/jq/tests/optional.test +20 -0
- package/deps/jq/tests/optionaltest +5 -0
- package/deps/jq/tests/setup +7 -1
- package/deps/jq/tests/shtest +133 -29
- package/deps/jq/tests/utf8-truncate.jq +3 -0
- package/deps/jq/tests/utf8test +10 -0
- package/lib/index.js +7 -1
- package/package.json +3 -3
- package/test/santiy.test.js +24 -0
- package/deps/jq/docs/default_manpage.md +0 -22
- package/deps/jq/docs/public/bootstrap/css/bootstrap-responsive.css +0 -1058
- package/deps/jq/docs/public/bootstrap/css/bootstrap-responsive.min.css +0 -9
- package/deps/jq/docs/public/bootstrap/css/bootstrap.css +0 -5224
- package/deps/jq/docs/public/bootstrap/css/bootstrap.min.css +0 -9
- package/deps/jq/docs/public/bootstrap/img/glyphicons-halflings-white.png +0 -0
- package/deps/jq/docs/public/bootstrap/img/glyphicons-halflings.png +0 -0
- package/deps/jq/docs/public/bootstrap/js/bootstrap.js +0 -2027
- package/deps/jq/docs/public/bootstrap/js/bootstrap.min.js +0 -6
- package/deps/jq/docs/templates/shared/_header.liquid +0 -26
- package/deps/jq/jq.1.default +0 -39
- package/deps/jq/jv_file.c +0 -49
- package/deps/jq/libm.h +0 -160
- package/deps/jq/setup.sh +0 -33
- package/reports/jest-port-api.xml +0 -35
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
/**********************************************************************
|
|
2
|
+
utf16_be.c - Oniguruma (regular expression library)
|
|
3
|
+
**********************************************************************/
|
|
4
|
+
/*-
|
|
5
|
+
* Copyright (c) 2002-2016 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
|
|
6
|
+
* All rights reserved.
|
|
7
|
+
*
|
|
8
|
+
* Redistribution and use in source and binary forms, with or without
|
|
9
|
+
* modification, are permitted provided that the following conditions
|
|
10
|
+
* are met:
|
|
11
|
+
* 1. Redistributions of source code must retain the above copyright
|
|
12
|
+
* notice, this list of conditions and the following disclaimer.
|
|
13
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
|
14
|
+
* notice, this list of conditions and the following disclaimer in the
|
|
15
|
+
* documentation and/or other materials provided with the distribution.
|
|
16
|
+
*
|
|
17
|
+
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
18
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
19
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
20
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
21
|
+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
22
|
+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
23
|
+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
24
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
25
|
+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
26
|
+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
27
|
+
* SUCH DAMAGE.
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
#include "regenc.h"
|
|
31
|
+
|
|
32
|
+
static const int EncLen_UTF16[] = {
|
|
33
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
34
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
35
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
36
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
37
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
38
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
39
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
40
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
41
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
42
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
43
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
44
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
45
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
46
|
+
2, 2, 2, 2, 2, 2, 2, 2, 4, 4, 4, 4, 2, 2, 2, 2,
|
|
47
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
48
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
static int
|
|
52
|
+
utf16be_mbc_enc_len(const UChar* p)
|
|
53
|
+
{
|
|
54
|
+
return EncLen_UTF16[*p];
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
static int
|
|
58
|
+
is_valid_mbc_string(const UChar* s, const UChar* end)
|
|
59
|
+
{
|
|
60
|
+
return onigenc_length_check_is_valid_mbc_string(ONIG_ENCODING_UTF16_BE, s, end);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
static int
|
|
64
|
+
utf16be_is_mbc_newline(const UChar* p, const UChar* end)
|
|
65
|
+
{
|
|
66
|
+
if (p + 1 < end) {
|
|
67
|
+
if (*(p+1) == 0x0a && *p == 0x00)
|
|
68
|
+
return 1;
|
|
69
|
+
#ifdef USE_UNICODE_ALL_LINE_TERMINATORS
|
|
70
|
+
if ((
|
|
71
|
+
#ifndef USE_CRNL_AS_LINE_TERMINATOR
|
|
72
|
+
*(p+1) == 0x0d ||
|
|
73
|
+
#endif
|
|
74
|
+
*(p+1) == 0x85) && *p == 0x00)
|
|
75
|
+
return 1;
|
|
76
|
+
|
|
77
|
+
if (*p == 0x20 && (*(p+1) == 0x29 || *(p+1) == 0x28))
|
|
78
|
+
return 1;
|
|
79
|
+
#endif
|
|
80
|
+
}
|
|
81
|
+
return 0;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
static OnigCodePoint
|
|
85
|
+
utf16be_mbc_to_code(const UChar* p, const UChar* end ARG_UNUSED)
|
|
86
|
+
{
|
|
87
|
+
OnigCodePoint code;
|
|
88
|
+
|
|
89
|
+
if (UTF16_IS_SURROGATE_FIRST(*p)) {
|
|
90
|
+
code = ((((p[0] - 0xd8) << 2) + ((p[1] & 0xc0) >> 6) + 1) << 16)
|
|
91
|
+
+ ((((p[1] & 0x3f) << 2) + (p[2] - 0xdc)) << 8)
|
|
92
|
+
+ p[3];
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
code = p[0] * 256 + p[1];
|
|
96
|
+
}
|
|
97
|
+
return code;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
static int
|
|
101
|
+
utf16be_code_to_mbclen(OnigCodePoint code)
|
|
102
|
+
{
|
|
103
|
+
return (code > 0xffff ? 4 : 2);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
static int
|
|
107
|
+
utf16be_code_to_mbc(OnigCodePoint code, UChar *buf)
|
|
108
|
+
{
|
|
109
|
+
UChar* p = buf;
|
|
110
|
+
|
|
111
|
+
if (code > 0xffff) {
|
|
112
|
+
unsigned int plane, high;
|
|
113
|
+
|
|
114
|
+
plane = (code >> 16) - 1;
|
|
115
|
+
*p++ = (plane >> 2) + 0xd8;
|
|
116
|
+
high = (code & 0xff00) >> 8;
|
|
117
|
+
*p++ = ((plane & 0x03) << 6) + (high >> 2);
|
|
118
|
+
*p++ = (high & 0x03) + 0xdc;
|
|
119
|
+
*p = (UChar )(code & 0xff);
|
|
120
|
+
return 4;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
*p++ = (UChar )((code & 0xff00) >> 8);
|
|
124
|
+
*p++ = (UChar )(code & 0xff);
|
|
125
|
+
return 2;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
static int
|
|
130
|
+
utf16be_mbc_case_fold(OnigCaseFoldType flag,
|
|
131
|
+
const UChar** pp, const UChar* end, UChar* fold)
|
|
132
|
+
{
|
|
133
|
+
const UChar* p = *pp;
|
|
134
|
+
|
|
135
|
+
if (ONIGENC_IS_ASCII_CODE(*(p+1)) && *p == 0) {
|
|
136
|
+
p++;
|
|
137
|
+
#ifdef USE_UNICODE_CASE_FOLD_TURKISH_AZERI
|
|
138
|
+
if ((flag & ONIGENC_CASE_FOLD_TURKISH_AZERI) != 0) {
|
|
139
|
+
if (*p == 0x49) {
|
|
140
|
+
*fold++ = 0x01;
|
|
141
|
+
*fold = 0x31;
|
|
142
|
+
(*pp) += 2;
|
|
143
|
+
return 2;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
#endif
|
|
147
|
+
|
|
148
|
+
*fold++ = 0;
|
|
149
|
+
*fold = ONIGENC_ASCII_CODE_TO_LOWER_CASE(*p);
|
|
150
|
+
*pp += 2;
|
|
151
|
+
return 2;
|
|
152
|
+
}
|
|
153
|
+
else
|
|
154
|
+
return onigenc_unicode_mbc_case_fold(ONIG_ENCODING_UTF16_BE, flag,
|
|
155
|
+
pp, end, fold);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
#if 0
|
|
159
|
+
static int
|
|
160
|
+
utf16be_is_mbc_ambiguous(OnigCaseFoldType flag, const UChar** pp, const UChar* end)
|
|
161
|
+
{
|
|
162
|
+
const UChar* p = *pp;
|
|
163
|
+
|
|
164
|
+
(*pp) += EncLen_UTF16[*p];
|
|
165
|
+
|
|
166
|
+
if (*p == 0) {
|
|
167
|
+
int c, v;
|
|
168
|
+
|
|
169
|
+
p++;
|
|
170
|
+
if (*p == 0xdf && (flag & INTERNAL_ONIGENC_CASE_FOLD_MULTI_CHAR) != 0) {
|
|
171
|
+
return TRUE;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
c = *p;
|
|
175
|
+
v = ONIGENC_IS_UNICODE_ISO_8859_1_BIT_CTYPE(c,
|
|
176
|
+
(BIT_CTYPE_UPPER | BIT_CTYPE_LOWER));
|
|
177
|
+
|
|
178
|
+
if ((v | BIT_CTYPE_LOWER) != 0) {
|
|
179
|
+
/* 0xaa, 0xb5, 0xba are lower case letter, but can't convert. */
|
|
180
|
+
if (c >= 0xaa && c <= 0xba)
|
|
181
|
+
return FALSE;
|
|
182
|
+
else
|
|
183
|
+
return TRUE;
|
|
184
|
+
}
|
|
185
|
+
return (v != 0 ? TRUE : FALSE);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
return FALSE;
|
|
189
|
+
}
|
|
190
|
+
#endif
|
|
191
|
+
|
|
192
|
+
static UChar*
|
|
193
|
+
utf16be_left_adjust_char_head(const UChar* start, const UChar* s)
|
|
194
|
+
{
|
|
195
|
+
if (s <= start) return (UChar* )s;
|
|
196
|
+
|
|
197
|
+
if ((s - start) % 2 == 1) {
|
|
198
|
+
s--;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
if (UTF16_IS_SURROGATE_SECOND(*s) && s > start + 1)
|
|
202
|
+
s -= 2;
|
|
203
|
+
|
|
204
|
+
return (UChar* )s;
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
static int
|
|
208
|
+
utf16be_get_case_fold_codes_by_str(OnigCaseFoldType flag,
|
|
209
|
+
const OnigUChar* p, const OnigUChar* end, OnigCaseFoldCodeItem items[])
|
|
210
|
+
{
|
|
211
|
+
return onigenc_unicode_get_case_fold_codes_by_str(ONIG_ENCODING_UTF16_BE,
|
|
212
|
+
flag, p, end, items);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
OnigEncodingType OnigEncodingUTF16_BE = {
|
|
216
|
+
utf16be_mbc_enc_len,
|
|
217
|
+
"UTF-16BE", /* name */
|
|
218
|
+
4, /* max byte length */
|
|
219
|
+
2, /* min byte length */
|
|
220
|
+
utf16be_is_mbc_newline,
|
|
221
|
+
utf16be_mbc_to_code,
|
|
222
|
+
utf16be_code_to_mbclen,
|
|
223
|
+
utf16be_code_to_mbc,
|
|
224
|
+
utf16be_mbc_case_fold,
|
|
225
|
+
onigenc_unicode_apply_all_case_fold,
|
|
226
|
+
utf16be_get_case_fold_codes_by_str,
|
|
227
|
+
onigenc_unicode_property_name_to_ctype,
|
|
228
|
+
onigenc_unicode_is_code_ctype,
|
|
229
|
+
onigenc_utf16_32_get_ctype_code_range,
|
|
230
|
+
utf16be_left_adjust_char_head,
|
|
231
|
+
onigenc_always_false_is_allowed_reverse_match,
|
|
232
|
+
NULL, /* init */
|
|
233
|
+
NULL, /* is_initialized */
|
|
234
|
+
is_valid_mbc_string
|
|
235
|
+
};
|
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
/**********************************************************************
|
|
2
|
+
utf16_le.c - Oniguruma (regular expression library)
|
|
3
|
+
**********************************************************************/
|
|
4
|
+
/*-
|
|
5
|
+
* Copyright (c) 2002-2016 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
|
|
6
|
+
* All rights reserved.
|
|
7
|
+
*
|
|
8
|
+
* Redistribution and use in source and binary forms, with or without
|
|
9
|
+
* modification, are permitted provided that the following conditions
|
|
10
|
+
* are met:
|
|
11
|
+
* 1. Redistributions of source code must retain the above copyright
|
|
12
|
+
* notice, this list of conditions and the following disclaimer.
|
|
13
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
|
14
|
+
* notice, this list of conditions and the following disclaimer in the
|
|
15
|
+
* documentation and/or other materials provided with the distribution.
|
|
16
|
+
*
|
|
17
|
+
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
18
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
19
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
20
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
21
|
+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
22
|
+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
23
|
+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
24
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
25
|
+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
26
|
+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
27
|
+
* SUCH DAMAGE.
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
#include "regenc.h"
|
|
31
|
+
|
|
32
|
+
static const int EncLen_UTF16[] = {
|
|
33
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
34
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
35
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
36
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
37
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
38
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
39
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
40
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
41
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
42
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
43
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
44
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
45
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
46
|
+
2, 2, 2, 2, 2, 2, 2, 2, 4, 4, 4, 4, 2, 2, 2, 2,
|
|
47
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
|
|
48
|
+
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
static int
|
|
52
|
+
utf16le_code_to_mbclen(OnigCodePoint code)
|
|
53
|
+
{
|
|
54
|
+
return (code > 0xffff ? 4 : 2);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
static int
|
|
58
|
+
utf16le_mbc_enc_len(const UChar* p)
|
|
59
|
+
{
|
|
60
|
+
return EncLen_UTF16[*(p+1)];
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
static int
|
|
64
|
+
is_valid_mbc_string(const UChar* p, const UChar* end)
|
|
65
|
+
{
|
|
66
|
+
const UChar* end1 = end - 1;
|
|
67
|
+
|
|
68
|
+
while (p < end1) {
|
|
69
|
+
p += utf16le_mbc_enc_len(p);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
if (p != end)
|
|
73
|
+
return FALSE;
|
|
74
|
+
else
|
|
75
|
+
return TRUE;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
static int
|
|
79
|
+
utf16le_is_mbc_newline(const UChar* p, const UChar* end)
|
|
80
|
+
{
|
|
81
|
+
if (p + 1 < end) {
|
|
82
|
+
if (*p == 0x0a && *(p+1) == 0x00)
|
|
83
|
+
return 1;
|
|
84
|
+
#ifdef USE_UNICODE_ALL_LINE_TERMINATORS
|
|
85
|
+
if ((
|
|
86
|
+
#ifndef USE_CRNL_AS_LINE_TERMINATOR
|
|
87
|
+
*p == 0x0d ||
|
|
88
|
+
#endif
|
|
89
|
+
*p == 0x85) && *(p+1) == 0x00)
|
|
90
|
+
return 1;
|
|
91
|
+
|
|
92
|
+
if (*(p+1) == 0x20 && (*p == 0x29 || *p == 0x28))
|
|
93
|
+
return 1;
|
|
94
|
+
#endif
|
|
95
|
+
}
|
|
96
|
+
return 0;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
static OnigCodePoint
|
|
100
|
+
utf16le_mbc_to_code(const UChar* p, const UChar* end ARG_UNUSED)
|
|
101
|
+
{
|
|
102
|
+
OnigCodePoint code;
|
|
103
|
+
UChar c0 = *p;
|
|
104
|
+
UChar c1 = *(p+1);
|
|
105
|
+
|
|
106
|
+
if (UTF16_IS_SURROGATE_FIRST(c1)) {
|
|
107
|
+
code = ((((c1 - 0xd8) << 2) + ((c0 & 0xc0) >> 6) + 1) << 16)
|
|
108
|
+
+ ((((c0 & 0x3f) << 2) + (p[3] - 0xdc)) << 8)
|
|
109
|
+
+ p[2];
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
code = c1 * 256 + p[0];
|
|
113
|
+
}
|
|
114
|
+
return code;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
static int
|
|
118
|
+
utf16le_code_to_mbc(OnigCodePoint code, UChar *buf)
|
|
119
|
+
{
|
|
120
|
+
UChar* p = buf;
|
|
121
|
+
|
|
122
|
+
if (code > 0xffff) {
|
|
123
|
+
unsigned int plane, high;
|
|
124
|
+
|
|
125
|
+
plane = (code >> 16) - 1;
|
|
126
|
+
high = (code & 0xff00) >> 8;
|
|
127
|
+
|
|
128
|
+
*p++ = ((plane & 0x03) << 6) + (high >> 2);
|
|
129
|
+
*p++ = (plane >> 2) + 0xd8;
|
|
130
|
+
*p++ = (UChar )(code & 0xff);
|
|
131
|
+
*p = (high & 0x03) + 0xdc;
|
|
132
|
+
return 4;
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
*p++ = (UChar )(code & 0xff);
|
|
136
|
+
*p++ = (UChar )((code & 0xff00) >> 8);
|
|
137
|
+
return 2;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
static int
|
|
142
|
+
utf16le_mbc_case_fold(OnigCaseFoldType flag,
|
|
143
|
+
const UChar** pp, const UChar* end, UChar* fold)
|
|
144
|
+
{
|
|
145
|
+
const UChar* p = *pp;
|
|
146
|
+
|
|
147
|
+
if (ONIGENC_IS_ASCII_CODE(*p) && *(p+1) == 0) {
|
|
148
|
+
#ifdef USE_UNICODE_CASE_FOLD_TURKISH_AZERI
|
|
149
|
+
if ((flag & ONIGENC_CASE_FOLD_TURKISH_AZERI) != 0) {
|
|
150
|
+
if (*p == 0x49) {
|
|
151
|
+
*fold++ = 0x31;
|
|
152
|
+
*fold = 0x01;
|
|
153
|
+
(*pp) += 2;
|
|
154
|
+
return 2;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
#endif
|
|
158
|
+
|
|
159
|
+
*fold++ = ONIGENC_ASCII_CODE_TO_LOWER_CASE(*p);
|
|
160
|
+
*fold = 0;
|
|
161
|
+
*pp += 2;
|
|
162
|
+
return 2;
|
|
163
|
+
}
|
|
164
|
+
else
|
|
165
|
+
return onigenc_unicode_mbc_case_fold(ONIG_ENCODING_UTF16_LE, flag, pp, end,
|
|
166
|
+
fold);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
#if 0
|
|
170
|
+
static int
|
|
171
|
+
utf16le_is_mbc_ambiguous(OnigCaseFoldType flag, const UChar** pp,
|
|
172
|
+
const UChar* end)
|
|
173
|
+
{
|
|
174
|
+
const UChar* p = *pp;
|
|
175
|
+
|
|
176
|
+
(*pp) += EncLen_UTF16[*(p+1)];
|
|
177
|
+
|
|
178
|
+
if (*(p+1) == 0) {
|
|
179
|
+
int c, v;
|
|
180
|
+
|
|
181
|
+
if (*p == 0xdf && (flag & INTERNAL_ONIGENC_CASE_FOLD_MULTI_CHAR) != 0) {
|
|
182
|
+
return TRUE;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
c = *p;
|
|
186
|
+
v = ONIGENC_IS_UNICODE_ISO_8859_1_BIT_CTYPE(c,
|
|
187
|
+
(BIT_CTYPE_UPPER | BIT_CTYPE_LOWER));
|
|
188
|
+
if ((v | BIT_CTYPE_LOWER) != 0) {
|
|
189
|
+
/* 0xaa, 0xb5, 0xba are lower case letter, but can't convert. */
|
|
190
|
+
if (c >= 0xaa && c <= 0xba)
|
|
191
|
+
return FALSE;
|
|
192
|
+
else
|
|
193
|
+
return TRUE;
|
|
194
|
+
}
|
|
195
|
+
return (v != 0 ? TRUE : FALSE);
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
return FALSE;
|
|
199
|
+
}
|
|
200
|
+
#endif
|
|
201
|
+
|
|
202
|
+
static UChar*
|
|
203
|
+
utf16le_left_adjust_char_head(const UChar* start, const UChar* s)
|
|
204
|
+
{
|
|
205
|
+
if (s <= start) return (UChar* )s;
|
|
206
|
+
|
|
207
|
+
if ((s - start) % 2 == 1) {
|
|
208
|
+
s--;
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
if (UTF16_IS_SURROGATE_SECOND(*(s+1)) && s > start + 1)
|
|
212
|
+
s -= 2;
|
|
213
|
+
|
|
214
|
+
return (UChar* )s;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
static int
|
|
218
|
+
utf16le_get_case_fold_codes_by_str(OnigCaseFoldType flag,
|
|
219
|
+
const OnigUChar* p, const OnigUChar* end, OnigCaseFoldCodeItem items[])
|
|
220
|
+
{
|
|
221
|
+
return onigenc_unicode_get_case_fold_codes_by_str(ONIG_ENCODING_UTF16_LE,
|
|
222
|
+
flag, p, end, items);
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
OnigEncodingType OnigEncodingUTF16_LE = {
|
|
226
|
+
utf16le_mbc_enc_len,
|
|
227
|
+
"UTF-16LE", /* name */
|
|
228
|
+
4, /* max byte length */
|
|
229
|
+
2, /* min byte length */
|
|
230
|
+
utf16le_is_mbc_newline,
|
|
231
|
+
utf16le_mbc_to_code,
|
|
232
|
+
utf16le_code_to_mbclen,
|
|
233
|
+
utf16le_code_to_mbc,
|
|
234
|
+
utf16le_mbc_case_fold,
|
|
235
|
+
onigenc_unicode_apply_all_case_fold,
|
|
236
|
+
utf16le_get_case_fold_codes_by_str,
|
|
237
|
+
onigenc_unicode_property_name_to_ctype,
|
|
238
|
+
onigenc_unicode_is_code_ctype,
|
|
239
|
+
onigenc_utf16_32_get_ctype_code_range,
|
|
240
|
+
utf16le_left_adjust_char_head,
|
|
241
|
+
onigenc_always_false_is_allowed_reverse_match,
|
|
242
|
+
NULL, /* init */
|
|
243
|
+
NULL, /* is_initialized */
|
|
244
|
+
is_valid_mbc_string
|
|
245
|
+
};
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
/**********************************************************************
|
|
2
|
+
utf32_be.c - Oniguruma (regular expression library)
|
|
3
|
+
**********************************************************************/
|
|
4
|
+
/*-
|
|
5
|
+
* Copyright (c) 2002-2016 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
|
|
6
|
+
* All rights reserved.
|
|
7
|
+
*
|
|
8
|
+
* Redistribution and use in source and binary forms, with or without
|
|
9
|
+
* modification, are permitted provided that the following conditions
|
|
10
|
+
* are met:
|
|
11
|
+
* 1. Redistributions of source code must retain the above copyright
|
|
12
|
+
* notice, this list of conditions and the following disclaimer.
|
|
13
|
+
* 2. Redistributions in binary form must reproduce the above copyright
|
|
14
|
+
* notice, this list of conditions and the following disclaimer in the
|
|
15
|
+
* documentation and/or other materials provided with the distribution.
|
|
16
|
+
*
|
|
17
|
+
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
18
|
+
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
19
|
+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
20
|
+
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
21
|
+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
22
|
+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
23
|
+
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
24
|
+
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
25
|
+
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
26
|
+
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
27
|
+
* SUCH DAMAGE.
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
#include "regenc.h"
|
|
31
|
+
|
|
32
|
+
static int
|
|
33
|
+
utf32be_mbc_enc_len(const UChar* p ARG_UNUSED)
|
|
34
|
+
{
|
|
35
|
+
return 4;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
static int
|
|
39
|
+
is_valid_mbc_string(const UChar* s, const UChar* end)
|
|
40
|
+
{
|
|
41
|
+
return onigenc_length_check_is_valid_mbc_string(ONIG_ENCODING_UTF32_BE, s, end);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
static int
|
|
45
|
+
utf32be_is_mbc_newline(const UChar* p, const UChar* end)
|
|
46
|
+
{
|
|
47
|
+
if (p + 3 < end) {
|
|
48
|
+
if (*(p+3) == 0x0a && *(p+2) == 0 && *(p+1) == 0 && *p == 0)
|
|
49
|
+
return 1;
|
|
50
|
+
#ifdef USE_UNICODE_ALL_LINE_TERMINATORS
|
|
51
|
+
if ((
|
|
52
|
+
#ifndef USE_CRNL_AS_LINE_TERMINATOR
|
|
53
|
+
*(p+3) == 0x0d ||
|
|
54
|
+
#endif
|
|
55
|
+
*(p+3) == 0x85)
|
|
56
|
+
&& *(p+2) == 0 && *(p+1) == 0 && *p == 0x00)
|
|
57
|
+
return 1;
|
|
58
|
+
|
|
59
|
+
if (*(p+2) == 0x20 && (*(p+3) == 0x29 || *(p+3) == 0x28)
|
|
60
|
+
&& *(p+1) == 0 && *p == 0)
|
|
61
|
+
return 1;
|
|
62
|
+
#endif
|
|
63
|
+
}
|
|
64
|
+
return 0;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
static OnigCodePoint
|
|
68
|
+
utf32be_mbc_to_code(const UChar* p, const UChar* end ARG_UNUSED)
|
|
69
|
+
{
|
|
70
|
+
return (OnigCodePoint )(((p[0] * 256 + p[1]) * 256 + p[2]) * 256 + p[3]);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
static int
|
|
74
|
+
utf32be_code_to_mbclen(OnigCodePoint code ARG_UNUSED)
|
|
75
|
+
{
|
|
76
|
+
return 4;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
static int
|
|
80
|
+
utf32be_code_to_mbc(OnigCodePoint code, UChar *buf)
|
|
81
|
+
{
|
|
82
|
+
UChar* p = buf;
|
|
83
|
+
|
|
84
|
+
*p++ = (UChar )((code & 0xff000000) >>24);
|
|
85
|
+
*p++ = (UChar )((code & 0xff0000) >>16);
|
|
86
|
+
*p++ = (UChar )((code & 0xff00) >> 8);
|
|
87
|
+
*p++ = (UChar ) (code & 0xff);
|
|
88
|
+
return 4;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
static int
|
|
92
|
+
utf32be_mbc_case_fold(OnigCaseFoldType flag,
|
|
93
|
+
const UChar** pp, const UChar* end, UChar* fold)
|
|
94
|
+
{
|
|
95
|
+
const UChar* p = *pp;
|
|
96
|
+
|
|
97
|
+
if (ONIGENC_IS_ASCII_CODE(*(p+3)) && *(p+2) == 0 && *(p+1) == 0 && *p == 0) {
|
|
98
|
+
*fold++ = 0;
|
|
99
|
+
*fold++ = 0;
|
|
100
|
+
|
|
101
|
+
#ifdef USE_UNICODE_CASE_FOLD_TURKISH_AZERI
|
|
102
|
+
if ((flag & ONIGENC_CASE_FOLD_TURKISH_AZERI) != 0) {
|
|
103
|
+
if (*(p+3) == 0x49) {
|
|
104
|
+
*fold++ = 0x01;
|
|
105
|
+
*fold = 0x31;
|
|
106
|
+
(*pp) += 4;
|
|
107
|
+
return 4;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
#endif
|
|
111
|
+
|
|
112
|
+
*fold++ = 0;
|
|
113
|
+
*fold = ONIGENC_ASCII_CODE_TO_LOWER_CASE(*(p+3));
|
|
114
|
+
*pp += 4;
|
|
115
|
+
return 4;
|
|
116
|
+
}
|
|
117
|
+
else
|
|
118
|
+
return onigenc_unicode_mbc_case_fold(ONIG_ENCODING_UTF32_BE, flag, pp, end,
|
|
119
|
+
fold);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
#if 0
|
|
123
|
+
static int
|
|
124
|
+
utf32be_is_mbc_ambiguous(OnigCaseFoldType flag, const UChar** pp, const UChar* end)
|
|
125
|
+
{
|
|
126
|
+
const UChar* p = *pp;
|
|
127
|
+
|
|
128
|
+
(*pp) += 4;
|
|
129
|
+
|
|
130
|
+
if (*(p+2) == 0 && *(p+1) == 0 && *p == 0) {
|
|
131
|
+
int c, v;
|
|
132
|
+
|
|
133
|
+
p += 3;
|
|
134
|
+
if (*p == 0xdf && (flag & INTERNAL_ONIGENC_CASE_FOLD_MULTI_CHAR) != 0) {
|
|
135
|
+
return TRUE;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
c = *p;
|
|
139
|
+
v = ONIGENC_IS_UNICODE_ISO_8859_1_BIT_CTYPE(c,
|
|
140
|
+
(BIT_CTYPE_UPPER | BIT_CTYPE_LOWER));
|
|
141
|
+
if ((v | BIT_CTYPE_LOWER) != 0) {
|
|
142
|
+
/* 0xaa, 0xb5, 0xba are lower case letter, but can't convert. */
|
|
143
|
+
if (c >= 0xaa && c <= 0xba)
|
|
144
|
+
return FALSE;
|
|
145
|
+
else
|
|
146
|
+
return TRUE;
|
|
147
|
+
}
|
|
148
|
+
return (v != 0 ? TRUE : FALSE);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
return FALSE;
|
|
152
|
+
}
|
|
153
|
+
#endif
|
|
154
|
+
|
|
155
|
+
static UChar*
|
|
156
|
+
utf32be_left_adjust_char_head(const UChar* start, const UChar* s)
|
|
157
|
+
{
|
|
158
|
+
int rem;
|
|
159
|
+
|
|
160
|
+
if (s <= start) return (UChar* )s;
|
|
161
|
+
|
|
162
|
+
rem = (s - start) % 4;
|
|
163
|
+
return (UChar* )(s - rem);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
static int
|
|
167
|
+
utf32be_get_case_fold_codes_by_str(OnigCaseFoldType flag,
|
|
168
|
+
const OnigUChar* p, const OnigUChar* end, OnigCaseFoldCodeItem items[])
|
|
169
|
+
{
|
|
170
|
+
return onigenc_unicode_get_case_fold_codes_by_str(ONIG_ENCODING_UTF32_BE,
|
|
171
|
+
flag, p, end, items);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
OnigEncodingType OnigEncodingUTF32_BE = {
|
|
175
|
+
utf32be_mbc_enc_len,
|
|
176
|
+
"UTF-32BE", /* name */
|
|
177
|
+
4, /* max byte length */
|
|
178
|
+
4, /* min byte length */
|
|
179
|
+
utf32be_is_mbc_newline,
|
|
180
|
+
utf32be_mbc_to_code,
|
|
181
|
+
utf32be_code_to_mbclen,
|
|
182
|
+
utf32be_code_to_mbc,
|
|
183
|
+
utf32be_mbc_case_fold,
|
|
184
|
+
onigenc_unicode_apply_all_case_fold,
|
|
185
|
+
utf32be_get_case_fold_codes_by_str,
|
|
186
|
+
onigenc_unicode_property_name_to_ctype,
|
|
187
|
+
onigenc_unicode_is_code_ctype,
|
|
188
|
+
onigenc_utf16_32_get_ctype_code_range,
|
|
189
|
+
utf32be_left_adjust_char_head,
|
|
190
|
+
onigenc_always_false_is_allowed_reverse_match,
|
|
191
|
+
NULL, /* init */
|
|
192
|
+
NULL, /* is_initialized */
|
|
193
|
+
is_valid_mbc_string
|
|
194
|
+
};
|