jade-lang 0.1.0

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 (326) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +23 -0
  3. data/LICENSE +21 -0
  4. data/README.md +386 -0
  5. data/exe/jade +6 -0
  6. data/lib/jade/ast/node.rb +44 -0
  7. data/lib/jade/ast/nodes.rb +35 -0
  8. data/lib/jade/ast/pretty_printer.rb +50 -0
  9. data/lib/jade/ast.rb +723 -0
  10. data/lib/jade/calendar/runtime.rb +15 -0
  11. data/lib/jade/cli/fmt.rb +96 -0
  12. data/lib/jade/cli/lsp.rb +13 -0
  13. data/lib/jade/cli/q.rb +113 -0
  14. data/lib/jade/cli.rb +43 -0
  15. data/lib/jade/clock/runtime.rb +13 -0
  16. data/lib/jade/codegen/boundary/cache.rb +94 -0
  17. data/lib/jade/codegen/boundary/specialized/list.rb +65 -0
  18. data/lib/jade/codegen/boundary/specialized/maybe.rb +40 -0
  19. data/lib/jade/codegen/boundary/specialized/record.rb +165 -0
  20. data/lib/jade/codegen/boundary/specialized/scalar.rb +67 -0
  21. data/lib/jade/codegen/boundary/specialized.rb +106 -0
  22. data/lib/jade/codegen/boundary.rb +189 -0
  23. data/lib/jade/codegen/constructor_reference.rb +18 -0
  24. data/lib/jade/codegen/context.rb +96 -0
  25. data/lib/jade/codegen/emitter.rb +81 -0
  26. data/lib/jade/codegen/function_call.rb +367 -0
  27. data/lib/jade/codegen/function_declaration.rb +199 -0
  28. data/lib/jade/codegen/helpers.rb +103 -0
  29. data/lib/jade/codegen/implementation.rb +178 -0
  30. data/lib/jade/codegen/inline.rb +89 -0
  31. data/lib/jade/codegen/inlines.rb +326 -0
  32. data/lib/jade/codegen/method_names.rb +54 -0
  33. data/lib/jade/codegen/pattern/constructor.rb +57 -0
  34. data/lib/jade/codegen/port_decoder.rb +77 -0
  35. data/lib/jade/codegen/pretty.rb +53 -0
  36. data/lib/jade/codegen/transforms/fold_shape.rb +222 -0
  37. data/lib/jade/codegen/transforms/self_call.rb +80 -0
  38. data/lib/jade/codegen/transforms/tail_call.rb +120 -0
  39. data/lib/jade/codegen/variant_declaration.rb +41 -0
  40. data/lib/jade/codegen.rb +400 -0
  41. data/lib/jade/compiler.rb +69 -0
  42. data/lib/jade/decode.rb +320 -0
  43. data/lib/jade/diagnostics/renderer.rb +121 -0
  44. data/lib/jade/diagnostics.rb +77 -0
  45. data/lib/jade/did_you_mean.rb +16 -0
  46. data/lib/jade/entry.rb +177 -0
  47. data/lib/jade/error.rb +72 -0
  48. data/lib/jade/formatter/accesses.rb +37 -0
  49. data/lib/jade/formatter/bindings.rb +29 -0
  50. data/lib/jade/formatter/body.rb +50 -0
  51. data/lib/jade/formatter/calls.rb +51 -0
  52. data/lib/jade/formatter/case_of.rb +31 -0
  53. data/lib/jade/formatter/case_of_branch.rb +59 -0
  54. data/lib/jade/formatter/collections.rb +78 -0
  55. data/lib/jade/formatter/declarations.rb +178 -0
  56. data/lib/jade/formatter/exposing.rb +48 -0
  57. data/lib/jade/formatter/function_declaration.rb +72 -0
  58. data/lib/jade/formatter/helper.rb +122 -0
  59. data/lib/jade/formatter/if_then_else.rb +64 -0
  60. data/lib/jade/formatter/infix_application.rb +69 -0
  61. data/lib/jade/formatter/lambda.rb +50 -0
  62. data/lib/jade/formatter/leaves.rb +111 -0
  63. data/lib/jade/formatter/module_node.rb +26 -0
  64. data/lib/jade/formatter/pattern.rb +61 -0
  65. data/lib/jade/formatter/type.rb +67 -0
  66. data/lib/jade/formatter.rb +38 -0
  67. data/lib/jade/frontend/comment_attacher.rb +121 -0
  68. data/lib/jade/frontend/desugaring/placeholder.rb +39 -0
  69. data/lib/jade/frontend/desugaring/resolved.rb +63 -0
  70. data/lib/jade/frontend/desugaring.rb +217 -0
  71. data/lib/jade/frontend/fixity_fixer.rb +209 -0
  72. data/lib/jade/frontend/forward_declaration/body.rb +30 -0
  73. data/lib/jade/frontend/forward_declaration/error/bad_import.rb +19 -0
  74. data/lib/jade/frontend/forward_declaration/error/exposed_type_not_found.rb +18 -0
  75. data/lib/jade/frontend/forward_declaration/error/exposed_value_not_found.rb +18 -0
  76. data/lib/jade/frontend/forward_declaration/error/module_not_found.rb +18 -0
  77. data/lib/jade/frontend/forward_declaration/error/private_type_expansion.rb +19 -0
  78. data/lib/jade/frontend/forward_declaration/error/tuple_arity_overflow.rb +25 -0
  79. data/lib/jade/frontend/forward_declaration/error/type_not_found.rb +29 -0
  80. data/lib/jade/frontend/forward_declaration/error/type_not_lowerable.rb +16 -0
  81. data/lib/jade/frontend/forward_declaration/error/unknown_extends_interface.rb +18 -0
  82. data/lib/jade/frontend/forward_declaration/error.rb +11 -0
  83. data/lib/jade/frontend/forward_declaration/function_declaration.rb +32 -0
  84. data/lib/jade/frontend/forward_declaration/helper.rb +91 -0
  85. data/lib/jade/frontend/forward_declaration/implementation.rb +63 -0
  86. data/lib/jade/frontend/forward_declaration/implementation_function.rb +39 -0
  87. data/lib/jade/frontend/forward_declaration/import_declaration.rb +115 -0
  88. data/lib/jade/frontend/forward_declaration/interface_declaration.rb +66 -0
  89. data/lib/jade/frontend/forward_declaration/interop_import_declaration.rb +99 -0
  90. data/lib/jade/frontend/forward_declaration/module.rb +98 -0
  91. data/lib/jade/frontend/forward_declaration/struct_declaration.rb +42 -0
  92. data/lib/jade/frontend/forward_declaration/type_declaration.rb +42 -0
  93. data/lib/jade/frontend/forward_declaration.rb +71 -0
  94. data/lib/jade/frontend/pattern_analysis/exhaustiveness.rb +65 -0
  95. data/lib/jade/frontend/pattern_analysis/matrix.rb +235 -0
  96. data/lib/jade/frontend/pattern_analysis.rb +40 -0
  97. data/lib/jade/frontend/semantic_analysis/assign.rb +20 -0
  98. data/lib/jade/frontend/semantic_analysis/body.rb +33 -0
  99. data/lib/jade/frontend/semantic_analysis/case_of.rb +19 -0
  100. data/lib/jade/frontend/semantic_analysis/case_of_branch.rb +20 -0
  101. data/lib/jade/frontend/semantic_analysis/char_literal.rb +14 -0
  102. data/lib/jade/frontend/semantic_analysis/constructor_reference.rb +64 -0
  103. data/lib/jade/frontend/semantic_analysis/error/circular_extends.rb +19 -0
  104. data/lib/jade/frontend/semantic_analysis/error/constant_not_callable.rb +24 -0
  105. data/lib/jade/frontend/semantic_analysis/error/constructor_not_found.rb +34 -0
  106. data/lib/jade/frontend/semantic_analysis/error/constructor_pattern_arity_mismatch.rb +24 -0
  107. data/lib/jade/frontend/semantic_analysis/error/duplicate_field.rb +18 -0
  108. data/lib/jade/frontend/semantic_analysis/error/duplicate_function_declaration.rb +25 -0
  109. data/lib/jade/frontend/semantic_analysis/error/duplicate_record_field.rb +19 -0
  110. data/lib/jade/frontend/semantic_analysis/error/invalid_list_rest_pattern.rb +21 -0
  111. data/lib/jade/frontend/semantic_analysis/error/kwargs_on_non_constructor.rb +17 -0
  112. data/lib/jade/frontend/semantic_analysis/error/missing_exposing_clause.rb +17 -0
  113. data/lib/jade/frontend/semantic_analysis/error/missing_extends_implementation.rb +21 -0
  114. data/lib/jade/frontend/semantic_analysis/error/missing_field.rb +20 -0
  115. data/lib/jade/frontend/semantic_analysis/error/missing_implementation_function.rb +19 -0
  116. data/lib/jade/frontend/semantic_analysis/error/module_not_found.rb +22 -0
  117. data/lib/jade/frontend/semantic_analysis/error/nested_task_port.rb +19 -0
  118. data/lib/jade/frontend/semantic_analysis/error/non_task_port.rb +22 -0
  119. data/lib/jade/frontend/semantic_analysis/error/orphan_implementation.rb +20 -0
  120. data/lib/jade/frontend/semantic_analysis/error/predicate_must_return_bool.rb +22 -0
  121. data/lib/jade/frontend/semantic_analysis/error/predicate_name_not_allowed.rb +25 -0
  122. data/lib/jade/frontend/semantic_analysis/error/shadowing_error.rb +22 -0
  123. data/lib/jade/frontend/semantic_analysis/error/type_args_mismatch.rb +25 -0
  124. data/lib/jade/frontend/semantic_analysis/error/type_param_required.rb +19 -0
  125. data/lib/jade/frontend/semantic_analysis/error/unbound_type_variable.rb +22 -0
  126. data/lib/jade/frontend/semantic_analysis/error/undefined_variable.rb +29 -0
  127. data/lib/jade/frontend/semantic_analysis/error/unknown_field.rb +20 -0
  128. data/lib/jade/frontend/semantic_analysis/error/unknown_implementation_function.rb +19 -0
  129. data/lib/jade/frontend/semantic_analysis/error/unused_interface_type_param.rb +24 -0
  130. data/lib/jade/frontend/semantic_analysis/error/value_not_exposed.rb +23 -0
  131. data/lib/jade/frontend/semantic_analysis/error/variable_not_found.rb +25 -0
  132. data/lib/jade/frontend/semantic_analysis/error.rb +40 -0
  133. data/lib/jade/frontend/semantic_analysis/function_call.rb +60 -0
  134. data/lib/jade/frontend/semantic_analysis/function_declaration.rb +58 -0
  135. data/lib/jade/frontend/semantic_analysis/grouping.rb +17 -0
  136. data/lib/jade/frontend/semantic_analysis/helper.rb +152 -0
  137. data/lib/jade/frontend/semantic_analysis/if_then_else.rb +20 -0
  138. data/lib/jade/frontend/semantic_analysis/implementation.rb +143 -0
  139. data/lib/jade/frontend/semantic_analysis/implementation_function.rb +16 -0
  140. data/lib/jade/frontend/semantic_analysis/import_declaration.rb +14 -0
  141. data/lib/jade/frontend/semantic_analysis/interface_declaration.rb +45 -0
  142. data/lib/jade/frontend/semantic_analysis/interop_import_declaration.rb +69 -0
  143. data/lib/jade/frontend/semantic_analysis/keyed_call/validation.rb +109 -0
  144. data/lib/jade/frontend/semantic_analysis/keyed_call.rb +88 -0
  145. data/lib/jade/frontend/semantic_analysis/lambda.rb +23 -0
  146. data/lib/jade/frontend/semantic_analysis/list.rb +17 -0
  147. data/lib/jade/frontend/semantic_analysis/literal.rb +23 -0
  148. data/lib/jade/frontend/semantic_analysis/member_access.rb +87 -0
  149. data/lib/jade/frontend/semantic_analysis/module_node.rb +27 -0
  150. data/lib/jade/frontend/semantic_analysis/pattern_binding.rb +27 -0
  151. data/lib/jade/frontend/semantic_analysis/pattern_constructor.rb +47 -0
  152. data/lib/jade/frontend/semantic_analysis/pattern_list.rb +33 -0
  153. data/lib/jade/frontend/semantic_analysis/pattern_literal.rb +17 -0
  154. data/lib/jade/frontend/semantic_analysis/pattern_record.rb +25 -0
  155. data/lib/jade/frontend/semantic_analysis/pattern_wildcard.rb +14 -0
  156. data/lib/jade/frontend/semantic_analysis/qualified_access.rb +14 -0
  157. data/lib/jade/frontend/semantic_analysis/record_access.rb +14 -0
  158. data/lib/jade/frontend/semantic_analysis/record_field.rb +17 -0
  159. data/lib/jade/frontend/semantic_analysis/record_literal.rb +21 -0
  160. data/lib/jade/frontend/semantic_analysis/record_update.rb +21 -0
  161. data/lib/jade/frontend/semantic_analysis/struct_declaration.rb +44 -0
  162. data/lib/jade/frontend/semantic_analysis/tuple.rb +17 -0
  163. data/lib/jade/frontend/semantic_analysis/type_declaration.rb +69 -0
  164. data/lib/jade/frontend/semantic_analysis/variable_reference.rb +27 -0
  165. data/lib/jade/frontend/semantic_analysis/variant_declaration.rb +18 -0
  166. data/lib/jade/frontend/semantic_analysis.rb +161 -0
  167. data/lib/jade/frontend/type_checking/canonicalize.rb +97 -0
  168. data/lib/jade/frontend/type_checking/constraints/deriving/decodable.rb +144 -0
  169. data/lib/jade/frontend/type_checking/constraints/deriving/encodable.rb +144 -0
  170. data/lib/jade/frontend/type_checking/constraints/deriving/eq.rb +265 -0
  171. data/lib/jade/frontend/type_checking/constraints/deriving/helpers.rb +59 -0
  172. data/lib/jade/frontend/type_checking/constraints/deriving.rb +28 -0
  173. data/lib/jade/frontend/type_checking/constraints.rb +101 -0
  174. data/lib/jade/frontend/type_checking/definition.rb +71 -0
  175. data/lib/jade/frontend/type_checking/env.rb +79 -0
  176. data/lib/jade/frontend/type_checking/error/case_of_branches_type_mismatch.rb +19 -0
  177. data/lib/jade/frontend/type_checking/error/derivation_failed.rb +21 -0
  178. data/lib/jade/frontend/type_checking/error/function_body_type_mismatch.rb +23 -0
  179. data/lib/jade/frontend/type_checking/error/function_call_type_mismatch.rb +37 -0
  180. data/lib/jade/frontend/type_checking/error/if_branch_type_mismatch.rb +19 -0
  181. data/lib/jade/frontend/type_checking/error/if_branches_type_mismatch.rb +18 -0
  182. data/lib/jade/frontend/type_checking/error/if_condition_type_mismatch.rb +17 -0
  183. data/lib/jade/frontend/type_checking/error/implementation_type_mismatch.rb +20 -0
  184. data/lib/jade/frontend/type_checking/error/list_item_type_mismatch.rb +19 -0
  185. data/lib/jade/frontend/type_checking/error/missing_implementation.rb +20 -0
  186. data/lib/jade/frontend/type_checking/error/missing_patterns.rb +26 -0
  187. data/lib/jade/frontend/type_checking/error/pattern_type_mismatch.rb +13 -0
  188. data/lib/jade/frontend/type_checking/error/port_not_decodable.rb +38 -0
  189. data/lib/jade/frontend/type_checking/error/record_access_type_mismatch.rb +14 -0
  190. data/lib/jade/frontend/type_checking/error/type_mismatch.rb +23 -0
  191. data/lib/jade/frontend/type_checking/error/unresolved_constraint.rb +20 -0
  192. data/lib/jade/frontend/type_checking/error.rb +18 -0
  193. data/lib/jade/frontend/type_checking/expected.rb +23 -0
  194. data/lib/jade/frontend/type_checking/generalization.rb +17 -0
  195. data/lib/jade/frontend/type_checking/generalizer.rb +38 -0
  196. data/lib/jade/frontend/type_checking/inference/assign.rb +58 -0
  197. data/lib/jade/frontend/type_checking/inference/body.rb +45 -0
  198. data/lib/jade/frontend/type_checking/inference/case_of.rb +102 -0
  199. data/lib/jade/frontend/type_checking/inference/constructor_reference.rb +21 -0
  200. data/lib/jade/frontend/type_checking/inference/function_call.rb +132 -0
  201. data/lib/jade/frontend/type_checking/inference/function_declaration.rb +70 -0
  202. data/lib/jade/frontend/type_checking/inference/grouping.rb +18 -0
  203. data/lib/jade/frontend/type_checking/inference/helpers.rb +34 -0
  204. data/lib/jade/frontend/type_checking/inference/if_then_else.rb +46 -0
  205. data/lib/jade/frontend/type_checking/inference/implementation.rb +150 -0
  206. data/lib/jade/frontend/type_checking/inference/import_declaration.rb +19 -0
  207. data/lib/jade/frontend/type_checking/inference/interface_declaration.rb +18 -0
  208. data/lib/jade/frontend/type_checking/inference/interop_import_declaration.rb +18 -0
  209. data/lib/jade/frontend/type_checking/inference/lambda.rb +87 -0
  210. data/lib/jade/frontend/type_checking/inference/list.rb +52 -0
  211. data/lib/jade/frontend/type_checking/inference/literal.rb +24 -0
  212. data/lib/jade/frontend/type_checking/inference/module.rb +18 -0
  213. data/lib/jade/frontend/type_checking/inference/pattern.rb +135 -0
  214. data/lib/jade/frontend/type_checking/inference/qualified_access.rb +23 -0
  215. data/lib/jade/frontend/type_checking/inference/record_access.rb +35 -0
  216. data/lib/jade/frontend/type_checking/inference/record_field.rb +19 -0
  217. data/lib/jade/frontend/type_checking/inference/record_literal.rb +24 -0
  218. data/lib/jade/frontend/type_checking/inference/record_update.rb +37 -0
  219. data/lib/jade/frontend/type_checking/inference/struct_declaration.rb +18 -0
  220. data/lib/jade/frontend/type_checking/inference/type_declaration.rb +18 -0
  221. data/lib/jade/frontend/type_checking/inference/variable_reference.rb +27 -0
  222. data/lib/jade/frontend/type_checking/inference.rb +27 -0
  223. data/lib/jade/frontend/type_checking/instantiation.rb +24 -0
  224. data/lib/jade/frontend/type_checking/loader.rb +80 -0
  225. data/lib/jade/frontend/type_checking/placeholder.rb +12 -0
  226. data/lib/jade/frontend/type_checking/port_resolution.rb +123 -0
  227. data/lib/jade/frontend/type_checking/result.rb +41 -0
  228. data/lib/jade/frontend/type_checking/scheme.rb +20 -0
  229. data/lib/jade/frontend/type_checking/state.rb +52 -0
  230. data/lib/jade/frontend/type_checking/substitution.rb +93 -0
  231. data/lib/jade/frontend/type_checking/unification.rb +282 -0
  232. data/lib/jade/frontend/type_checking/var_gen.rb +33 -0
  233. data/lib/jade/frontend/type_checking.rb +129 -0
  234. data/lib/jade/frontend/unused_analysis.rb +41 -0
  235. data/lib/jade/frontend/usage_analysis/reference_index.rb +53 -0
  236. data/lib/jade/frontend/usage_analysis.rb +195 -0
  237. data/lib/jade/frontend.rb +101 -0
  238. data/lib/jade/interop/boundary.rb +68 -0
  239. data/lib/jade/interop/error.rb +84 -0
  240. data/lib/jade/interop/lowering/error.rb +32 -0
  241. data/lib/jade/interop/lowering.rb +53 -0
  242. data/lib/jade/interop/runtime.rb +24 -0
  243. data/lib/jade/interop.rb +1 -0
  244. data/lib/jade/lexer.rb +189 -0
  245. data/lib/jade/lsp/converters.rb +542 -0
  246. data/lib/jade/lsp/handlers.rb +340 -0
  247. data/lib/jade/lsp/server.rb +63 -0
  248. data/lib/jade/lsp/snippets.rb +100 -0
  249. data/lib/jade/lsp/state.rb +25 -0
  250. data/lib/jade/lsp.rb +16 -0
  251. data/lib/jade/module_loader/cache.rb +56 -0
  252. data/lib/jade/module_loader/dependency_graph.rb +23 -0
  253. data/lib/jade/module_loader/dependency_resolver.rb +48 -0
  254. data/lib/jade/module_loader/normalize.rb +34 -0
  255. data/lib/jade/module_loader/topological_sort.rb +41 -0
  256. data/lib/jade/module_loader.rb +127 -0
  257. data/lib/jade/parsing/combinators.rb +291 -0
  258. data/lib/jade/parsing/error.rb +154 -0
  259. data/lib/jade/parsing/token.rb +12 -0
  260. data/lib/jade/parsing/type.rb +92 -0
  261. data/lib/jade/parsing.rb +674 -0
  262. data/lib/jade/port.rb +1 -0
  263. data/lib/jade/registry.rb +79 -0
  264. data/lib/jade/result.rb +121 -0
  265. data/lib/jade/runtime.rb +127 -0
  266. data/lib/jade/source.rb +62 -0
  267. data/lib/jade/stdlib/basics.rb +214 -0
  268. data/lib/jade/stdlib/bytes.rb +70 -0
  269. data/lib/jade/stdlib/calendar.rb +405 -0
  270. data/lib/jade/stdlib/char.rb +27 -0
  271. data/lib/jade/stdlib/clock.rb +342 -0
  272. data/lib/jade/stdlib/compiled.rb +48 -0
  273. data/lib/jade/stdlib/decode/params.rb +154 -0
  274. data/lib/jade/stdlib/decode.rb +315 -0
  275. data/lib/jade/stdlib/dict.rb +134 -0
  276. data/lib/jade/stdlib/encode.rb +143 -0
  277. data/lib/jade/stdlib/intrinsics.rb +280 -0
  278. data/lib/jade/stdlib/list.rb +214 -0
  279. data/lib/jade/stdlib/maybe.rb +73 -0
  280. data/lib/jade/stdlib/result.rb +131 -0
  281. data/lib/jade/stdlib/set.rb +123 -0
  282. data/lib/jade/stdlib/string.rb +65 -0
  283. data/lib/jade/stdlib/task.rb +55 -0
  284. data/lib/jade/stdlib/tuple.rb +21 -0
  285. data/lib/jade/stdlib.rb +112 -0
  286. data/lib/jade/symbol/anonymous_record.rb +7 -0
  287. data/lib/jade/symbol/base.rb +15 -0
  288. data/lib/jade/symbol/constructor.rb +11 -0
  289. data/lib/jade/symbol/derived_function.rb +5 -0
  290. data/lib/jade/symbol/function.rb +15 -0
  291. data/lib/jade/symbol/function_type.rb +7 -0
  292. data/lib/jade/symbol/implementation.rb +17 -0
  293. data/lib/jade/symbol/implementation_template.rb +13 -0
  294. data/lib/jade/symbol/interface.rb +11 -0
  295. data/lib/jade/symbol/interface_function.rb +18 -0
  296. data/lib/jade/symbol/interop_function.rb +22 -0
  297. data/lib/jade/symbol/lambda.rb +7 -0
  298. data/lib/jade/symbol/parser.rb +79 -0
  299. data/lib/jade/symbol/partial_application.rb +7 -0
  300. data/lib/jade/symbol/record_type.rb +8 -0
  301. data/lib/jade/symbol/stdlib_function.rb +15 -0
  302. data/lib/jade/symbol/stdlib_implementation.rb +7 -0
  303. data/lib/jade/symbol/struct.rb +15 -0
  304. data/lib/jade/symbol/type_application.rb +8 -0
  305. data/lib/jade/symbol/type_ref.rb +11 -0
  306. data/lib/jade/symbol/union.rb +15 -0
  307. data/lib/jade/symbol/value_ref.rb +15 -0
  308. data/lib/jade/symbol/variable.rb +7 -0
  309. data/lib/jade/symbol/variant.rb +11 -0
  310. data/lib/jade/symbol.rb +162 -0
  311. data/lib/jade/task.rb +103 -0
  312. data/lib/jade/tasks/rspec.rb +266 -0
  313. data/lib/jade/tasks.rb +70 -0
  314. data/lib/jade/type/anonymous_record.rb +33 -0
  315. data/lib/jade/type/application.rb +21 -0
  316. data/lib/jade/type/base.rb +9 -0
  317. data/lib/jade/type/constraint.rb +17 -0
  318. data/lib/jade/type/constructor.rb +19 -0
  319. data/lib/jade/type/function.rb +18 -0
  320. data/lib/jade/type/partial_application.rb +17 -0
  321. data/lib/jade/type/unit.rb +15 -0
  322. data/lib/jade/type/var.rb +21 -0
  323. data/lib/jade/type.rb +259 -0
  324. data/lib/jade/version.rb +3 -0
  325. data/lib/jade.rb +55 -0
  326. metadata +387 -0
