@shd101wyy/yo 0.0.2

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 (339) hide show
  1. package/LICENSE.md +17 -0
  2. package/README.md +80 -0
  3. package/out/cjs/index.cjs +51 -0
  4. package/out/cjs/yo-cli.cjs +2158 -0
  5. package/out/esm/index.mjs +51 -0
  6. package/out/types/src/codegen/async/runtime.d.ts +2 -0
  7. package/out/types/src/codegen/async/state-code-gen.d.ts +10 -0
  8. package/out/types/src/codegen/async/state-machine.d.ts +13 -0
  9. package/out/types/src/codegen/c/collection.d.ts +3 -0
  10. package/out/types/src/codegen/codegen-c.d.ts +12 -0
  11. package/out/types/src/codegen/constants.d.ts +3 -0
  12. package/out/types/src/codegen/expressions/array.d.ts +4 -0
  13. package/out/types/src/codegen/expressions/generation.d.ts +11 -0
  14. package/out/types/src/codegen/expressions/index.d.ts +2 -0
  15. package/out/types/src/codegen/functions/collection.d.ts +5 -0
  16. package/out/types/src/codegen/functions/context.d.ts +57 -0
  17. package/out/types/src/codegen/functions/generation.d.ts +25 -0
  18. package/out/types/src/codegen/functions/index.d.ts +2 -0
  19. package/out/types/src/codegen/index.d.ts +20 -0
  20. package/out/types/src/codegen/parallelism/runtime.d.ts +2 -0
  21. package/out/types/src/codegen/types/collection.d.ts +8 -0
  22. package/out/types/src/codegen/types/generation.d.ts +13 -0
  23. package/out/types/src/codegen/types/index.d.ts +2 -0
  24. package/out/types/src/codegen/utils/fixup.d.ts +2 -0
  25. package/out/types/src/codegen/utils/index.d.ts +77 -0
  26. package/out/types/src/codegen/values/index.d.ts +1 -0
  27. package/out/types/src/emitter.d.ts +11 -0
  28. package/out/types/src/env.d.ts +85 -0
  29. package/out/types/src/error.d.ts +45 -0
  30. package/out/types/src/evaluator/async/await-analysis-types.d.ts +23 -0
  31. package/out/types/src/evaluator/async/await-analysis.d.ts +5 -0
  32. package/out/types/src/evaluator/builtins/alignof.d.ts +8 -0
  33. package/out/types/src/evaluator/builtins/and_or.d.ts +8 -0
  34. package/out/types/src/evaluator/builtins/arc_fns.d.ts +58 -0
  35. package/out/types/src/evaluator/builtins/array_fns.d.ts +0 -0
  36. package/out/types/src/evaluator/builtins/as.d.ts +8 -0
  37. package/out/types/src/evaluator/builtins/async_fns.d.ts +8 -0
  38. package/out/types/src/evaluator/builtins/compt_assert.d.ts +8 -0
  39. package/out/types/src/evaluator/builtins/compt_boolean_fns.d.ts +8 -0
  40. package/out/types/src/evaluator/builtins/compt_expect_error.d.ts +8 -0
  41. package/out/types/src/evaluator/builtins/compt_list_fns.d.ts +33 -0
  42. package/out/types/src/evaluator/builtins/compt_print.d.ts +8 -0
  43. package/out/types/src/evaluator/builtins/compt_string_fns.d.ts +8 -0
  44. package/out/types/src/evaluator/builtins/consume.d.ts +8 -0
  45. package/out/types/src/evaluator/builtins/drop.d.ts +8 -0
  46. package/out/types/src/evaluator/builtins/dup.d.ts +8 -0
  47. package/out/types/src/evaluator/builtins/expr_fns.d.ts +33 -0
  48. package/out/types/src/evaluator/builtins/future_fns.d.ts +8 -0
  49. package/out/types/src/evaluator/builtins/gc.d.ts +8 -0
  50. package/out/types/src/evaluator/builtins/gensym.d.ts +8 -0
  51. package/out/types/src/evaluator/builtins/impl_constraint.d.ts +8 -0
  52. package/out/types/src/evaluator/builtins/macro_expand.d.ts +8 -0
  53. package/out/types/src/evaluator/builtins/numeric_fns.d.ts +8 -0
  54. package/out/types/src/evaluator/builtins/panic.d.ts +8 -0
  55. package/out/types/src/evaluator/builtins/ptr_fns.d.ts +8 -0
  56. package/out/types/src/evaluator/builtins/quote.d.ts +13 -0
  57. package/out/types/src/evaluator/builtins/rc.d.ts +8 -0
  58. package/out/types/src/evaluator/builtins/sizeof.d.ts +8 -0
  59. package/out/types/src/evaluator/builtins/the.d.ts +8 -0
  60. package/out/types/src/evaluator/builtins/type_fns.d.ts +28 -0
  61. package/out/types/src/evaluator/builtins/va_start.d.ts +8 -0
  62. package/out/types/src/evaluator/builtins/var_fns.d.ts +18 -0
  63. package/out/types/src/evaluator/calls/array.d.ts +13 -0
  64. package/out/types/src/evaluator/calls/array_type.d.ts +11 -0
  65. package/out/types/src/evaluator/calls/closure_type.d.ts +11 -0
  66. package/out/types/src/evaluator/calls/compt_function.d.ts +19 -0
  67. package/out/types/src/evaluator/calls/compt_list_type.d.ts +11 -0
  68. package/out/types/src/evaluator/calls/function.d.ts +16 -0
  69. package/out/types/src/evaluator/calls/function_type.d.ts +15 -0
  70. package/out/types/src/evaluator/calls/helper.d.ts +42 -0
  71. package/out/types/src/evaluator/calls/iso.d.ts +15 -0
  72. package/out/types/src/evaluator/calls/module_type.d.ts +11 -0
  73. package/out/types/src/evaluator/calls/numeric_type.d.ts +15 -0
  74. package/out/types/src/evaluator/calls/pointer.d.ts +8 -0
  75. package/out/types/src/evaluator/calls/pointer_type.d.ts +14 -0
  76. package/out/types/src/evaluator/calls/type.d.ts +12 -0
  77. package/out/types/src/evaluator/context.d.ts +169 -0
  78. package/out/types/src/evaluator/exprs/_expr.d.ts +8 -0
  79. package/out/types/src/evaluator/exprs/assignment.d.ts +9 -0
  80. package/out/types/src/evaluator/exprs/begin.d.ts +10 -0
  81. package/out/types/src/evaluator/exprs/binding.d.ts +12 -0
  82. package/out/types/src/evaluator/exprs/c_include.d.ts +8 -0
  83. package/out/types/src/evaluator/exprs/cond.d.ts +8 -0
  84. package/out/types/src/evaluator/exprs/destructuring_assignment.d.ts +33 -0
  85. package/out/types/src/evaluator/exprs/exists.d.ts +0 -0
  86. package/out/types/src/evaluator/exprs/expr.d.ts +9 -0
  87. package/out/types/src/evaluator/exprs/extern.d.ts +8 -0
  88. package/out/types/src/evaluator/exprs/identifer_and_operator.d.ts +9 -0
  89. package/out/types/src/evaluator/exprs/import.d.ts +9 -0
  90. package/out/types/src/evaluator/exprs/initialization_assignment.d.ts +8 -0
  91. package/out/types/src/evaluator/exprs/match.d.ts +8 -0
  92. package/out/types/src/evaluator/exprs/open.d.ts +8 -0
  93. package/out/types/src/evaluator/exprs/property_access.d.ts +8 -0
  94. package/out/types/src/evaluator/exprs/recur.d.ts +8 -0
  95. package/out/types/src/evaluator/exprs/subtype_of.d.ts +21 -0
  96. package/out/types/src/evaluator/exprs/test.d.ts +8 -0
  97. package/out/types/src/evaluator/exprs/typeof.d.ts +8 -0
  98. package/out/types/src/evaluator/exprs/while.d.ts +8 -0
  99. package/out/types/src/evaluator/index.d.ts +26 -0
  100. package/out/types/src/evaluator/types/array.d.ts +8 -0
  101. package/out/types/src/evaluator/types/closure.d.ts +8 -0
  102. package/out/types/src/evaluator/types/compt_list.d.ts +8 -0
  103. package/out/types/src/evaluator/types/concrete_module.d.ts +8 -0
  104. package/out/types/src/evaluator/types/dyn.d.ts +8 -0
  105. package/out/types/src/evaluator/types/enum.d.ts +8 -0
  106. package/out/types/src/evaluator/types/expr_synthesizer.d.ts +14 -0
  107. package/out/types/src/evaluator/types/field.d.ts +14 -0
  108. package/out/types/src/evaluator/types/fn_module.d.ts +8 -0
  109. package/out/types/src/evaluator/types/function.d.ts +58 -0
  110. package/out/types/src/evaluator/types/future_module.d.ts +8 -0
  111. package/out/types/src/evaluator/types/module.d.ts +19 -0
  112. package/out/types/src/evaluator/types/newtype.d.ts +8 -0
  113. package/out/types/src/evaluator/types/object.d.ts +8 -0
  114. package/out/types/src/evaluator/types/proofs.d.ts +0 -0
  115. package/out/types/src/evaluator/types/slice.d.ts +8 -0
  116. package/out/types/src/evaluator/types/struct.d.ts +8 -0
  117. package/out/types/src/evaluator/types/synthesizer.d.ts +16 -0
  118. package/out/types/src/evaluator/types/tuple.d.ts +18 -0
  119. package/out/types/src/evaluator/types/union.d.ts +8 -0
  120. package/out/types/src/evaluator/types/utils.d.ts +71 -0
  121. package/out/types/src/evaluator/types/validation.d.ts +3 -0
  122. package/out/types/src/evaluator/utils/array-utils.d.ts +15 -0
  123. package/out/types/src/evaluator/utils/closure.d.ts +35 -0
  124. package/out/types/src/evaluator/utils.d.ts +4 -0
  125. package/out/types/src/evaluator/values/anonymous_function.d.ts +8 -0
  126. package/out/types/src/evaluator/values/anonymous_module.d.ts +17 -0
  127. package/out/types/src/evaluator/values/anonymous_struct.d.ts +8 -0
  128. package/out/types/src/evaluator/values/array.d.ts +8 -0
  129. package/out/types/src/evaluator/values/boolean.d.ts +3 -0
  130. package/out/types/src/evaluator/values/char.d.ts +3 -0
  131. package/out/types/src/evaluator/values/compt_list.d.ts +8 -0
  132. package/out/types/src/evaluator/values/dyn.d.ts +8 -0
  133. package/out/types/src/evaluator/values/float.d.ts +4 -0
  134. package/out/types/src/evaluator/values/integer.d.ts +4 -0
  135. package/out/types/src/evaluator/values/module.d.ts +58 -0
  136. package/out/types/src/evaluator/values/string.d.ts +3 -0
  137. package/out/types/src/evaluator/values/tuple.d.ts +32 -0
  138. package/out/types/src/expr.d.ts +456 -0
  139. package/out/types/src/function-value.d.ts +42 -0
  140. package/out/types/src/index.d.ts +4 -0
  141. package/out/types/src/lexer.d.ts +2 -0
  142. package/out/types/src/logger.d.ts +1 -0
  143. package/out/types/src/module-manager.d.ts +30 -0
  144. package/out/types/src/naming-checker.d.ts +4 -0
  145. package/out/types/src/parser.d.ts +33 -0
  146. package/out/types/src/test-runner.d.ts +30 -0
  147. package/out/types/src/tests/codegen.test.d.ts +1 -0
  148. package/out/types/src/tests/fixme.test.d.ts +1 -0
  149. package/out/types/src/tests/module-manager.test.d.ts +1 -0
  150. package/out/types/src/tests/parser.test.d.ts +1 -0
  151. package/out/types/src/tests/sample.test.d.ts +0 -0
  152. package/out/types/src/tests/std.test.d.ts +1 -0
  153. package/out/types/src/token.d.ts +40 -0
  154. package/out/types/src/type-value.d.ts +7 -0
  155. package/out/types/src/types/compatibility.d.ts +16 -0
  156. package/out/types/src/types/creators.d.ts +73 -0
  157. package/out/types/src/types/definitions.d.ts +218 -0
  158. package/out/types/src/types/guards.d.ts +70 -0
  159. package/out/types/src/types/hierarchy.d.ts +4 -0
  160. package/out/types/src/types/index.d.ts +7 -0
  161. package/out/types/src/types/module_field.d.ts +2 -0
  162. package/out/types/src/types/tags.d.ts +45 -0
  163. package/out/types/src/types/utils.d.ts +50 -0
  164. package/out/types/src/unit-value.d.ts +7 -0
  165. package/out/types/src/utils.d.ts +6 -0
  166. package/out/types/src/value-tag.d.ts +29 -0
  167. package/out/types/src/value.d.ts +110 -0
  168. package/out/types/src/yo-cli.d.ts +1 -0
  169. package/out/types/tsconfig.tsbuildinfo +1 -0
  170. package/package.json +57 -0
  171. package/scripts/check-liburing.js +76 -0
  172. package/std/alg/hash.yo +50 -0
  173. package/std/allocator.yo +113 -0
  174. package/std/allocators/c_allocator.yo +118 -0
  175. package/std/async.yo +13 -0
  176. package/std/collections/array_list.yo +415 -0
  177. package/std/collections/hash_map.yo +482 -0
  178. package/std/collections/hash_set.yo +706 -0
  179. package/std/collections/index.yo +11 -0
  180. package/std/collections/linked_list.yo +439 -0
  181. package/std/error.yo +0 -0
  182. package/std/gc.yo +10 -0
  183. package/std/index.yo +12 -0
  184. package/std/io/file.yo +191 -0
  185. package/std/io/index.yo +5 -0
  186. package/std/libc/assert.yo +39 -0
  187. package/std/libc/ctype.yo +57 -0
  188. package/std/libc/errno.yo +182 -0
  189. package/std/libc/float.yo +87 -0
  190. package/std/libc/index.yo +29 -0
  191. package/std/libc/limits.yo +65 -0
  192. package/std/libc/math.yo +679 -0
  193. package/std/libc/signal.yo +101 -0
  194. package/std/libc/stdatomic.yo +213 -0
  195. package/std/libc/stdint.yo +214 -0
  196. package/std/libc/stdio.yo +225 -0
  197. package/std/libc/stdlib.yo +204 -0
  198. package/std/libc/string.yo +151 -0
  199. package/std/libc/time.yo +92 -0
  200. package/std/libc/unistd.yo +130 -0
  201. package/std/monad.yo +152 -0
  202. package/std/prelude.yo +3094 -0
  203. package/std/string/index.yo +8 -0
  204. package/std/string/rune.yo +82 -0
  205. package/std/string/string.yo +288 -0
  206. package/std/sync.yo +95 -0
  207. package/std/thread.yo +36 -0
  208. package/std/time.yo +13 -0
  209. package/std/worker.yo +36 -0
  210. package/vendor/mimalloc/.gitattributes +12 -0
  211. package/vendor/mimalloc/CMakeLists.txt +763 -0
  212. package/vendor/mimalloc/LICENSE +21 -0
  213. package/vendor/mimalloc/SECURITY.md +41 -0
  214. package/vendor/mimalloc/azure-pipelines.yml +251 -0
  215. package/vendor/mimalloc/bin/mimalloc-redirect-arm64.dll +0 -0
  216. package/vendor/mimalloc/bin/mimalloc-redirect-arm64.lib +0 -0
  217. package/vendor/mimalloc/bin/mimalloc-redirect-arm64ec.dll +0 -0
  218. package/vendor/mimalloc/bin/mimalloc-redirect-arm64ec.lib +0 -0
  219. package/vendor/mimalloc/bin/mimalloc-redirect.dll +0 -0
  220. package/vendor/mimalloc/bin/mimalloc-redirect.lib +0 -0
  221. package/vendor/mimalloc/bin/mimalloc-redirect32.dll +0 -0
  222. package/vendor/mimalloc/bin/mimalloc-redirect32.lib +0 -0
  223. package/vendor/mimalloc/bin/minject-arm64.exe +0 -0
  224. package/vendor/mimalloc/bin/minject.exe +0 -0
  225. package/vendor/mimalloc/bin/minject32.exe +0 -0
  226. package/vendor/mimalloc/bin/readme.md +118 -0
  227. package/vendor/mimalloc/cmake/JoinPaths.cmake +23 -0
  228. package/vendor/mimalloc/cmake/mimalloc-config-version.cmake +19 -0
  229. package/vendor/mimalloc/cmake/mimalloc-config.cmake +14 -0
  230. package/vendor/mimalloc/contrib/docker/alpine/Dockerfile +23 -0
  231. package/vendor/mimalloc/contrib/docker/alpine-arm32v7/Dockerfile +28 -0
  232. package/vendor/mimalloc/contrib/docker/alpine-x86/Dockerfile +28 -0
  233. package/vendor/mimalloc/contrib/docker/manylinux-x64/Dockerfile +23 -0
  234. package/vendor/mimalloc/contrib/docker/readme.md +10 -0
  235. package/vendor/mimalloc/contrib/vcpkg/portfile.cmake +64 -0
  236. package/vendor/mimalloc/contrib/vcpkg/readme.md +40 -0
  237. package/vendor/mimalloc/contrib/vcpkg/usage +20 -0
  238. package/vendor/mimalloc/contrib/vcpkg/vcpkg-cmake-wrapper.cmake +20 -0
  239. package/vendor/mimalloc/contrib/vcpkg/vcpkg.json +48 -0
  240. package/vendor/mimalloc/doc/bench-2020/bench-c5-18xlarge-2020-01-20-a.svg +887 -0
  241. package/vendor/mimalloc/doc/bench-2020/bench-c5-18xlarge-2020-01-20-b.svg +1185 -0
  242. package/vendor/mimalloc/doc/bench-2020/bench-c5-18xlarge-2020-01-20-rss-a.svg +757 -0
  243. package/vendor/mimalloc/doc/bench-2020/bench-c5-18xlarge-2020-01-20-rss-b.svg +1028 -0
  244. package/vendor/mimalloc/doc/bench-2020/bench-r5a-1.svg +769 -0
  245. package/vendor/mimalloc/doc/bench-2020/bench-r5a-12xlarge-2020-01-16-a.svg +868 -0
  246. package/vendor/mimalloc/doc/bench-2020/bench-r5a-12xlarge-2020-01-16-b.svg +1157 -0
  247. package/vendor/mimalloc/doc/bench-2020/bench-r5a-2.svg +983 -0
  248. package/vendor/mimalloc/doc/bench-2020/bench-r5a-rss-1.svg +683 -0
  249. package/vendor/mimalloc/doc/bench-2020/bench-r5a-rss-2.svg +854 -0
  250. package/vendor/mimalloc/doc/bench-2020/bench-spec-rss.svg +713 -0
  251. package/vendor/mimalloc/doc/bench-2020/bench-spec.svg +713 -0
  252. package/vendor/mimalloc/doc/bench-2020/bench-z4-1.svg +890 -0
  253. package/vendor/mimalloc/doc/bench-2020/bench-z4-2.svg +1146 -0
  254. package/vendor/mimalloc/doc/bench-2020/bench-z4-rss-1.svg +796 -0
  255. package/vendor/mimalloc/doc/bench-2020/bench-z4-rss-2.svg +974 -0
  256. package/vendor/mimalloc/doc/bench-2021/bench-amd5950x-2021-01-30-a.svg +952 -0
  257. package/vendor/mimalloc/doc/bench-2021/bench-amd5950x-2021-01-30-b.svg +1255 -0
  258. package/vendor/mimalloc/doc/bench-2021/bench-c5-18xlarge-2021-01-30-a.svg +955 -0
  259. package/vendor/mimalloc/doc/bench-2021/bench-c5-18xlarge-2021-01-30-b.svg +1269 -0
  260. package/vendor/mimalloc/doc/bench-2021/bench-c5-18xlarge-2021-01-30-rss-a.svg +836 -0
  261. package/vendor/mimalloc/doc/bench-2021/bench-c5-18xlarge-2021-01-30-rss-b.svg +1131 -0
  262. package/vendor/mimalloc/doc/bench-2021/bench-macmini-2021-01-30.svg +766 -0
  263. package/vendor/mimalloc/doc/doxyfile +2895 -0
  264. package/vendor/mimalloc/doc/ds-logo.jpg +0 -0
  265. package/vendor/mimalloc/doc/ds-logo.png +0 -0
  266. package/vendor/mimalloc/doc/mimalloc-doc.h +1452 -0
  267. package/vendor/mimalloc/doc/mimalloc-doxygen.css +60 -0
  268. package/vendor/mimalloc/doc/mimalloc-logo-100.png +0 -0
  269. package/vendor/mimalloc/doc/mimalloc-logo.png +0 -0
  270. package/vendor/mimalloc/doc/mimalloc-logo.svg +161 -0
  271. package/vendor/mimalloc/doc/spades-logo.png +0 -0
  272. package/vendor/mimalloc/doc/unreal-logo.svg +43 -0
  273. package/vendor/mimalloc/ide/vs2022/mimalloc-lib.vcxproj +500 -0
  274. package/vendor/mimalloc/ide/vs2022/mimalloc-lib.vcxproj.filters +108 -0
  275. package/vendor/mimalloc/ide/vs2022/mimalloc-override-dll.vcxproj +508 -0
  276. package/vendor/mimalloc/ide/vs2022/mimalloc-override-dll.vcxproj.filters +111 -0
  277. package/vendor/mimalloc/ide/vs2022/mimalloc-override-test-dep.vcxproj +355 -0
  278. package/vendor/mimalloc/ide/vs2022/mimalloc-override-test.vcxproj +360 -0
  279. package/vendor/mimalloc/ide/vs2022/mimalloc-test-api.vcxproj +295 -0
  280. package/vendor/mimalloc/ide/vs2022/mimalloc-test-stress.vcxproj +292 -0
  281. package/vendor/mimalloc/ide/vs2022/mimalloc-test.vcxproj +289 -0
  282. package/vendor/mimalloc/ide/vs2022/mimalloc.sln +151 -0
  283. package/vendor/mimalloc/include/mimalloc/atomic.h +557 -0
  284. package/vendor/mimalloc/include/mimalloc/internal.h +1153 -0
  285. package/vendor/mimalloc/include/mimalloc/prim.h +421 -0
  286. package/vendor/mimalloc/include/mimalloc/track.h +145 -0
  287. package/vendor/mimalloc/include/mimalloc/types.h +685 -0
  288. package/vendor/mimalloc/include/mimalloc-new-delete.h +66 -0
  289. package/vendor/mimalloc/include/mimalloc-override.h +68 -0
  290. package/vendor/mimalloc/include/mimalloc-stats.h +103 -0
  291. package/vendor/mimalloc/include/mimalloc.h +612 -0
  292. package/vendor/mimalloc/mimalloc.pc.in +11 -0
  293. package/vendor/mimalloc/readme.md +946 -0
  294. package/vendor/mimalloc/src/alloc-aligned.c +360 -0
  295. package/vendor/mimalloc/src/alloc-override.c +316 -0
  296. package/vendor/mimalloc/src/alloc-posix.c +185 -0
  297. package/vendor/mimalloc/src/alloc.c +692 -0
  298. package/vendor/mimalloc/src/arena-abandon.c +346 -0
  299. package/vendor/mimalloc/src/arena.c +1043 -0
  300. package/vendor/mimalloc/src/bitmap.c +441 -0
  301. package/vendor/mimalloc/src/bitmap.h +119 -0
  302. package/vendor/mimalloc/src/free.c +572 -0
  303. package/vendor/mimalloc/src/heap.c +733 -0
  304. package/vendor/mimalloc/src/init.c +714 -0
  305. package/vendor/mimalloc/src/libc.c +334 -0
  306. package/vendor/mimalloc/src/options.c +663 -0
  307. package/vendor/mimalloc/src/os.c +770 -0
  308. package/vendor/mimalloc/src/page-queue.c +390 -0
  309. package/vendor/mimalloc/src/page.c +1049 -0
  310. package/vendor/mimalloc/src/prim/emscripten/prim.c +249 -0
  311. package/vendor/mimalloc/src/prim/osx/alloc-override-zone.c +461 -0
  312. package/vendor/mimalloc/src/prim/osx/prim.c +9 -0
  313. package/vendor/mimalloc/src/prim/prim.c +76 -0
  314. package/vendor/mimalloc/src/prim/readme.md +9 -0
  315. package/vendor/mimalloc/src/prim/unix/prim.c +934 -0
  316. package/vendor/mimalloc/src/prim/wasi/prim.c +284 -0
  317. package/vendor/mimalloc/src/prim/windows/etw-mimalloc.wprp +61 -0
  318. package/vendor/mimalloc/src/prim/windows/etw.h +905 -0
  319. package/vendor/mimalloc/src/prim/windows/etw.man +0 -0
  320. package/vendor/mimalloc/src/prim/windows/prim.c +878 -0
  321. package/vendor/mimalloc/src/prim/windows/readme.md +17 -0
  322. package/vendor/mimalloc/src/random.c +258 -0
  323. package/vendor/mimalloc/src/segment-map.c +142 -0
  324. package/vendor/mimalloc/src/segment.c +1702 -0
  325. package/vendor/mimalloc/src/static.c +41 -0
  326. package/vendor/mimalloc/src/stats.c +635 -0
  327. package/vendor/mimalloc/test/CMakeLists.txt +56 -0
  328. package/vendor/mimalloc/test/main-override-dep.cpp +51 -0
  329. package/vendor/mimalloc/test/main-override-dep.h +11 -0
  330. package/vendor/mimalloc/test/main-override-static.c +539 -0
  331. package/vendor/mimalloc/test/main-override.c +36 -0
  332. package/vendor/mimalloc/test/main-override.cpp +497 -0
  333. package/vendor/mimalloc/test/main.c +46 -0
  334. package/vendor/mimalloc/test/readme.md +16 -0
  335. package/vendor/mimalloc/test/test-api-fill.c +343 -0
  336. package/vendor/mimalloc/test/test-api.c +466 -0
  337. package/vendor/mimalloc/test/test-stress.c +428 -0
  338. package/vendor/mimalloc/test/test-wrong.c +92 -0
  339. package/vendor/mimalloc/test/testhelper.h +49 -0
