koffi 2.1.3 → 2.1.5

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.
Files changed (374) hide show
  1. package/ChangeLog.md +17 -0
  2. package/doc/contribute.md +5 -5
  3. package/doc/index.rst +1 -1
  4. package/doc/memory.md +1 -0
  5. package/doc/templates/badges.html +1 -1
  6. package/package.json +44 -68
  7. package/src/cnoke/LICENSE.txt +661 -0
  8. package/src/cnoke/README.md +97 -0
  9. package/src/cnoke/assets/FindCNoke.cmake +71 -0
  10. package/src/cnoke/assets/win_delay_hook.c +34 -0
  11. package/src/cnoke/cnoke.js +968 -0
  12. package/src/cnoke/package.json +25 -0
  13. package/{vendor → src/core}/libcc/libcc.cc +38 -11
  14. package/{vendor → src/core}/libcc/libcc.hh +4 -2
  15. package/{CMakeLists.txt → src/koffi/CMakeLists.txt} +3 -3
  16. package/{benchmark → src/koffi/benchmark}/CMakeLists.txt +9 -6
  17. package/{benchmark → src/koffi/benchmark}/atoi_koffi.js +0 -0
  18. package/{benchmark → src/koffi/benchmark}/atoi_napi.cc +1 -1
  19. package/{benchmark → src/koffi/benchmark}/atoi_napi.js +0 -0
  20. package/{benchmark → src/koffi/benchmark}/atoi_node_ffi.js +0 -0
  21. package/src/koffi/benchmark/benchmark.js +118 -0
  22. package/src/koffi/benchmark/rand_koffi.js +52 -0
  23. package/src/koffi/benchmark/rand_napi.cc +69 -0
  24. package/src/koffi/benchmark/rand_napi.js +47 -0
  25. package/src/koffi/benchmark/rand_node_ffi.js +55 -0
  26. package/{benchmark → src/koffi/benchmark}/raylib_cc.cc +2 -2
  27. package/{benchmark → src/koffi/benchmark}/raylib_cc.js +0 -0
  28. package/{benchmark → src/koffi/benchmark}/raylib_koffi.js +0 -0
  29. package/{benchmark → src/koffi/benchmark}/raylib_node_ffi.js +0 -0
  30. package/{benchmark → src/koffi/benchmark}/raylib_node_raylib.js +0 -0
  31. package/src/koffi/build/2.1.5/koffi_darwin_arm64.tar.gz +0 -0
  32. package/src/koffi/build/2.1.5/koffi_darwin_x64.tar.gz +0 -0
  33. package/src/koffi/build/2.1.5/koffi_freebsd_arm64.tar.gz +0 -0
  34. package/src/koffi/build/2.1.5/koffi_freebsd_ia32.tar.gz +0 -0
  35. package/src/koffi/build/2.1.5/koffi_freebsd_x64.tar.gz +0 -0
  36. package/src/koffi/build/2.1.5/koffi_linux_arm32hf.tar.gz +0 -0
  37. package/src/koffi/build/2.1.5/koffi_linux_arm64.tar.gz +0 -0
  38. package/src/koffi/build/2.1.5/koffi_linux_ia32.tar.gz +0 -0
  39. package/src/koffi/build/2.1.5/koffi_linux_riscv64hf64.tar.gz +0 -0
  40. package/src/koffi/build/2.1.5/koffi_linux_x64.tar.gz +0 -0
  41. package/src/koffi/build/2.1.5/koffi_openbsd_ia32.tar.gz +0 -0
  42. package/src/koffi/build/2.1.5/koffi_openbsd_x64.tar.gz +0 -0
  43. package/src/koffi/build/2.1.5/koffi_win32_arm64.tar.gz +0 -0
  44. package/src/koffi/build/2.1.5/koffi_win32_ia32.tar.gz +0 -0
  45. package/src/koffi/build/2.1.5/koffi_win32_x64.tar.gz +0 -0
  46. package/src/koffi/qemu/qemu/.gitkeep +0 -0
  47. package/{qemu → src/koffi/qemu}/qemu.js +227 -133
  48. package/{qemu → src/koffi/qemu}/registry/machines.json +24 -0
  49. package/{qemu → src/koffi/qemu}/registry/sha256sum.txt +0 -0
  50. package/src/{abi_arm32.cc → koffi/src/abi_arm32.cc} +1 -1
  51. package/src/{abi_arm32_fwd.S → koffi/src/abi_arm32_fwd.S} +0 -0
  52. package/src/{abi_arm64.cc → koffi/src/abi_arm64.cc} +1 -1
  53. package/src/{abi_arm64_fwd.S → koffi/src/abi_arm64_fwd.S} +0 -0
  54. package/src/{abi_arm64_fwd.asm → koffi/src/abi_arm64_fwd.asm} +0 -0
  55. package/src/{abi_riscv64.cc → koffi/src/abi_riscv64.cc} +1 -1
  56. package/src/{abi_riscv64_fwd.S → koffi/src/abi_riscv64_fwd.S} +0 -0
  57. package/src/{abi_x64_sysv.cc → koffi/src/abi_x64_sysv.cc} +1 -1
  58. package/src/{abi_x64_sysv_fwd.S → koffi/src/abi_x64_sysv_fwd.S} +0 -0
  59. package/src/{abi_x64_win.cc → koffi/src/abi_x64_win.cc} +1 -1
  60. package/src/{abi_x64_win_fwd.asm → koffi/src/abi_x64_win_fwd.asm} +0 -0
  61. package/src/{abi_x86.cc → koffi/src/abi_x86.cc} +1 -1
  62. package/src/{abi_x86_fwd.S → koffi/src/abi_x86_fwd.S} +0 -0
  63. package/src/{abi_x86_fwd.asm → koffi/src/abi_x86_fwd.asm} +0 -0
  64. package/src/{call.cc → koffi/src/call.cc} +1 -1
  65. package/src/{call.hh → koffi/src/call.hh} +2 -2
  66. package/src/{ffi.cc → koffi/src/ffi.cc} +34 -18
  67. package/src/{ffi.hh → koffi/src/ffi.hh} +5 -3
  68. package/src/{index.js → koffi/src/index.js} +0 -0
  69. package/src/{parser.cc → koffi/src/parser.cc} +1 -1
  70. package/src/{parser.hh → koffi/src/parser.hh} +1 -1
  71. package/src/{util.cc → koffi/src/util.cc} +1 -1
  72. package/src/{util.hh → koffi/src/util.hh} +1 -1
  73. package/{test → src/koffi/test}/CMakeLists.txt +14 -15
  74. package/{test → src/koffi/test}/async.js +0 -0
  75. package/{test → src/koffi/test}/callbacks.js +0 -0
  76. package/{test → src/koffi/test}/misc.c +13 -0
  77. package/{test → src/koffi/test}/misc.def +0 -0
  78. package/{test → src/koffi/test}/raylib.js +0 -0
  79. package/{test → src/koffi/test}/sqlite.js +1 -1
  80. package/{test → src/koffi/test}/sync.js +17 -0
  81. package/vendor/brotli/BUILD +144 -0
  82. package/vendor/brotli/CMakeLists.txt +421 -0
  83. package/vendor/brotli/CONTRIBUTING.md +27 -0
  84. package/vendor/brotli/LICENSE +19 -0
  85. package/vendor/brotli/MANIFEST.in +17 -0
  86. package/vendor/brotli/Makefile +55 -0
  87. package/vendor/brotli/Makefile.am +38 -0
  88. package/vendor/brotli/README +15 -0
  89. package/vendor/brotli/README.md +104 -0
  90. package/vendor/brotli/WORKSPACE +21 -0
  91. package/vendor/brotli/bootstrap +35 -0
  92. package/vendor/brotli/c/common/constants.c +15 -0
  93. package/vendor/brotli/c/common/constants.h +200 -0
  94. package/vendor/brotli/c/common/context.c +156 -0
  95. package/vendor/brotli/c/common/context.h +113 -0
  96. package/vendor/brotli/c/common/dictionary.c +5914 -0
  97. package/vendor/brotli/c/common/dictionary.h +64 -0
  98. package/vendor/brotli/c/common/platform.c +22 -0
  99. package/vendor/brotli/c/common/platform.h +594 -0
  100. package/vendor/brotli/c/common/transform.c +291 -0
  101. package/vendor/brotli/c/common/transform.h +85 -0
  102. package/vendor/brotli/c/common/version.h +26 -0
  103. package/vendor/brotli/c/dec/bit_reader.c +76 -0
  104. package/vendor/brotli/c/dec/bit_reader.h +351 -0
  105. package/vendor/brotli/c/dec/decode.c +2608 -0
  106. package/vendor/brotli/c/dec/huffman.c +339 -0
  107. package/vendor/brotli/c/dec/huffman.h +121 -0
  108. package/vendor/brotli/c/dec/prefix.h +732 -0
  109. package/vendor/brotli/c/dec/state.c +159 -0
  110. package/vendor/brotli/c/dec/state.h +365 -0
  111. package/vendor/brotli/c/enc/backward_references.c +145 -0
  112. package/vendor/brotli/c/enc/backward_references.h +39 -0
  113. package/vendor/brotli/c/enc/backward_references_hq.c +843 -0
  114. package/vendor/brotli/c/enc/backward_references_hq.h +95 -0
  115. package/vendor/brotli/c/enc/backward_references_inc.h +163 -0
  116. package/vendor/brotli/c/enc/bit_cost.c +35 -0
  117. package/vendor/brotli/c/enc/bit_cost.h +63 -0
  118. package/vendor/brotli/c/enc/bit_cost_inc.h +127 -0
  119. package/vendor/brotli/c/enc/block_encoder_inc.h +34 -0
  120. package/vendor/brotli/c/enc/block_splitter.c +194 -0
  121. package/vendor/brotli/c/enc/block_splitter.h +51 -0
  122. package/vendor/brotli/c/enc/block_splitter_inc.h +440 -0
  123. package/vendor/brotli/c/enc/brotli_bit_stream.c +1314 -0
  124. package/vendor/brotli/c/enc/brotli_bit_stream.h +84 -0
  125. package/vendor/brotli/c/enc/cluster.c +56 -0
  126. package/vendor/brotli/c/enc/cluster.h +48 -0
  127. package/vendor/brotli/c/enc/cluster_inc.h +320 -0
  128. package/vendor/brotli/c/enc/command.c +28 -0
  129. package/vendor/brotli/c/enc/command.h +190 -0
  130. package/vendor/brotli/c/enc/compress_fragment.c +790 -0
  131. package/vendor/brotli/c/enc/compress_fragment.h +61 -0
  132. package/vendor/brotli/c/enc/compress_fragment_two_pass.c +645 -0
  133. package/vendor/brotli/c/enc/compress_fragment_two_pass.h +54 -0
  134. package/vendor/brotli/c/enc/dictionary_hash.c +1846 -0
  135. package/vendor/brotli/c/enc/dictionary_hash.h +25 -0
  136. package/vendor/brotli/c/enc/encode.c +1927 -0
  137. package/vendor/brotli/c/enc/encoder_dict.c +33 -0
  138. package/vendor/brotli/c/enc/encoder_dict.h +43 -0
  139. package/vendor/brotli/c/enc/entropy_encode.c +503 -0
  140. package/vendor/brotli/c/enc/entropy_encode.h +122 -0
  141. package/vendor/brotli/c/enc/entropy_encode_static.h +539 -0
  142. package/vendor/brotli/c/enc/fast_log.c +105 -0
  143. package/vendor/brotli/c/enc/fast_log.h +66 -0
  144. package/vendor/brotli/c/enc/find_match_length.h +79 -0
  145. package/vendor/brotli/c/enc/hash.h +488 -0
  146. package/vendor/brotli/c/enc/hash_composite_inc.h +125 -0
  147. package/vendor/brotli/c/enc/hash_forgetful_chain_inc.h +293 -0
  148. package/vendor/brotli/c/enc/hash_longest_match64_inc.h +267 -0
  149. package/vendor/brotli/c/enc/hash_longest_match_inc.h +262 -0
  150. package/vendor/brotli/c/enc/hash_longest_match_quickly_inc.h +266 -0
  151. package/vendor/brotli/c/enc/hash_rolling_inc.h +212 -0
  152. package/vendor/brotli/c/enc/hash_to_binary_tree_inc.h +329 -0
  153. package/vendor/brotli/c/enc/histogram.c +100 -0
  154. package/vendor/brotli/c/enc/histogram.h +63 -0
  155. package/vendor/brotli/c/enc/histogram_inc.h +51 -0
  156. package/vendor/brotli/c/enc/literal_cost.c +175 -0
  157. package/vendor/brotli/c/enc/literal_cost.h +30 -0
  158. package/vendor/brotli/c/enc/memory.c +170 -0
  159. package/vendor/brotli/c/enc/memory.h +114 -0
  160. package/vendor/brotli/c/enc/metablock.c +663 -0
  161. package/vendor/brotli/c/enc/metablock.h +105 -0
  162. package/vendor/brotli/c/enc/metablock_inc.h +183 -0
  163. package/vendor/brotli/c/enc/params.h +46 -0
  164. package/vendor/brotli/c/enc/prefix.h +53 -0
  165. package/vendor/brotli/c/enc/quality.h +165 -0
  166. package/vendor/brotli/c/enc/ringbuffer.h +167 -0
  167. package/vendor/brotli/c/enc/static_dict.c +486 -0
  168. package/vendor/brotli/c/enc/static_dict.h +40 -0
  169. package/vendor/brotli/c/enc/static_dict_lut.h +5864 -0
  170. package/vendor/brotli/c/enc/utf8_util.c +85 -0
  171. package/vendor/brotli/c/enc/utf8_util.h +32 -0
  172. package/vendor/brotli/c/enc/write_bits.h +87 -0
  173. package/vendor/brotli/c/include/brotli/decode.h +344 -0
  174. package/vendor/brotli/c/include/brotli/encode.h +448 -0
  175. package/vendor/brotli/c/include/brotli/port.h +288 -0
  176. package/vendor/brotli/c/include/brotli/types.h +83 -0
  177. package/vendor/brotli/c/tools/brotli.c +1116 -0
  178. package/vendor/brotli/c/tools/brotli.md +107 -0
  179. package/vendor/brotli/compiler_config_setting.bzl +28 -0
  180. package/vendor/brotli/configure +8 -0
  181. package/vendor/brotli/configure-cmake +318 -0
  182. package/vendor/brotli/configure.ac +14 -0
  183. package/vendor/brotli/docs/brotli.1 +132 -0
  184. package/vendor/brotli/docs/constants.h.3 +47 -0
  185. package/vendor/brotli/docs/decode.h.3 +415 -0
  186. package/vendor/brotli/docs/encode.h.3 +586 -0
  187. package/vendor/brotli/docs/types.h.3 +117 -0
  188. package/vendor/brotli/premake5.lua +78 -0
  189. package/vendor/brotli/python/Makefile +57 -0
  190. package/vendor/brotli/python/README.md +54 -0
  191. package/vendor/brotli/python/_brotli.cc +753 -0
  192. package/vendor/brotli/python/bro.py +160 -0
  193. package/vendor/brotli/python/brotli.py +56 -0
  194. package/vendor/brotli/python/tests/__init__.py +0 -0
  195. package/vendor/brotli/python/tests/_test_utils.py +112 -0
  196. package/vendor/brotli/python/tests/bro_test.py +102 -0
  197. package/vendor/brotli/python/tests/compress_test.py +41 -0
  198. package/vendor/brotli/python/tests/compressor_test.py +94 -0
  199. package/vendor/brotli/python/tests/decompress_test.py +42 -0
  200. package/vendor/brotli/python/tests/decompressor_test.py +59 -0
  201. package/vendor/brotli/scripts/libbrotlicommon.pc.in +11 -0
  202. package/vendor/brotli/scripts/libbrotlidec.pc.in +12 -0
  203. package/vendor/brotli/scripts/libbrotlienc.pc.in +12 -0
  204. package/vendor/brotli/scripts/sources.lst +104 -0
  205. package/vendor/brotli/setup.cfg +5 -0
  206. package/vendor/brotli/setup.py +293 -0
  207. package/vendor/brotli/tests/Makefile +17 -0
  208. package/vendor/brotli/tests/compatibility_test.sh +25 -0
  209. package/vendor/brotli/tests/roundtrip_test.sh +36 -0
  210. package/vendor/brotli/tests/run-compatibility-test.cmake +31 -0
  211. package/vendor/brotli/tests/run-roundtrip-test.cmake +36 -0
  212. package/vendor/brotli/tests/testdata/empty +0 -0
  213. package/vendor/brotli/tests/testdata/empty.compressed +1 -0
  214. package/vendor/brotli/tests/testdata/ukkonooa +1 -0
  215. package/vendor/brotli/tests/testdata/ukkonooa.compressed +0 -0
  216. package/vendor/miniz/ChangeLog.md +235 -0
  217. package/vendor/miniz/LICENSE +22 -0
  218. package/vendor/miniz/examples/example1.c +105 -0
  219. package/vendor/miniz/examples/example2.c +164 -0
  220. package/vendor/miniz/examples/example3.c +269 -0
  221. package/vendor/miniz/examples/example4.c +102 -0
  222. package/vendor/miniz/examples/example5.c +327 -0
  223. package/vendor/miniz/examples/example6.c +166 -0
  224. package/vendor/miniz/miniz.c +7835 -0
  225. package/vendor/miniz/miniz.h +1422 -0
  226. package/vendor/miniz/readme.md +46 -0
  227. package/vendor/{sqlite3 → sqlite3mc}/sqlite3ext.h +18 -2
  228. package/vendor/{sqlite3/sqlite3.c → sqlite3mc/sqlite3mc.c} +60872 -4890
  229. package/vendor/sqlite3mc/sqlite3mc.def +312 -0
  230. package/vendor/{sqlite3/sqlite3.h → sqlite3mc/sqlite3mc.h} +480 -36
  231. package/build/qemu/2.1.3/koffi_darwin_arm64.tar.gz +0 -0
  232. package/build/qemu/2.1.3/koffi_darwin_x64.tar.gz +0 -0
  233. package/build/qemu/2.1.3/koffi_freebsd_arm64.tar.gz +0 -0
  234. package/build/qemu/2.1.3/koffi_freebsd_ia32.tar.gz +0 -0
  235. package/build/qemu/2.1.3/koffi_freebsd_x64.tar.gz +0 -0
  236. package/build/qemu/2.1.3/koffi_linux_arm32hf.tar.gz +0 -0
  237. package/build/qemu/2.1.3/koffi_linux_arm64.tar.gz +0 -0
  238. package/build/qemu/2.1.3/koffi_linux_ia32.tar.gz +0 -0
  239. package/build/qemu/2.1.3/koffi_linux_riscv64hf64.tar.gz +0 -0
  240. package/build/qemu/2.1.3/koffi_linux_x64.tar.gz +0 -0
  241. package/build/qemu/2.1.3/koffi_openbsd_ia32.tar.gz +0 -0
  242. package/build/qemu/2.1.3/koffi_openbsd_x64.tar.gz +0 -0
  243. package/build/qemu/2.1.3/koffi_win32_arm64.tar.gz +0 -0
  244. package/build/qemu/2.1.3/koffi_win32_ia32.tar.gz +0 -0
  245. package/build/qemu/2.1.3/koffi_win32_x64.tar.gz +0 -0
  246. package/vendor/_patches/glfw_001_fix_openbsd_xlib_soname.patch +0 -145
  247. package/vendor/raylib/projects/VS2019-Android/raylib_android/raylib_android.NativeActivity/raylib_android.NativeActivity.vcxproj +0 -226
  248. package/vendor/raylib/projects/VS2019-Android/raylib_android/raylib_android.NativeActivity/raylib_android.NativeActivity.vcxproj.filters +0 -10
  249. package/vendor/raylib/projects/VS2019-Android/raylib_android/raylib_android.NativeActivity/raylib_android.NativeActivity.vcxproj.user +0 -4
  250. package/vendor/raylib/projects/VS2019-Android/raylib_android.sln +0 -75
  251. package/vendor/raylib/projects/VS2022/examples/audio_module_playing.vcxproj +0 -390
  252. package/vendor/raylib/projects/VS2022/examples/audio_multichannel_sound.vcxproj +0 -390
  253. package/vendor/raylib/projects/VS2022/examples/audio_music_stream.vcxproj +0 -390
  254. package/vendor/raylib/projects/VS2022/examples/audio_raw_stream.vcxproj +0 -390
  255. package/vendor/raylib/projects/VS2022/examples/audio_sound_loading.vcxproj +0 -390
  256. package/vendor/raylib/projects/VS2022/examples/audio_stream_effects.vcxproj +0 -390
  257. package/vendor/raylib/projects/VS2022/examples/core_2d_camera.vcxproj +0 -390
  258. package/vendor/raylib/projects/VS2022/examples/core_2d_camera_mouse_zoom.vcxproj +0 -390
  259. package/vendor/raylib/projects/VS2022/examples/core_2d_camera_platformer.vcxproj +0 -390
  260. package/vendor/raylib/projects/VS2022/examples/core_3d_camera_first_person.vcxproj +0 -390
  261. package/vendor/raylib/projects/VS2022/examples/core_3d_camera_free.vcxproj +0 -390
  262. package/vendor/raylib/projects/VS2022/examples/core_3d_camera_mode.vcxproj +0 -390
  263. package/vendor/raylib/projects/VS2022/examples/core_3d_picking.vcxproj +0 -390
  264. package/vendor/raylib/projects/VS2022/examples/core_basic_screen_manager.vcxproj +0 -390
  265. package/vendor/raylib/projects/VS2022/examples/core_basic_window.vcxproj +0 -390
  266. package/vendor/raylib/projects/VS2022/examples/core_custom_frame_control.vcxproj +0 -390
  267. package/vendor/raylib/projects/VS2022/examples/core_custom_logging.vcxproj +0 -390
  268. package/vendor/raylib/projects/VS2022/examples/core_drop_files.vcxproj +0 -390
  269. package/vendor/raylib/projects/VS2022/examples/core_input_gamepad.vcxproj +0 -387
  270. package/vendor/raylib/projects/VS2022/examples/core_input_gestures.vcxproj +0 -387
  271. package/vendor/raylib/projects/VS2022/examples/core_input_keys.vcxproj +0 -387
  272. package/vendor/raylib/projects/VS2022/examples/core_input_mouse.vcxproj +0 -387
  273. package/vendor/raylib/projects/VS2022/examples/core_input_mouse_wheel.vcxproj +0 -387
  274. package/vendor/raylib/projects/VS2022/examples/core_input_multitouch.vcxproj +0 -387
  275. package/vendor/raylib/projects/VS2022/examples/core_loading_thread.vcxproj +0 -387
  276. package/vendor/raylib/projects/VS2022/examples/core_random_values.vcxproj +0 -387
  277. package/vendor/raylib/projects/VS2022/examples/core_scissor_test.vcxproj +0 -387
  278. package/vendor/raylib/projects/VS2022/examples/core_split_screen.vcxproj +0 -387
  279. package/vendor/raylib/projects/VS2022/examples/core_storage_values.vcxproj +0 -387
  280. package/vendor/raylib/projects/VS2022/examples/core_vr_simulator.vcxproj +0 -387
  281. package/vendor/raylib/projects/VS2022/examples/core_window_flags.vcxproj +0 -387
  282. package/vendor/raylib/projects/VS2022/examples/core_window_letterbox.vcxproj +0 -387
  283. package/vendor/raylib/projects/VS2022/examples/core_window_should_close.vcxproj +0 -390
  284. package/vendor/raylib/projects/VS2022/examples/core_world_screen.vcxproj +0 -387
  285. package/vendor/raylib/projects/VS2022/examples/easings_testbed.vcxproj +0 -387
  286. package/vendor/raylib/projects/VS2022/examples/embedded_files_loading.vcxproj +0 -387
  287. package/vendor/raylib/projects/VS2022/examples/models_animation.vcxproj +0 -387
  288. package/vendor/raylib/projects/VS2022/examples/models_billboard.vcxproj +0 -387
  289. package/vendor/raylib/projects/VS2022/examples/models_box_collisions.vcxproj +0 -387
  290. package/vendor/raylib/projects/VS2022/examples/models_cubicmap.vcxproj +0 -387
  291. package/vendor/raylib/projects/VS2022/examples/models_first_person_maze.vcxproj +0 -387
  292. package/vendor/raylib/projects/VS2022/examples/models_geometric_shapes.vcxproj +0 -387
  293. package/vendor/raylib/projects/VS2022/examples/models_heightmap.vcxproj +0 -387
  294. package/vendor/raylib/projects/VS2022/examples/models_loading.vcxproj +0 -387
  295. package/vendor/raylib/projects/VS2022/examples/models_loading_gltf.vcxproj +0 -387
  296. package/vendor/raylib/projects/VS2022/examples/models_loading_vox.vcxproj +0 -387
  297. package/vendor/raylib/projects/VS2022/examples/models_mesh_generation.vcxproj +0 -387
  298. package/vendor/raylib/projects/VS2022/examples/models_mesh_picking.vcxproj +0 -387
  299. package/vendor/raylib/projects/VS2022/examples/models_orthographic_projection.vcxproj +0 -387
  300. package/vendor/raylib/projects/VS2022/examples/models_rlgl_solar_system.vcxproj +0 -387
  301. package/vendor/raylib/projects/VS2022/examples/models_skybox.vcxproj +0 -387
  302. package/vendor/raylib/projects/VS2022/examples/models_waving_cubes.vcxproj +0 -387
  303. package/vendor/raylib/projects/VS2022/examples/models_yaw_pitch_roll.vcxproj +0 -387
  304. package/vendor/raylib/projects/VS2022/examples/rlgl_compute_shaders.vcxproj +0 -391
  305. package/vendor/raylib/projects/VS2022/examples/rlgl_standalone.vcxproj +0 -391
  306. package/vendor/raylib/projects/VS2022/examples/shaders_basic_lighting.vcxproj +0 -387
  307. package/vendor/raylib/projects/VS2022/examples/shaders_custom_uniform.vcxproj +0 -387
  308. package/vendor/raylib/projects/VS2022/examples/shaders_eratosthenes.vcxproj +0 -387
  309. package/vendor/raylib/projects/VS2022/examples/shaders_fog.vcxproj +0 -387
  310. package/vendor/raylib/projects/VS2022/examples/shaders_hot_reloading.vcxproj +0 -387
  311. package/vendor/raylib/projects/VS2022/examples/shaders_julia_set.vcxproj +0 -387
  312. package/vendor/raylib/projects/VS2022/examples/shaders_mesh_instancing.vcxproj +0 -387
  313. package/vendor/raylib/projects/VS2022/examples/shaders_model_shader.vcxproj +0 -387
  314. package/vendor/raylib/projects/VS2022/examples/shaders_multi_sample2d.vcxproj +0 -387
  315. package/vendor/raylib/projects/VS2022/examples/shaders_palette_switch.vcxproj +0 -387
  316. package/vendor/raylib/projects/VS2022/examples/shaders_postprocessing.vcxproj +0 -387
  317. package/vendor/raylib/projects/VS2022/examples/shaders_raymarching.vcxproj +0 -387
  318. package/vendor/raylib/projects/VS2022/examples/shaders_shapes_textures.vcxproj +0 -387
  319. package/vendor/raylib/projects/VS2022/examples/shaders_simple_mask.vcxproj +0 -387
  320. package/vendor/raylib/projects/VS2022/examples/shaders_spotlight.vcxproj +0 -387
  321. package/vendor/raylib/projects/VS2022/examples/shaders_texture_drawing.vcxproj +0 -387
  322. package/vendor/raylib/projects/VS2022/examples/shaders_texture_waves.vcxproj +0 -387
  323. package/vendor/raylib/projects/VS2022/examples/shapes_basic_shapes.vcxproj +0 -387
  324. package/vendor/raylib/projects/VS2022/examples/shapes_bouncing_ball.vcxproj +0 -387
  325. package/vendor/raylib/projects/VS2022/examples/shapes_collision_area.vcxproj +0 -387
  326. package/vendor/raylib/projects/VS2022/examples/shapes_colors_palette.vcxproj +0 -387
  327. package/vendor/raylib/projects/VS2022/examples/shapes_draw_circle_sector.vcxproj +0 -387
  328. package/vendor/raylib/projects/VS2022/examples/shapes_draw_rectangle_rounded.vcxproj +0 -387
  329. package/vendor/raylib/projects/VS2022/examples/shapes_draw_ring.vcxproj +0 -387
  330. package/vendor/raylib/projects/VS2022/examples/shapes_easings_ball_anim.vcxproj +0 -387
  331. package/vendor/raylib/projects/VS2022/examples/shapes_easings_box_anim.vcxproj +0 -387
  332. package/vendor/raylib/projects/VS2022/examples/shapes_easings_rectangle_array.vcxproj +0 -387
  333. package/vendor/raylib/projects/VS2022/examples/shapes_following_eyes.vcxproj +0 -387
  334. package/vendor/raylib/projects/VS2022/examples/shapes_lines_bezier.vcxproj +0 -387
  335. package/vendor/raylib/projects/VS2022/examples/shapes_logo_raylib.vcxproj +0 -387
  336. package/vendor/raylib/projects/VS2022/examples/shapes_logo_raylib_anim.vcxproj +0 -387
  337. package/vendor/raylib/projects/VS2022/examples/shapes_rectangle_scaling.vcxproj +0 -387
  338. package/vendor/raylib/projects/VS2022/examples/text_codepoints_loading.vcxproj +0 -387
  339. package/vendor/raylib/projects/VS2022/examples/text_draw_3d.vcxproj +0 -387
  340. package/vendor/raylib/projects/VS2022/examples/text_font_filters.vcxproj +0 -387
  341. package/vendor/raylib/projects/VS2022/examples/text_font_loading.vcxproj +0 -387
  342. package/vendor/raylib/projects/VS2022/examples/text_font_sdf.vcxproj +0 -387
  343. package/vendor/raylib/projects/VS2022/examples/text_font_spritefont.vcxproj +0 -387
  344. package/vendor/raylib/projects/VS2022/examples/text_format_text.vcxproj +0 -387
  345. package/vendor/raylib/projects/VS2022/examples/text_input_box.vcxproj +0 -387
  346. package/vendor/raylib/projects/VS2022/examples/text_raylib_fonts.vcxproj +0 -387
  347. package/vendor/raylib/projects/VS2022/examples/text_rectangle_bounds.vcxproj +0 -387
  348. package/vendor/raylib/projects/VS2022/examples/text_unicode.vcxproj +0 -387
  349. package/vendor/raylib/projects/VS2022/examples/text_writing_anim.vcxproj +0 -387
  350. package/vendor/raylib/projects/VS2022/examples/textures_background_scrolling.vcxproj +0 -387
  351. package/vendor/raylib/projects/VS2022/examples/textures_blend_modes.vcxproj +0 -387
  352. package/vendor/raylib/projects/VS2022/examples/textures_bunnymark.vcxproj +0 -387
  353. package/vendor/raylib/projects/VS2022/examples/textures_draw_tiled.vcxproj +0 -387
  354. package/vendor/raylib/projects/VS2022/examples/textures_fog_of_war.vcxproj +0 -387
  355. package/vendor/raylib/projects/VS2022/examples/textures_gif_player.vcxproj +0 -387
  356. package/vendor/raylib/projects/VS2022/examples/textures_image_drawing.vcxproj +0 -387
  357. package/vendor/raylib/projects/VS2022/examples/textures_image_generation.vcxproj +0 -387
  358. package/vendor/raylib/projects/VS2022/examples/textures_image_loading.vcxproj +0 -387
  359. package/vendor/raylib/projects/VS2022/examples/textures_image_processing.vcxproj +0 -387
  360. package/vendor/raylib/projects/VS2022/examples/textures_image_text.vcxproj +0 -387
  361. package/vendor/raylib/projects/VS2022/examples/textures_logo_raylib.vcxproj +0 -387
  362. package/vendor/raylib/projects/VS2022/examples/textures_mouse_painting.vcxproj +0 -387
  363. package/vendor/raylib/projects/VS2022/examples/textures_npatch_drawing.vcxproj +0 -387
  364. package/vendor/raylib/projects/VS2022/examples/textures_particles_blending.vcxproj +0 -387
  365. package/vendor/raylib/projects/VS2022/examples/textures_polygon.vcxproj +0 -387
  366. package/vendor/raylib/projects/VS2022/examples/textures_raw_data.vcxproj +0 -387
  367. package/vendor/raylib/projects/VS2022/examples/textures_sprite_anim.vcxproj +0 -387
  368. package/vendor/raylib/projects/VS2022/examples/textures_sprite_button.vcxproj +0 -387
  369. package/vendor/raylib/projects/VS2022/examples/textures_sprite_explosion.vcxproj +0 -387
  370. package/vendor/raylib/projects/VS2022/examples/textures_srcrec_dstrec.vcxproj +0 -387
  371. package/vendor/raylib/projects/VS2022/examples/textures_to_image.vcxproj +0 -387
  372. package/vendor/raylib/projects/VS2022/raylib/raylib.vcxproj +0 -340
  373. package/vendor/raylib/projects/VS2022/raylib.sln +0 -2347
  374. package/vendor/sqlite3/shell.c +0 -23496