@@ -0,0 +1,123 @@
1
+ require 'jade/stdlib/intrinsics'
2
+
3
+ module Jade
4
+ module Stdlib
5
+ module Set
6
+ extend Intrinsics
7
+
8
+ import Basics
9
+ import Maybe
10
+ import List
11
+
12
+ union :Set, 'a'
13
+
14
+ native_type :Set, Jade::Set::Set
15
+
16
+ implementation('Eq', 'Set', '(==)' => 'set_eq')
17
+
18
+ function(:empty, {}, 'Set(a)')
19
+
20
+ function(
21
+ :singleton,
22
+ { value: 'a' },
23
+ 'Set(a)',
24
+ constraints: [['Basics.Eq', 'a']],
25
+ )
26
+
27
+ function(:"empty?", { set: 'Set(a)' }, 'Bool')
28
+ function(:size, { set: 'Set(a)' }, 'Int')
29
+
30
+ function(
31
+ :"member?",
32
+ { set: 'Set(a)', value: 'a' },
33
+ 'Bool',
34
+ constraints: [['Basics.Eq', 'a']],
35
+ )
36
+
37
+ function(
38
+ :insert,
39
+ { set: 'Set(a)', value: 'a' },
40
+ 'Set(a)',
41
+ constraints: [['Basics.Eq', 'a']],
42
+ )
43
+
44
+ function(
45
+ :remove,
46
+ { set: 'Set(a)', value: 'a' },
47
+ 'Set(a)',
48
+ constraints: [['Basics.Eq', 'a']],
49
+ )
50
+
51
+ function(:to_list, { set: 'Set(a)' }, 'List(a)')
52
+
53
+ function(
54
+ :from_list,
55
+ { values: 'List(a)' },
56
+ 'Set(a)',
57
+ constraints: [['Basics.Eq', 'a']],
58
+ )
59
+
60
+ function(
61
+ :map,
62
+ { set: 'Set(a)', fn: 'a -> b' },
63
+ 'Set(b)',
64
+ constraints: [['Basics.Eq', 'b']],
65
+ ) do |set, fn|
66
+ set.hash.keys
67
+ .each_with_object({}) { |v, h| h[fn.call(v)] = true }
68
+ .then { Jade::Set::Set[it] }
69
+ end
70
+
71
+ function(
72
+ :filter,
73
+ { set: 'Set(a)', fn: 'a -> Bool' },
74
+ 'Set(a)',
75
+ ) do |set, fn|
76
+ set.hash
77
+ .select { |k, _| fn.call(k) }
78
+ .then { Jade::Set::Set[it] }
79
+ end
80
+
81
+ function(
82
+ :fold,
83
+ { set: 'Set(a)', initial: 'b', fn: 'a, b -> b' },
84
+ 'b',
85
+ ) do |set, initial, fn|
86
+ set.hash.keys.reduce(initial) { |acc, v| fn.call(v, acc) }
87
+ end
88
+
89
+ function(
90
+ :union,
91
+ { left: 'Set(a)', right: 'Set(a)' },
92
+ 'Set(a)',
93
+ constraints: [['Basics.Eq', 'a']],
94
+ )
95
+
96
+ function(
97
+ :intersect,
98
+ { left: 'Set(a)', right: 'Set(a)' },
99
+ 'Set(a)',
100
+ constraints: [['Basics.Eq', 'a']],
101
+ ) do |left, right|
102
+ left.hash
103
+ .select { |k, _| right.hash.key?(k) }
104
+ .then { Jade::Set::Set[it] }
105
+ end
106
+
107
+ function(
108
+ :diff,
109
+ { left: 'Set(a)', right: 'Set(a)' },
110
+ 'Set(a)',
111
+ constraints: [['Basics.Eq', 'a']],
112
+ ) do |left, right|
113
+ left.hash
114
+ .reject { |k, _| right.hash.key?(k) }
115
+ .then { Jade::Set::Set[it] }
116
+ end
117
+
118
+ default_importing('Set')
119
+
120
+ function('set_eq', { a: 'Set(a)', b: 'Set(a)' }, 'Bool')
121
+ end
122
+ end
123
+ end
@@ -0,0 +1,65 @@
1
+ require 'jade/stdlib/intrinsics'
2
+
3
+ module Jade
4
+ module Stdlib
5
+ module String
6
+ extend Intrinsics
7
+
8
+ import Basics
9
+ import Maybe
10
+ import List
11
+ import Char
12
+ import Tuple
13
+
14
+ union :String
15
+
16
+ native_type :String, ::String
17
+
18
+ implementation('Eq', 'String', '(==)' => 'str_eq')
19
+ implementation('Appendable', 'String', '(++)' => 'str_append')
20
+ implementation('Comparable', 'String', 'compare' => 'str_compare')
21
+
22
+ function('str_compare', { a: 'String', b: 'String' }, 'Ordering')
23
+ function('str_append', { a: 'String', b: 'String' }, 'String')
24
+ function(:"empty?", { str: 'String' }, 'Bool')
25
+ function(:length, { str: 'String' }, 'Int')
26
+ function(:reverse, { str: 'String' }, 'String')
27
+ function(:uncons, { str: 'String' }, 'Maybe(Tuple2(Char, String))')
28
+ function(:cons, { head: 'Char', tail: 'String' }, 'String')
29
+ function(:from_char, { char: 'Char' }, 'String')
30
+ function(:map, { str: 'String', fn: 'Char -> Char' }, 'String')
31
+ function(:repeat, { str: 'String', times: 'Int' }, 'String')
32
+ function(:to_int, { str: 'String' }, 'Maybe(Int)')
33
+ function(:from_int, { n: 'Int' }, 'String')
34
+ function(:split, { str: 'String', by: 'String' }, 'List(String)')
35
+ function(:concat, { list: 'List(String)' }, 'String')
36
+ function(:join, { list: 'List(String)', with: 'String' }, 'String')
37
+ function(:trim, { str: 'String' }, 'String')
38
+ function(:trim_left, { str: 'String' }, 'String')
39
+ function(:trim_right, { str: 'String' }, 'String')
40
+ function(:to_lower, { str: 'String' }, 'String')
41
+ function(:to_upper, { str: 'String' }, 'String')
42
+ function(:"contains?", { str: 'String', sub: 'String' }, 'Bool')
43
+ function(:"starts_with?", { str: 'String', prefix: 'String' }, 'Bool')
44
+ function(:"ends_with?", { str: 'String', suffix: 'String' }, 'Bool')
45
+ function(:replace, { str: 'String', target: 'String', replacement: 'String' }, 'String')
46
+
47
+ # Every start position of `sub` in `str`, left to right, non-overlapping
48
+ # (matches Elm's String.indexes). Empty `sub` yields an empty list.
49
+ function(:indexes, { str: 'String', sub: 'String' }, 'List(Int)')
50
+
51
+ # Half-open slice. Negative offsets count from the end (Ruby `s[i...j]`
52
+ # semantics). Out-of-range returns an empty string rather than nil.
53
+ function(:slice, { str: 'String', start: 'Int', end_: 'Int' }, 'String')
54
+
55
+ function(:words, { str: 'String' }, 'List(String)')
56
+ function(:lines, { str: 'String' }, 'List(String)')
57
+ function(:to_list, { str: 'String' }, 'List(Char)')
58
+ function(:from_list, { chars: 'List(Char)' }, 'String')
59
+
60
+ default_importing('String')
61
+
62
+ function('str_eq', { one: 'String', other: 'String' }, 'Bool')
63
+ end
64
+ end
65
+ end
@@ -0,0 +1,55 @@
1
+ require 'jade/stdlib/intrinsics'
2
+ require 'jade/task'
3
+
4
+ module Jade
5
+ module Stdlib
6
+ module Task
7
+ extend Intrinsics
8
+
9
+ union :Task, :a, :e
10
+
11
+ function('succeed', { value: 'a' }, 'Task(a, e)') do |value|
12
+ Jade::Task::Literal.new(Jade::Result::Ok[value])
13
+ end
14
+
15
+ function('fail', { error: 'e' }, 'Task(a, e)') do |error|
16
+ Jade::Task::Literal.new(Jade::Result::Err[error])
17
+ end
18
+
19
+ function('map', { task: 'Task(a, e)', fn: 'a -> b' }, 'Task(b, e)') do |task, fn|
20
+ Jade::Task::Map.new(task, fn)
21
+ end
22
+
23
+ function('and_then', { task: 'Task(a, e)', fn: 'a -> Task(b, e)' }, 'Task(b, e)') do |task, fn|
24
+ Jade::Task::AndThen.new(task, fn)
25
+ end
26
+
27
+ function('on_error', { task: 'Task(a, e)', fn: 'e -> Task(a, f)' }, 'Task(a, f)') do |task, fn|
28
+ Jade::Task::OnError.new(task, fn)
29
+ end
30
+
31
+ function('map_error', { task: 'Task(a, e)', fn: 'e -> f' }, 'Task(a, f)') do |task, fn|
32
+ Jade::Task::MapError.new(task, fn)
33
+ end
34
+
35
+ function('from_result', { result: 'Result(a, e)' }, 'Task(a, e)') do |result|
36
+ Jade::Task::Literal.new(result)
37
+ end
38
+
39
+ function('sequence', { tasks: 'List(Task(a, e))' }, 'Task(List(a), e)') do |tasks|
40
+ Jade::Task::Sequence.new(tasks)
41
+ end
42
+
43
+ function('run', { task: 'Task(a, e)' }, 'Result(a, e)') do |task|
44
+ task.run
45
+ end
46
+
47
+ implementation('Mappable', 'Task', 'map' => 'map')
48
+ implementation('Chainable', 'Task', 'and_then' => 'and_then')
49
+
50
+ def self.default_imports
51
+ [Symbol.type_ref('Task', 'Task')]
52
+ end
53
+ end
54
+ end
55
+ end
@@ -0,0 +1,21 @@
1
+ require 'jade/stdlib/intrinsics'
2
+
3
+ module Jade
4
+ module Stdlib
5
+ module Tuple
6
+ extend Intrinsics
7
+
8
+ union :Tuple2, 'a', 'b', constructor: true
9
+ union :Tuple3, 'a', 'b', 'c', constructor: true
10
+ union :Tuple4, 'a', 'b', 'c', 'd', constructor: true
11
+
12
+ function(:pair, { first: 'a', second: 'b' }, 'Tuple2(a, b)')
13
+ function(:first, { pair: 'Tuple2(a, b)' }, 'a')
14
+ function(:second, { pair: 'Tuple2(a, b)' }, 'b')
15
+
16
+ def self.constructor_by_arity(arity)
17
+ "Tuple.Tuple#{arity}"
18
+ end
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,112 @@
1
+ require 'set'
2
+ require 'jade/stdlib/basics'
3
+ require 'jade/stdlib/maybe'
4
+ require 'jade/stdlib/tuple'
5
+ require 'jade/stdlib/list'
6
+ require 'jade/stdlib/char'
7
+ require 'jade/stdlib/string'
8
+ require 'jade/stdlib/result'
9
+ require 'jade/stdlib/task'
10
+ require 'jade/stdlib/dict'
11
+ require 'jade/stdlib/set'
12
+ require 'jade/stdlib/decode'
13
+ require 'jade/stdlib/decode/params'
14
+ require 'jade/stdlib/encode'
15
+ require 'jade/stdlib/bytes'
16
+ require 'jade/stdlib/calendar'
17
+ require 'jade/stdlib/clock'
18
+
19
+ module Jade
20
+ module Stdlib
21
+ extend self
22
+
23
+ INTRINSICS = %w[
24
+ Basics String List Tuple Char Task
25
+ Decode Encode
26
+ Bytes
27
+ Dict Set
28
+ ].freeze
29
+ COMPILED = %w[Maybe Result Decode.Params Calendar Clock].freeze
30
+ TOPLEVELS = (INTRINSICS + COMPILED).map { it.split('.', 2).first }.to_set.freeze
31
+ STDLIBS = [
32
+ Stdlib::Basics, Stdlib::Maybe, Stdlib::Tuple, Stdlib::List, Stdlib::Char,
33
+ Stdlib::String, Stdlib::Result, Stdlib::Task,
34
+ Stdlib::Dict, Stdlib::Set,
35
+ Stdlib::Decode, Stdlib::Decode::Params, Stdlib::Encode,
36
+ Stdlib::Bytes,
37
+ Stdlib::Calendar, Stdlib::Clock,
38
+ ]
39
+ # Loaded into the registry but not auto-imported into user modules.
40
+ EXTENSIONS = [
41
+ Stdlib::Dict, Stdlib::Set,
42
+ Stdlib::Decode, Stdlib::Decode::Params, Stdlib::Encode,
43
+ Stdlib::Calendar, Stdlib::Clock,
44
+ ]
45
+
46
+ def load(registry)
47
+ registry
48
+ .then { load_stdlib(registry) }
49
+ end
50
+
51
+ def apply(registry)
52
+ # TODO: [ModuleLoaderRefactor] This should live in registry probably
53
+ user_entries = registry
54
+ .modules
55
+ .values
56
+ .reject { is_stdlib?(it) }
57
+
58
+ user_entries
59
+ .reduce(registry) do |acc, entry|
60
+ add_imports(entry)
61
+ .then { acc.add_module(it) }
62
+ end
63
+ end
64
+
65
+ def requires(name)
66
+ return [] if COMPILED.include?(name)
67
+
68
+ prefix = '../' * name.count('.')
69
+ COMPILED
70
+ .map { it.downcase.tr('.', '/') }
71
+ .map { "require_relative '#{prefix}#{it}'" }
72
+ end
73
+
74
+ PRIVATE_CONSTRUCTORS = %w[Tuple.Tuple2 Tuple.Tuple3 Tuple.Tuple4].freeze
75
+
76
+ def is_intrinsic?(entry)
77
+ INTRINSICS.include? entry.name
78
+ end
79
+
80
+ def private_constructor?(name)
81
+ PRIVATE_CONSTRUCTORS.include?(name)
82
+ end
83
+
84
+ def is_stdlib?(entry)
85
+ is_intrinsic?(entry) || COMPILED.include?(entry.name)
86
+ end
87
+
88
+ def stdlib_name?(qualified_name)
89
+ dot = qualified_name.index('.')
90
+ first = dot ? qualified_name[0, dot] : qualified_name
91
+ TOPLEVELS.include?(first)
92
+ end
93
+
94
+ private
95
+
96
+ def add_imports(entry)
97
+ (STDLIBS - EXTENSIONS)
98
+ .reduce(entry) do |acc, stdlib|
99
+ ImportEntry[stdlib.entry.name, stdlib.entry.name, stdlib.default_imports, stdlib.entry.exposes]
100
+ .then { acc.import(it) }
101
+ end
102
+ end
103
+
104
+ def load_stdlib(registry)
105
+ STDLIBS
106
+ .reduce(registry) do |acc, stdlib|
107
+ stdlib.generate_entry(acc)
108
+ acc.add_module(stdlib.entry)
109
+ end
110
+ end
111
+ end
112
+ end
@@ -0,0 +1,7 @@
1
+ module Jade
2
+ module Symbol
3
+ AnonymousRecord = Data.define(:fields, :row_var) do
4
+ include Base
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,15 @@
1
+ module Jade
2
+ module Symbol
3
+ module Base
4
+ def qualified_name
5
+ [module_name, name].join('.')
6
+ end
7
+
8
+ alias_method :qname, :qualified_name
9
+
10
+ def constructor_refs
11
+ []
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,11 @@
1
+ module Jade
2
+ module Symbol
3
+ Constructor = Data.define(:module_name, :name, :args, :parent, :decl_span) do
4
+ include Base
5
+
6
+ def to_ref
7
+ ValueRef[module_name, name]
8
+ end
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,5 @@
1
+ module Jade
2
+ module Symbol
3
+ DerivedFunction = Data.define(:params, :body)
4
+ end
5
+ end
@@ -0,0 +1,15 @@
1
+ module Jade
2
+ module Symbol
3
+ Function = Data.define(:module_name, :name, :params, :return_type, :decl_span) do
4
+ include Base
5
+
6
+ def to_ref
7
+ ValueRef[module_name, name]
8
+ end
9
+
10
+ def constant?
11
+ params.empty?
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,7 @@
1
+ module Jade
2
+ module Symbol
3
+ FunctionType = Data.define(:params, :return_type) do
4
+ include Base
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,17 @@
1
+ module Jade
2
+ module Symbol
3
+ Implementation = Data.define(
4
+ :module_name,
5
+ :interface,
6
+ :type,
7
+ :type_params,
8
+ :constraints,
9
+ :functions,
10
+ :deps,
11
+ :extends,
12
+ :decl_span
13
+ ) do
14
+ include Base
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,13 @@
1
+ module Jade
2
+ module Symbol
3
+ ImplementationTemplate = Data.define(
4
+ :interface,
5
+ :type,
6
+ :type_params,
7
+ :constraints,
8
+ :functions,
9
+ ) do
10
+ include Base
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,11 @@
1
+ module Jade
2
+ module Symbol
3
+ Interface = Data.define(:module_name, :name, :type_param, :functions, :default, :decl_span) do
4
+ include Base
5
+
6
+ def to_ref
7
+ TypeRef[module_name, name]
8
+ end
9
+ end
10
+ end
11
+ end
@@ -0,0 +1,18 @@
1
+ module Jade
2
+ module Symbol
3
+ InterfaceFunction = Data.define(
4
+ :module_name,
5
+ :name,
6
+ :interface,
7
+ :params,
8
+ :return_type,
9
+ :decl_span
10
+ ) do
11
+ include Base
12
+
13
+ def to_ref
14
+ ValueRef[module_name, name]
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,22 @@
1
+ module Jade
2
+ module Symbol
3
+ InteropFunction = Data.define(
4
+ :module_name,
5
+ :name,
6
+ :params,
7
+ :return_type,
8
+ :interop_module_name,
9
+ :constraints, # [[iface_qname, var_name]] — implicit Decodable on var arms
10
+ :decoders, # { ok: impl_or_pass_or_dict, err: ... } | nil
11
+ ) do
12
+ include Base
13
+
14
+ def to_ref
15
+ ValueRef[module_name, name]
16
+ end
17
+ end
18
+
19
+ InteropFunction::PASS = :pass
20
+ InteropFunction::Dict = Data.define(:constraint_index)
21
+ end
22
+ end
@@ -0,0 +1,7 @@
1
+ module Jade
2
+ module Symbol
3
+ Lambda = Data.define(:arity) do
4
+ include Base
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,79 @@
1
+ require 'jade/parsing'
2
+
3
+ module Jade
4
+ module Symbol
5
+ module Parser
6
+ extend self
7
+ include Parsing::Combinators
8
+ include Parsing::Token
9
+ include Parsing::Type
10
+
11
+ def parse(tokens)
12
+ type_expression
13
+ .call(State.new(tokens:, entry: 'symbol'))
14
+ .map(&:first) => Ok(node)
15
+
16
+ to_symbol(node)
17
+ end
18
+
19
+ private
20
+
21
+ def to_symbol(node)
22
+ case node
23
+ in AST::TypeApplication(constructor: AST::TypeVar(type: name), args:)
24
+ Symbol.partial_application(Symbol.var(name, nil), args.map(&method(:to_symbol)), nil)
25
+
26
+ in AST::TypeApplication(constructor: AST::QualifiedTypeName(path:), args:)
27
+ *mod_parts, type_name = path
28
+ Symbol.type_application(Symbol.type_ref(mod_parts.join('.'), type_name), args.map(&method(:to_symbol)), nil)
29
+
30
+ in AST::TypeApplication(constructor:, args:)
31
+ Symbol.type_application(Symbol.type_ref(*qualify(constructor.type)), args.map(&method(:to_symbol)), nil)
32
+
33
+ in AST::TypeVar(type:)
34
+ Symbol.var(type, nil)
35
+
36
+ in AST::TypeFunction(params:, return_type:)
37
+ Symbol
38
+ .function_type(
39
+ params.map { to_symbol(it) },
40
+ to_symbol(return_type)
41
+ )
42
+ end
43
+ end
44
+
45
+ def qualify(type)
46
+ case type
47
+ in 'Int' | 'Float' | 'Bool' | 'Ordering' | 'Never'
48
+ 'Basics'
49
+
50
+ in 'String' | 'Maybe' | 'List' | 'Result' | 'Task' | 'Char'
51
+ type
52
+
53
+ in 'Tuple2' | 'Tuple3' | 'Tuple4'
54
+ 'Tuple'
55
+
56
+ in 'Decoder' | 'Decodable' | 'DecodeError' | 'Value'
57
+ 'Decode'
58
+
59
+ in 'Encodable'
60
+ 'Encode'
61
+
62
+ in 'Params'
63
+ 'Decode.Params'
64
+
65
+ in 'Bytes'
66
+ 'Bytes'
67
+
68
+ in 'Dict'
69
+ 'Dict'
70
+
71
+ in 'Set'
72
+ 'Set'
73
+
74
+ end
75
+ .then { [it, type] }
76
+ end
77
+ end
78
+ end
79
+ end
@@ -0,0 +1,7 @@
1
+ module Jade
2
+ module Symbol
3
+ PartialApplication = Data.define(:constructor, :args, :span) do
4
+ include Base
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,8 @@
1
+ module Jade
2
+ module Symbol
3
+ RecordType = Data.define(:fields, :row_var) do
4
+ include Base
5
+ end
6
+
7
+ end
8
+ end
@@ -0,0 +1,15 @@
1
+ module Jade
2
+ module Symbol
3
+ StdlibFunction = Data.define(:module_name, :name, :params, :return_type, :codegen, :constraints) do
4
+ include Base
5
+
6
+ def to_ref
7
+ ValueRef[module_name, name]
8
+ end
9
+
10
+ def constant?
11
+ params.empty? && constraints.empty?
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,7 @@
1
+ module Jade
2
+ module Symbol
3
+ StdlibImplementation = Data.define(:params, :body) do
4
+ include Base
5
+ end
6
+ end
7
+ end
@@ -0,0 +1,15 @@
1
+ module Jade
2
+ module Symbol
3
+ Struct = Data.define(:module_name, :name, :type_params, :record_type, :decl_span) do
4
+ include Base
5
+
6
+ def to_ref
7
+ TypeRef[module_name, name]
8
+ end
9
+
10
+ def constructor_refs
11
+ [ValueRef[module_name, name]]
12
+ end
13
+ end
14
+ end
15
+ end