@@ -0,0 +1,466 @@
1
+ /* ----------------------------------------------------------------------------
2
+ Copyright (c) 2018-2020, Microsoft Research, Daan Leijen
3
+ This is free software; you can redistribute it and/or modify it under the
4
+ terms of the MIT license. A copy of the license can be found in the file
5
+ "LICENSE" at the root of this distribution.
6
+ -----------------------------------------------------------------------------*/
7
+ #if defined(__GNUC__) && !defined(__clang__)
8
+ #pragma GCC diagnostic ignored "-Walloc-size-larger-than="
9
+ #endif
10
+
11
+ /*
12
+ Testing allocators is difficult as bugs may only surface after particular
13
+ allocation patterns. The main approach to testing _mimalloc_ is therefore
14
+ to have extensive internal invariant checking (see `page_is_valid` in `page.c`
15
+ for example), which is enabled in debug mode with `-DMI_DEBUG_FULL=ON`.
16
+ The main testing is then to run `mimalloc-bench` [1] using full invariant checking
17
+ to catch any potential problems over a wide range of intensive allocation bench
18
+ marks.
19
+
20
+ However, this does not test well for the entire API surface. In this test file
21
+ we therefore test the API over various inputs. Please add more tests :-)
22
+
23
+ [1] https://github.com/daanx/mimalloc-bench
24
+ */
25
+
26
+ #include <assert.h>
27
+ #include <stdbool.h>
28
+ #include <stdint.h>
29
+ #include <errno.h>
30
+
31
+ #ifdef __cplusplus
32
+ #include <vector>
33
+ #endif
34
+
35
+ #include "mimalloc.h"
36
+ // #include "mimalloc/internal.h"
37
+ #include "mimalloc/types.h" // for MI_DEBUG and MI_BLOCK_ALIGNMENT_MAX
38
+
39
+ #include "testhelper.h"
40
+
41
+ // ---------------------------------------------------------------------------
42
+ // Test functions
43
+ // ---------------------------------------------------------------------------
44
+ bool test_heap1(void);
45
+ bool test_heap2(void);
46
+ bool test_stl_allocator1(void);
47
+ bool test_stl_allocator2(void);
48
+
49
+ bool test_stl_heap_allocator1(void);
50
+ bool test_stl_heap_allocator2(void);
51
+ bool test_stl_heap_allocator3(void);
52
+ bool test_stl_heap_allocator4(void);
53
+
54
+ bool mem_is_zero(uint8_t* p, size_t size) {
55
+ if (p==NULL) return false;
56
+ for (size_t i = 0; i < size; ++i) {
57
+ if (p[i] != 0) return false;
58
+ }
59
+ return true;
60
+ }
61
+
62
+ // ---------------------------------------------------------------------------
63
+ // Main testing
64
+ // ---------------------------------------------------------------------------
65
+ int main(void) {
66
+ mi_option_disable(mi_option_verbose);
67
+
68
+ CHECK_BODY("malloc-aligned9a") { // test large alignments
69
+ void* p = mi_zalloc_aligned(1024 * 1024, 2);
70
+ mi_free(p);
71
+ p = mi_zalloc_aligned(1024 * 1024, 2);
72
+ mi_free(p);
73
+ result = true;
74
+ };
75
+
76
+
77
+ // ---------------------------------------------------
78
+ // Malloc
79
+ // ---------------------------------------------------
80
+
81
+ CHECK_BODY("malloc-zero") {
82
+ void* p = mi_malloc(0);
83
+ result = (p != NULL);
84
+ mi_free(p);
85
+ };
86
+ CHECK_BODY("malloc-nomem1") {
87
+ result = (mi_malloc((size_t)PTRDIFF_MAX + (size_t)1) == NULL);
88
+ };
89
+ CHECK_BODY("malloc-null") {
90
+ mi_free(NULL);
91
+ };
92
+ CHECK_BODY("calloc-overflow") {
93
+ // use (size_t)&mi_calloc to get some number without triggering compiler warnings
94
+ result = (mi_calloc((size_t)&mi_calloc,SIZE_MAX/1000) == NULL);
95
+ };
96
+ CHECK_BODY("calloc0") {
97
+ void* p = mi_calloc(0,1000);
98
+ result = (mi_usable_size(p) <= 16);
99
+ mi_free(p);
100
+ };
101
+ CHECK_BODY("malloc-large") { // see PR #544.
102
+ void* p = mi_malloc(67108872);
103
+ mi_free(p);
104
+ };
105
+
106
+ // ---------------------------------------------------
107
+ // Extended
108
+ // ---------------------------------------------------
109
+ CHECK_BODY("posix_memalign1") {
110
+ void* p = &p;
111
+ int err = mi_posix_memalign(&p, sizeof(void*), 32);
112
+ result = ((err==0 && (uintptr_t)p % sizeof(void*) == 0) || p==&p);
113
+ mi_free(p);
114
+ };
115
+ CHECK_BODY("posix_memalign_no_align") {
116
+ void* p = &p;
117
+ int err = mi_posix_memalign(&p, 3, 32);
118
+ result = (err==EINVAL && p==&p);
119
+ };
120
+ CHECK_BODY("posix_memalign_zero") {
121
+ void* p = &p;
122
+ int err = mi_posix_memalign(&p, sizeof(void*), 0);
123
+ mi_free(p);
124
+ result = (err==0);
125
+ };
126
+ CHECK_BODY("posix_memalign_nopow2") {
127
+ void* p = &p;
128
+ int err = mi_posix_memalign(&p, 3*sizeof(void*), 32);
129
+ result = (err==EINVAL && p==&p);
130
+ };
131
+ CHECK_BODY("posix_memalign_nomem") {
132
+ void* p = &p;
133
+ int err = mi_posix_memalign(&p, sizeof(void*), SIZE_MAX);
134
+ result = (err==ENOMEM && p==&p);
135
+ };
136
+
137
+ // ---------------------------------------------------
138
+ // Aligned API
139
+ // ---------------------------------------------------
140
+ CHECK_BODY("malloc-aligned1") {
141
+ void* p = mi_malloc_aligned(32,32); result = (p != NULL && (uintptr_t)(p) % 32 == 0); mi_free(p);
142
+ };
143
+ CHECK_BODY("malloc-aligned2") {
144
+ void* p = mi_malloc_aligned(48,32); result = (p != NULL && (uintptr_t)(p) % 32 == 0); mi_free(p);
145
+ };
146
+ CHECK_BODY("malloc-aligned3") {
147
+ void* p1 = mi_malloc_aligned(48,32); bool result1 = (p1 != NULL && (uintptr_t)(p1) % 32 == 0);
148
+ void* p2 = mi_malloc_aligned(48,32); bool result2 = (p2 != NULL && (uintptr_t)(p2) % 32 == 0);
149
+ mi_free(p2);
150
+ mi_free(p1);
151
+ result = (result1&&result2);
152
+ };
153
+ CHECK_BODY("malloc-aligned4") {
154
+ void* p;
155
+ bool ok = true;
156
+ for (int i = 0; i < 8 && ok; i++) {
157
+ p = mi_malloc_aligned(8, 16);
158
+ ok = (p != NULL && (uintptr_t)(p) % 16 == 0); mi_free(p);
159
+ }
160
+ result = ok;
161
+ };
162
+ CHECK_BODY("malloc-aligned5") {
163
+ void* p = mi_malloc_aligned(4097,4096);
164
+ size_t usable = mi_usable_size(p);
165
+ result = (usable >= 4097 && usable < 16000);
166
+ printf("malloc_aligned5: usable size: %zi\n", usable);
167
+ mi_free(p);
168
+ };
169
+ /*
170
+ CHECK_BODY("malloc-aligned6") {
171
+ bool ok = true;
172
+ for (size_t align = 1; align <= MI_BLOCK_ALIGNMENT_MAX && ok; align *= 2) {
173
+ void* ps[8];
174
+ for (int i = 0; i < 8 && ok; i++) {
175
+ ps[i] = mi_malloc_aligned(align*13 // size
176
+ , align);
177
+ if (ps[i] == NULL || (uintptr_t)(ps[i]) % align != 0) {
178
+ ok = false;
179
+ }
180
+ }
181
+ for (int i = 0; i < 8 && ok; i++) {
182
+ mi_free(ps[i]);
183
+ }
184
+ }
185
+ result = ok;
186
+ };
187
+ */
188
+ CHECK_BODY("malloc-aligned7") {
189
+ void* p = mi_malloc_aligned(1024,MI_BLOCK_ALIGNMENT_MAX);
190
+ mi_free(p);
191
+ result = ((uintptr_t)p % MI_BLOCK_ALIGNMENT_MAX) == 0;
192
+ };
193
+ CHECK_BODY("malloc-aligned8") {
194
+ bool ok = true;
195
+ for (int i = 0; i < 5 && ok; i++) {
196
+ int n = (1 << i);
197
+ void* p = mi_malloc_aligned(1024, n * MI_BLOCK_ALIGNMENT_MAX);
198
+ ok = ((uintptr_t)p % (n*MI_BLOCK_ALIGNMENT_MAX)) == 0;
199
+ mi_free(p);
200
+ }
201
+ result = ok;
202
+ };
203
+ CHECK_BODY("malloc-aligned9") { // test large alignments
204
+ bool ok = true;
205
+ void* p[8];
206
+ size_t sizes[8] = { 8, 512, 1024 * 1024, MI_BLOCK_ALIGNMENT_MAX, MI_BLOCK_ALIGNMENT_MAX + 1,
207
+ #if SIZE_MAX > UINT32_MAX
208
+ 2 * MI_BLOCK_ALIGNMENT_MAX, 8 * MI_BLOCK_ALIGNMENT_MAX,
209
+ #endif
210
+ 0 };
211
+ for (int i = 0; i < 28 && ok; i++) {
212
+ int align = (1 << i);
213
+ for (int j = 0; j < 8 && ok; j++) {
214
+ p[j] = mi_zalloc_aligned(sizes[j], align);
215
+ ok = ((uintptr_t)p[j] % align) == 0;
216
+ }
217
+ for (int j = 0; j < 8; j++) {
218
+ mi_free(p[j]);
219
+ }
220
+ }
221
+ result = ok;
222
+ };
223
+ CHECK_BODY("malloc-aligned10") {
224
+ bool ok = true;
225
+ void* p[10+1];
226
+ int align;
227
+ int j;
228
+ for(j = 0, align = 1; j <= 10 && ok; align *= 2, j++ ) {
229
+ p[j] = mi_malloc_aligned(43 + align, align);
230
+ ok = ((uintptr_t)p[j] % align) == 0;
231
+ }
232
+ for ( ; j > 0; j--) {
233
+ mi_free(p[j-1]);
234
+ }
235
+ result = ok;
236
+ }
237
+ CHECK_BODY("malloc_aligned11") {
238
+ mi_heap_t* heap = mi_heap_new();
239
+ void* p = mi_heap_malloc_aligned(heap, 33554426, 8);
240
+ result = mi_heap_contains_block(heap, p);
241
+ mi_heap_destroy(heap);
242
+ }
243
+ CHECK_BODY("mimalloc-aligned12") {
244
+ void* p = mi_malloc_aligned(0x100, 0x100);
245
+ result = (((uintptr_t)p % 0x100) == 0); // #602
246
+ mi_free(p);
247
+ }
248
+ CHECK_BODY("mimalloc-aligned13") {
249
+ bool ok = true;
250
+ for( size_t size = 1; size <= (MI_SMALL_SIZE_MAX * 2) && ok; size++ ) {
251
+ for(size_t align = 1; align <= size && ok; align *= 2 ) {
252
+ void* p[10];
253
+ for(int i = 0; i < 10 && ok; i++) {
254
+ p[i] = mi_malloc_aligned(size,align);;
255
+ ok = (p[i] != NULL && ((uintptr_t)(p[i]) % align) == 0);
256
+ }
257
+ for(int i = 0; i < 10 && ok; i++) {
258
+ mi_free(p[i]);
259
+ }
260
+ /*
261
+ if (ok && align <= size && ((size + MI_PADDING_SIZE) & (align-1)) == 0) {
262
+ size_t bsize = mi_good_size(size);
263
+ ok = (align <= bsize && (bsize & (align-1)) == 0);
264
+ }
265
+ */
266
+ }
267
+ }
268
+ result = ok;
269
+ }
270
+ CHECK_BODY("malloc-aligned-at1") {
271
+ void* p = mi_malloc_aligned_at(48,32,0); result = (p != NULL && ((uintptr_t)(p) + 0) % 32 == 0); mi_free(p);
272
+ };
273
+ CHECK_BODY("malloc-aligned-at2") {
274
+ void* p = mi_malloc_aligned_at(50,32,8); result = (p != NULL && ((uintptr_t)(p) + 8) % 32 == 0); mi_free(p);
275
+ };
276
+ CHECK_BODY("memalign1") {
277
+ void* p;
278
+ bool ok = true;
279
+ for (int i = 0; i < 8 && ok; i++) {
280
+ p = mi_memalign(16,8);
281
+ ok = (p != NULL && (uintptr_t)(p) % 16 == 0); mi_free(p);
282
+ }
283
+ result = ok;
284
+ };
285
+ CHECK_BODY("zalloc-aligned-small1") {
286
+ size_t zalloc_size = MI_SMALL_SIZE_MAX / 2;
287
+ uint8_t* p = (uint8_t*)mi_zalloc_aligned(zalloc_size, MI_MAX_ALIGN_SIZE * 2);
288
+ result = mem_is_zero(p, zalloc_size);
289
+ mi_free(p);
290
+ };
291
+ CHECK_BODY("rezalloc_aligned-small1") {
292
+ size_t zalloc_size = MI_SMALL_SIZE_MAX / 2;
293
+ uint8_t* p = (uint8_t*)mi_zalloc_aligned(zalloc_size, MI_MAX_ALIGN_SIZE * 2);
294
+ result = mem_is_zero(p, zalloc_size);
295
+ zalloc_size *= 3;
296
+ p = (uint8_t*)mi_rezalloc_aligned(p, zalloc_size, MI_MAX_ALIGN_SIZE * 2);
297
+ result = result && mem_is_zero(p, zalloc_size);
298
+ mi_free(p);
299
+ };
300
+
301
+ // ---------------------------------------------------
302
+ // Reallocation
303
+ // ---------------------------------------------------
304
+ CHECK_BODY("realloc-null") {
305
+ void* p = mi_realloc(NULL,4);
306
+ result = (p != NULL);
307
+ mi_free(p);
308
+ };
309
+
310
+ CHECK_BODY("realloc-null-sizezero") {
311
+ void* p = mi_realloc(NULL,0); // <https://en.cppreference.com/w/c/memory/realloc> "If ptr is NULL, the behavior is the same as calling malloc(new_size)."
312
+ result = (p != NULL);
313
+ mi_free(p);
314
+ };
315
+
316
+ CHECK_BODY("realloc-sizezero") {
317
+ void* p = mi_malloc(4);
318
+ void* q = mi_realloc(p, 0);
319
+ result = (q != NULL);
320
+ mi_free(q);
321
+ };
322
+
323
+ CHECK_BODY("reallocarray-null-sizezero") {
324
+ void* p = mi_reallocarray(NULL,0,16); // issue #574
325
+ result = (p != NULL && errno == 0);
326
+ mi_free(p);
327
+ };
328
+
329
+ // ---------------------------------------------------
330
+ // Heaps
331
+ // ---------------------------------------------------
332
+ CHECK("heap_destroy", test_heap1());
333
+ CHECK("heap_delete", test_heap2());
334
+
335
+ //mi_stats_print(NULL);
336
+
337
+ // ---------------------------------------------------
338
+ // various
339
+ // ---------------------------------------------------
340
+ #if !defined(MI_TRACK_ASAN) // realpath may leak with ASAN enabled (as the ASAN allocator intercepts it)
341
+ CHECK_BODY("realpath") {
342
+ char* s = mi_realpath( ".", NULL );
343
+ // printf("realpath: %s\n",s);
344
+ mi_free(s);
345
+ };
346
+ #endif
347
+
348
+ CHECK("stl_allocator1", test_stl_allocator1());
349
+ CHECK("stl_allocator2", test_stl_allocator2());
350
+
351
+ CHECK("stl_heap_allocator1", test_stl_heap_allocator1());
352
+ CHECK("stl_heap_allocator2", test_stl_heap_allocator2());
353
+ CHECK("stl_heap_allocator3", test_stl_heap_allocator3());
354
+ CHECK("stl_heap_allocator4", test_stl_heap_allocator4());
355
+
356
+ // ---------------------------------------------------
357
+ // Done
358
+ // ---------------------------------------------------[]
359
+ return print_test_summary();
360
+ }
361
+
362
+ // ---------------------------------------------------
363
+ // Larger test functions
364
+ // ---------------------------------------------------
365
+
366
+ bool test_heap1(void) {
367
+ mi_heap_t* heap = mi_heap_new();
368
+ int* p1 = mi_heap_malloc_tp(heap,int);
369
+ int* p2 = mi_heap_malloc_tp(heap,int);
370
+ *p1 = *p2 = 43;
371
+ mi_heap_destroy(heap);
372
+ return true;
373
+ }
374
+
375
+ bool test_heap2(void) {
376
+ mi_heap_t* heap = mi_heap_new();
377
+ int* p1 = mi_heap_malloc_tp(heap,int);
378
+ int* p2 = mi_heap_malloc_tp(heap,int);
379
+ mi_heap_delete(heap);
380
+ *p1 = 42;
381
+ mi_free(p1);
382
+ mi_free(p2);
383
+ return true;
384
+ }
385
+
386
+ bool test_stl_allocator1(void) {
387
+ #ifdef __cplusplus
388
+ std::vector<int, mi_stl_allocator<int> > vec;
389
+ vec.push_back(1);
390
+ vec.pop_back();
391
+ return vec.size() == 0;
392
+ #else
393
+ return true;
394
+ #endif
395
+ }
396
+
397
+ struct some_struct { int i; int j; double z; };
398
+
399
+ bool test_stl_allocator2(void) {
400
+ #ifdef __cplusplus
401
+ std::vector<some_struct, mi_stl_allocator<some_struct> > vec;
402
+ vec.push_back(some_struct());
403
+ vec.pop_back();
404
+ return vec.size() == 0;
405
+ #else
406
+ return true;
407
+ #endif
408
+ }
409
+
410
+ bool test_stl_heap_allocator1(void) {
411
+ #ifdef __cplusplus
412
+ std::vector<some_struct, mi_heap_stl_allocator<some_struct> > vec;
413
+ vec.push_back(some_struct());
414
+ vec.pop_back();
415
+ return vec.size() == 0;
416
+ #else
417
+ return true;
418
+ #endif
419
+ }
420
+
421
+ bool test_stl_heap_allocator2(void) {
422
+ #ifdef __cplusplus
423
+ std::vector<some_struct, mi_heap_destroy_stl_allocator<some_struct> > vec;
424
+ vec.push_back(some_struct());
425
+ vec.pop_back();
426
+ return vec.size() == 0;
427
+ #else
428
+ return true;
429
+ #endif
430
+ }
431
+
432
+ bool test_stl_heap_allocator3(void) {
433
+ #ifdef __cplusplus
434
+ mi_heap_t* heap = mi_heap_new();
435
+ bool good = false;
436
+ {
437
+ mi_heap_stl_allocator<some_struct> myAlloc(heap);
438
+ std::vector<some_struct, mi_heap_stl_allocator<some_struct> > vec(myAlloc);
439
+ vec.push_back(some_struct());
440
+ vec.pop_back();
441
+ good = vec.size() == 0;
442
+ }
443
+ mi_heap_delete(heap);
444
+ return good;
445
+ #else
446
+ return true;
447
+ #endif
448
+ }
449
+
450
+ bool test_stl_heap_allocator4(void) {
451
+ #ifdef __cplusplus
452
+ mi_heap_t* heap = mi_heap_new();
453
+ bool good = false;
454
+ {
455
+ mi_heap_destroy_stl_allocator<some_struct> myAlloc(heap);
456
+ std::vector<some_struct, mi_heap_destroy_stl_allocator<some_struct> > vec(myAlloc);
457
+ vec.push_back(some_struct());
458
+ vec.pop_back();
459
+ good = vec.size() == 0;
460
+ }
461
+ mi_heap_destroy(heap);
462
+ return good;
463
+ #else
464
+ return true;
465
+ #endif
466
+ }