@@ -0,0 +1,339 @@
1
+ /* Copyright 2013 Google Inc. All Rights Reserved.
2
+
3
+ Distributed under MIT license.
4
+ See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
5
+ */
6
+
7
+ /* Utilities for building Huffman decoding tables. */
8
+
9
+ #include "./huffman.h"
10
+
11
+ #include <string.h> /* memcpy, memset */
12
+
13
+ #include "../common/constants.h"
14
+ #include "../common/platform.h"
15
+ #include <brotli/types.h>
16
+
17
+ #if defined(__cplusplus) || defined(c_plusplus)
18
+ extern "C" {
19
+ #endif
20
+
21
+ #define BROTLI_REVERSE_BITS_MAX 8
22
+
23
+ #if defined(BROTLI_RBIT)
24
+ #define BROTLI_REVERSE_BITS_BASE \
25
+ ((sizeof(brotli_reg_t) << 3) - BROTLI_REVERSE_BITS_MAX)
26
+ #else
27
+ #define BROTLI_REVERSE_BITS_BASE 0
28
+ static uint8_t kReverseBits[1 << BROTLI_REVERSE_BITS_MAX] = {
29
+ 0x00, 0x80, 0x40, 0xC0, 0x20, 0xA0, 0x60, 0xE0,
30
+ 0x10, 0x90, 0x50, 0xD0, 0x30, 0xB0, 0x70, 0xF0,
31
+ 0x08, 0x88, 0x48, 0xC8, 0x28, 0xA8, 0x68, 0xE8,
32
+ 0x18, 0x98, 0x58, 0xD8, 0x38, 0xB8, 0x78, 0xF8,
33
+ 0x04, 0x84, 0x44, 0xC4, 0x24, 0xA4, 0x64, 0xE4,
34
+ 0x14, 0x94, 0x54, 0xD4, 0x34, 0xB4, 0x74, 0xF4,
35
+ 0x0C, 0x8C, 0x4C, 0xCC, 0x2C, 0xAC, 0x6C, 0xEC,
36
+ 0x1C, 0x9C, 0x5C, 0xDC, 0x3C, 0xBC, 0x7C, 0xFC,
37
+ 0x02, 0x82, 0x42, 0xC2, 0x22, 0xA2, 0x62, 0xE2,
38
+ 0x12, 0x92, 0x52, 0xD2, 0x32, 0xB2, 0x72, 0xF2,
39
+ 0x0A, 0x8A, 0x4A, 0xCA, 0x2A, 0xAA, 0x6A, 0xEA,
40
+ 0x1A, 0x9A, 0x5A, 0xDA, 0x3A, 0xBA, 0x7A, 0xFA,
41
+ 0x06, 0x86, 0x46, 0xC6, 0x26, 0xA6, 0x66, 0xE6,
42
+ 0x16, 0x96, 0x56, 0xD6, 0x36, 0xB6, 0x76, 0xF6,
43
+ 0x0E, 0x8E, 0x4E, 0xCE, 0x2E, 0xAE, 0x6E, 0xEE,
44
+ 0x1E, 0x9E, 0x5E, 0xDE, 0x3E, 0xBE, 0x7E, 0xFE,
45
+ 0x01, 0x81, 0x41, 0xC1, 0x21, 0xA1, 0x61, 0xE1,
46
+ 0x11, 0x91, 0x51, 0xD1, 0x31, 0xB1, 0x71, 0xF1,
47
+ 0x09, 0x89, 0x49, 0xC9, 0x29, 0xA9, 0x69, 0xE9,
48
+ 0x19, 0x99, 0x59, 0xD9, 0x39, 0xB9, 0x79, 0xF9,
49
+ 0x05, 0x85, 0x45, 0xC5, 0x25, 0xA5, 0x65, 0xE5,
50
+ 0x15, 0x95, 0x55, 0xD5, 0x35, 0xB5, 0x75, 0xF5,
51
+ 0x0D, 0x8D, 0x4D, 0xCD, 0x2D, 0xAD, 0x6D, 0xED,
52
+ 0x1D, 0x9D, 0x5D, 0xDD, 0x3D, 0xBD, 0x7D, 0xFD,
53
+ 0x03, 0x83, 0x43, 0xC3, 0x23, 0xA3, 0x63, 0xE3,
54
+ 0x13, 0x93, 0x53, 0xD3, 0x33, 0xB3, 0x73, 0xF3,
55
+ 0x0B, 0x8B, 0x4B, 0xCB, 0x2B, 0xAB, 0x6B, 0xEB,
56
+ 0x1B, 0x9B, 0x5B, 0xDB, 0x3B, 0xBB, 0x7B, 0xFB,
57
+ 0x07, 0x87, 0x47, 0xC7, 0x27, 0xA7, 0x67, 0xE7,
58
+ 0x17, 0x97, 0x57, 0xD7, 0x37, 0xB7, 0x77, 0xF7,
59
+ 0x0F, 0x8F, 0x4F, 0xCF, 0x2F, 0xAF, 0x6F, 0xEF,
60
+ 0x1F, 0x9F, 0x5F, 0xDF, 0x3F, 0xBF, 0x7F, 0xFF
61
+ };
62
+ #endif /* BROTLI_RBIT */
63
+
64
+ #define BROTLI_REVERSE_BITS_LOWEST \
65
+ ((brotli_reg_t)1 << (BROTLI_REVERSE_BITS_MAX - 1 + BROTLI_REVERSE_BITS_BASE))
66
+
67
+ /* Returns reverse(num >> BROTLI_REVERSE_BITS_BASE, BROTLI_REVERSE_BITS_MAX),
68
+ where reverse(value, len) is the bit-wise reversal of the len least
69
+ significant bits of value. */
70
+ static BROTLI_INLINE brotli_reg_t BrotliReverseBits(brotli_reg_t num) {
71
+ #if defined(BROTLI_RBIT)
72
+ return BROTLI_RBIT(num);
73
+ #else
74
+ return kReverseBits[num];
75
+ #endif
76
+ }
77
+
78
+ /* Stores code in table[0], table[step], table[2*step], ..., table[end] */
79
+ /* Assumes that end is an integer multiple of step */
80
+ static BROTLI_INLINE void ReplicateValue(HuffmanCode* table,
81
+ int step, int end,
82
+ HuffmanCode code) {
83
+ do {
84
+ end -= step;
85
+ table[end] = code;
86
+ } while (end > 0);
87
+ }
88
+
89
+ /* Returns the table width of the next 2nd level table. |count| is the histogram
90
+ of bit lengths for the remaining symbols, |len| is the code length of the
91
+ next processed symbol. */
92
+ static BROTLI_INLINE int NextTableBitSize(const uint16_t* const count,
93
+ int len, int root_bits) {
94
+ int left = 1 << (len - root_bits);
95
+ while (len < BROTLI_HUFFMAN_MAX_CODE_LENGTH) {
96
+ left -= count[len];
97
+ if (left <= 0) break;
98
+ ++len;
99
+ left <<= 1;
100
+ }
101
+ return len - root_bits;
102
+ }
103
+
104
+ void BrotliBuildCodeLengthsHuffmanTable(HuffmanCode* table,
105
+ const uint8_t* const code_lengths,
106
+ uint16_t* count) {
107
+ HuffmanCode code; /* current table entry */
108
+ int symbol; /* symbol index in original or sorted table */
109
+ brotli_reg_t key; /* prefix code */
110
+ brotli_reg_t key_step; /* prefix code addend */
111
+ int step; /* step size to replicate values in current table */
112
+ int table_size; /* size of current table */
113
+ int sorted[BROTLI_CODE_LENGTH_CODES]; /* symbols sorted by code length */
114
+ /* offsets in sorted table for each length */
115
+ int offset[BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH + 1];
116
+ int bits;
117
+ int bits_count;
118
+ BROTLI_DCHECK(BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH <=
119
+ BROTLI_REVERSE_BITS_MAX);
120
+
121
+ /* Generate offsets into sorted symbol table by code length. */
122
+ symbol = -1;
123
+ bits = 1;
124
+ BROTLI_REPEAT(BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH, {
125
+ symbol += count[bits];
126
+ offset[bits] = symbol;
127
+ bits++;
128
+ });
129
+ /* Symbols with code length 0 are placed after all other symbols. */
130
+ offset[0] = BROTLI_CODE_LENGTH_CODES - 1;
131
+
132
+ /* Sort symbols by length, by symbol order within each length. */
133
+ symbol = BROTLI_CODE_LENGTH_CODES;
134
+ do {
135
+ BROTLI_REPEAT(6, {
136
+ symbol--;
137
+ sorted[offset[code_lengths[symbol]]--] = symbol;
138
+ });
139
+ } while (symbol != 0);
140
+
141
+ table_size = 1 << BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH;
142
+
143
+ /* Special case: all symbols but one have 0 code length. */
144
+ if (offset[0] == 0) {
145
+ code = ConstructHuffmanCode(0, (uint16_t)sorted[0]);
146
+ for (key = 0; key < (brotli_reg_t)table_size; ++key) {
147
+ table[key] = code;
148
+ }
149
+ return;
150
+ }
151
+
152
+ /* Fill in table. */
153
+ key = 0;
154
+ key_step = BROTLI_REVERSE_BITS_LOWEST;
155
+ symbol = 0;
156
+ bits = 1;
157
+ step = 2;
158
+ do {
159
+ for (bits_count = count[bits]; bits_count != 0; --bits_count) {
160
+ code = ConstructHuffmanCode((uint8_t)bits, (uint16_t)sorted[symbol++]);
161
+ ReplicateValue(&table[BrotliReverseBits(key)], step, table_size, code);
162
+ key += key_step;
163
+ }
164
+ step <<= 1;
165
+ key_step >>= 1;
166
+ } while (++bits <= BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH);
167
+ }
168
+
169
+ uint32_t BrotliBuildHuffmanTable(HuffmanCode* root_table,
170
+ int root_bits,
171
+ const uint16_t* const symbol_lists,
172
+ uint16_t* count) {
173
+ HuffmanCode code; /* current table entry */
174
+ HuffmanCode* table; /* next available space in table */
175
+ int len; /* current code length */
176
+ int symbol; /* symbol index in original or sorted table */
177
+ brotli_reg_t key; /* prefix code */
178
+ brotli_reg_t key_step; /* prefix code addend */
179
+ brotli_reg_t sub_key; /* 2nd level table prefix code */
180
+ brotli_reg_t sub_key_step; /* 2nd level table prefix code addend */
181
+ int step; /* step size to replicate values in current table */
182
+ int table_bits; /* key length of current table */
183
+ int table_size; /* size of current table */
184
+ int total_size; /* sum of root table size and 2nd level table sizes */
185
+ int max_length = -1;
186
+ int bits;
187
+ int bits_count;
188
+
189
+ BROTLI_DCHECK(root_bits <= BROTLI_REVERSE_BITS_MAX);
190
+ BROTLI_DCHECK(BROTLI_HUFFMAN_MAX_CODE_LENGTH - root_bits <=
191
+ BROTLI_REVERSE_BITS_MAX);
192
+
193
+ while (symbol_lists[max_length] == 0xFFFF) max_length--;
194
+ max_length += BROTLI_HUFFMAN_MAX_CODE_LENGTH + 1;
195
+
196
+ table = root_table;
197
+ table_bits = root_bits;
198
+ table_size = 1 << table_bits;
199
+ total_size = table_size;
200
+
201
+ /* Fill in the root table. Reduce the table size to if possible,
202
+ and create the repetitions by memcpy. */
203
+ if (table_bits > max_length) {
204
+ table_bits = max_length;
205
+ table_size = 1 << table_bits;
206
+ }
207
+ key = 0;
208
+ key_step = BROTLI_REVERSE_BITS_LOWEST;
209
+ bits = 1;
210
+ step = 2;
211
+ do {
212
+ symbol = bits - (BROTLI_HUFFMAN_MAX_CODE_LENGTH + 1);
213
+ for (bits_count = count[bits]; bits_count != 0; --bits_count) {
214
+ symbol = symbol_lists[symbol];
215
+ code = ConstructHuffmanCode((uint8_t)bits, (uint16_t)symbol);
216
+ ReplicateValue(&table[BrotliReverseBits(key)], step, table_size, code);
217
+ key += key_step;
218
+ }
219
+ step <<= 1;
220
+ key_step >>= 1;
221
+ } while (++bits <= table_bits);
222
+
223
+ /* If root_bits != table_bits then replicate to fill the remaining slots. */
224
+ while (total_size != table_size) {
225
+ memcpy(&table[table_size], &table[0],
226
+ (size_t)table_size * sizeof(table[0]));
227
+ table_size <<= 1;
228
+ }
229
+
230
+ /* Fill in 2nd level tables and add pointers to root table. */
231
+ key_step = BROTLI_REVERSE_BITS_LOWEST >> (root_bits - 1);
232
+ sub_key = (BROTLI_REVERSE_BITS_LOWEST << 1);
233
+ sub_key_step = BROTLI_REVERSE_BITS_LOWEST;
234
+ for (len = root_bits + 1, step = 2; len <= max_length; ++len) {
235
+ symbol = len - (BROTLI_HUFFMAN_MAX_CODE_LENGTH + 1);
236
+ for (; count[len] != 0; --count[len]) {
237
+ if (sub_key == (BROTLI_REVERSE_BITS_LOWEST << 1U)) {
238
+ table += table_size;
239
+ table_bits = NextTableBitSize(count, len, root_bits);
240
+ table_size = 1 << table_bits;
241
+ total_size += table_size;
242
+ sub_key = BrotliReverseBits(key);
243
+ key += key_step;
244
+ root_table[sub_key] = ConstructHuffmanCode(
245
+ (uint8_t)(table_bits + root_bits),
246
+ (uint16_t)(((size_t)(table - root_table)) - sub_key));
247
+ sub_key = 0;
248
+ }
249
+ symbol = symbol_lists[symbol];
250
+ code = ConstructHuffmanCode((uint8_t)(len - root_bits), (uint16_t)symbol);
251
+ ReplicateValue(
252
+ &table[BrotliReverseBits(sub_key)], step, table_size, code);
253
+ sub_key += sub_key_step;
254
+ }
255
+ step <<= 1;
256
+ sub_key_step >>= 1;
257
+ }
258
+ return (uint32_t)total_size;
259
+ }
260
+
261
+ uint32_t BrotliBuildSimpleHuffmanTable(HuffmanCode* table,
262
+ int root_bits,
263
+ uint16_t* val,
264
+ uint32_t num_symbols) {
265
+ uint32_t table_size = 1;
266
+ const uint32_t goal_size = 1U << root_bits;
267
+ switch (num_symbols) {
268
+ case 0:
269
+ table[0] = ConstructHuffmanCode(0, val[0]);
270
+ break;
271
+ case 1:
272
+ if (val[1] > val[0]) {
273
+ table[0] = ConstructHuffmanCode(1, val[0]);
274
+ table[1] = ConstructHuffmanCode(1, val[1]);
275
+ } else {
276
+ table[0] = ConstructHuffmanCode(1, val[1]);
277
+ table[1] = ConstructHuffmanCode(1, val[0]);
278
+ }
279
+ table_size = 2;
280
+ break;
281
+ case 2:
282
+ table[0] = ConstructHuffmanCode(1, val[0]);
283
+ table[2] = ConstructHuffmanCode(1, val[0]);
284
+ if (val[2] > val[1]) {
285
+ table[1] = ConstructHuffmanCode(2, val[1]);
286
+ table[3] = ConstructHuffmanCode(2, val[2]);
287
+ } else {
288
+ table[1] = ConstructHuffmanCode(2, val[2]);
289
+ table[3] = ConstructHuffmanCode(2, val[1]);
290
+ }
291
+ table_size = 4;
292
+ break;
293
+ case 3: {
294
+ int i, k;
295
+ for (i = 0; i < 3; ++i) {
296
+ for (k = i + 1; k < 4; ++k) {
297
+ if (val[k] < val[i]) {
298
+ uint16_t t = val[k];
299
+ val[k] = val[i];
300
+ val[i] = t;
301
+ }
302
+ }
303
+ }
304
+ table[0] = ConstructHuffmanCode(2, val[0]);
305
+ table[2] = ConstructHuffmanCode(2, val[1]);
306
+ table[1] = ConstructHuffmanCode(2, val[2]);
307
+ table[3] = ConstructHuffmanCode(2, val[3]);
308
+ table_size = 4;
309
+ break;
310
+ }
311
+ case 4: {
312
+ if (val[3] < val[2]) {
313
+ uint16_t t = val[3];
314
+ val[3] = val[2];
315
+ val[2] = t;
316
+ }
317
+ table[0] = ConstructHuffmanCode(1, val[0]);
318
+ table[1] = ConstructHuffmanCode(2, val[1]);
319
+ table[2] = ConstructHuffmanCode(1, val[0]);
320
+ table[3] = ConstructHuffmanCode(3, val[2]);
321
+ table[4] = ConstructHuffmanCode(1, val[0]);
322
+ table[5] = ConstructHuffmanCode(2, val[1]);
323
+ table[6] = ConstructHuffmanCode(1, val[0]);
324
+ table[7] = ConstructHuffmanCode(3, val[3]);
325
+ table_size = 8;
326
+ break;
327
+ }
328
+ }
329
+ while (table_size != goal_size) {
330
+ memcpy(&table[table_size], &table[0],
331
+ (size_t)table_size * sizeof(table[0]));
332
+ table_size <<= 1;
333
+ }
334
+ return goal_size;
335
+ }
336
+
337
+ #if defined(__cplusplus) || defined(c_plusplus)
338
+ } /* extern "C" */
339
+ #endif
@@ -0,0 +1,121 @@
1
+ /* Copyright 2013 Google Inc. All Rights Reserved.
2
+
3
+ Distributed under MIT license.
4
+ See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
5
+ */
6
+
7
+ /* Utilities for building Huffman decoding tables. */
8
+
9
+ #ifndef BROTLI_DEC_HUFFMAN_H_
10
+ #define BROTLI_DEC_HUFFMAN_H_
11
+
12
+ #include "../common/platform.h"
13
+ #include <brotli/types.h>
14
+
15
+ #if defined(__cplusplus) || defined(c_plusplus)
16
+ extern "C" {
17
+ #endif
18
+
19
+ #define BROTLI_HUFFMAN_MAX_CODE_LENGTH 15
20
+
21
+ /* BROTLI_NUM_BLOCK_LEN_SYMBOLS == 26 */
22
+ #define BROTLI_HUFFMAN_MAX_SIZE_26 396
23
+ /* BROTLI_MAX_BLOCK_TYPE_SYMBOLS == 258 */
24
+ #define BROTLI_HUFFMAN_MAX_SIZE_258 632
25
+ /* BROTLI_MAX_CONTEXT_MAP_SYMBOLS == 272 */
26
+ #define BROTLI_HUFFMAN_MAX_SIZE_272 646
27
+
28
+ #define BROTLI_HUFFMAN_MAX_CODE_LENGTH_CODE_LENGTH 5
29
+
30
+ #if ((defined(BROTLI_TARGET_ARMV7) || defined(BROTLI_TARGET_ARMV8_32)) && \
31
+ BROTLI_GNUC_HAS_ATTRIBUTE(aligned, 2, 7, 0))
32
+ #define BROTLI_HUFFMAN_CODE_FAST_LOAD
33
+ #endif
34
+
35
+ #if !defined(BROTLI_HUFFMAN_CODE_FAST_LOAD)
36
+ /* Do not create this struct directly - use the ConstructHuffmanCode
37
+ * constructor below! */
38
+ typedef struct {
39
+ uint8_t bits; /* number of bits used for this symbol */
40
+ uint16_t value; /* symbol value or table offset */
41
+ } HuffmanCode;
42
+
43
+ static BROTLI_INLINE HuffmanCode ConstructHuffmanCode(const uint8_t bits,
44
+ const uint16_t value) {
45
+ HuffmanCode h;
46
+ h.bits = bits;
47
+ h.value = value;
48
+ return h;
49
+ }
50
+
51
+ /* Please use the following macros to optimize HuffmanCode accesses in hot
52
+ * paths.
53
+ *
54
+ * For example, assuming |table| contains a HuffmanCode pointer:
55
+ *
56
+ * BROTLI_HC_MARK_TABLE_FOR_FAST_LOAD(table);
57
+ * BROTLI_HC_ADJUST_TABLE_INDEX(table, index_into_table);
58
+ * *bits = BROTLI_HC_GET_BITS(table);
59
+ * *value = BROTLI_HC_GET_VALUE(table);
60
+ * BROTLI_HC_ADJUST_TABLE_INDEX(table, offset);
61
+ * *bits2 = BROTLI_HC_GET_BITS(table);
62
+ * *value2 = BROTLI_HC_GET_VALUE(table);
63
+ *
64
+ */
65
+
66
+ #define BROTLI_HC_MARK_TABLE_FOR_FAST_LOAD(H)
67
+ #define BROTLI_HC_ADJUST_TABLE_INDEX(H, V) H += (V)
68
+
69
+ /* These must be given a HuffmanCode pointer! */
70
+ #define BROTLI_HC_FAST_LOAD_BITS(H) (H->bits)
71
+ #define BROTLI_HC_FAST_LOAD_VALUE(H) (H->value)
72
+
73
+ #else /* BROTLI_HUFFMAN_CODE_FAST_LOAD */
74
+
75
+ typedef BROTLI_ALIGNED(4) uint32_t HuffmanCode;
76
+
77
+ static BROTLI_INLINE HuffmanCode ConstructHuffmanCode(const uint8_t bits,
78
+ const uint16_t value) {
79
+ return (HuffmanCode) ((value & 0xFFFF) << 16) | (bits & 0xFF);
80
+ }
81
+
82
+ #define BROTLI_HC_MARK_TABLE_FOR_FAST_LOAD(H) uint32_t __fastload_##H = (*H)
83
+ #define BROTLI_HC_ADJUST_TABLE_INDEX(H, V) H += (V); __fastload_##H = (*H)
84
+
85
+ /* These must be given a HuffmanCode pointer! */
86
+ #define BROTLI_HC_FAST_LOAD_BITS(H) ((__fastload_##H) & 0xFF)
87
+ #define BROTLI_HC_FAST_LOAD_VALUE(H) ((__fastload_##H) >> 16)
88
+ #endif /* BROTLI_HUFFMAN_CODE_FAST_LOAD */
89
+
90
+ /* Builds Huffman lookup table assuming code lengths are in symbol order. */
91
+ BROTLI_INTERNAL void BrotliBuildCodeLengthsHuffmanTable(HuffmanCode* root_table,
92
+ const uint8_t* const code_lengths, uint16_t* count);
93
+
94
+ /* Builds Huffman lookup table assuming code lengths are in symbol order.
95
+ Returns size of resulting table. */
96
+ BROTLI_INTERNAL uint32_t BrotliBuildHuffmanTable(HuffmanCode* root_table,
97
+ int root_bits, const uint16_t* const symbol_lists, uint16_t* count);
98
+
99
+ /* Builds a simple Huffman table. The |num_symbols| parameter is to be
100
+ interpreted as follows: 0 means 1 symbol, 1 means 2 symbols,
101
+ 2 means 3 symbols, 3 means 4 symbols with lengths [2, 2, 2, 2],
102
+ 4 means 4 symbols with lengths [1, 2, 3, 3]. */
103
+ BROTLI_INTERNAL uint32_t BrotliBuildSimpleHuffmanTable(HuffmanCode* table,
104
+ int root_bits, uint16_t* symbols, uint32_t num_symbols);
105
+
106
+ /* Contains a collection of Huffman trees with the same alphabet size. */
107
+ /* alphabet_size_limit is needed due to simple codes, since
108
+ log2(alphabet_size_max) could be greater than log2(alphabet_size_limit). */
109
+ typedef struct {
110
+ HuffmanCode** htrees;
111
+ HuffmanCode* codes;
112
+ uint16_t alphabet_size_max;
113
+ uint16_t alphabet_size_limit;
114
+ uint16_t num_htrees;
115
+ } HuffmanTreeGroup;
116
+
117
+ #if defined(__cplusplus) || defined(c_plusplus)
118
+ } /* extern "C" */
119
+ #endif
120
+
121
+ #endif /* BROTLI_DEC_HUFFMAN_H_ */