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,21 @@
1
+ module Jade
2
+ module Type
3
+ Application = Data.define(:constructor, :args) do
4
+ include Base
5
+
6
+ def to_s
7
+ return constructor.to_s if args.empty?
8
+
9
+ if constructor.name.start_with?('Tuple.Tuple')
10
+ return "(#{args.map(&:to_s).join(', ')})"
11
+ end
12
+
13
+ "#{constructor.to_s}(#{args.map(&:to_s).join(", ")})"
14
+ end
15
+
16
+ def unbound_vars
17
+ constructor.unbound_vars + args.flat_map(&:unbound_vars)
18
+ end
19
+ end
20
+ end
21
+ end
@@ -0,0 +1,9 @@
1
+ module Jade
2
+ module Type
3
+ module Base
4
+ def to_s
5
+ fail NotImplementedError
6
+ end
7
+ end
8
+ end
9
+ end
@@ -0,0 +1,17 @@
1
+ module Jade
2
+ module Type
3
+ # `:unindex` is for constraints that never reach `attach_dictionary` —
4
+ # typically deriving deps that live on impls, not call origins.
5
+ Constraint = Data.define(:interface, :type, :origin, :index) do
6
+ include Base
7
+
8
+ def unbound_vars
9
+ type.unbound_vars
10
+ end
11
+
12
+ def to_s
13
+ "#{interface} #{type.to_s}"
14
+ end
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,19 @@
1
+ module Jade
2
+ module Type
3
+ Constructor = Data.define(:name) do
4
+ include Base
5
+
6
+ def to_s
7
+ name.split('.').last
8
+ end
9
+
10
+ def apply(types)
11
+ Application[self, types]
12
+ end
13
+
14
+ def unbound_vars
15
+ []
16
+ end
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,18 @@
1
+ module Jade
2
+ module Type
3
+ Function = Data.define(:args, :return_type) do
4
+ include Base
5
+
6
+ def to_s
7
+ args
8
+ .map(&:to_s).join(', ')
9
+ .then { "(#{it})"} + " -> " + return_type.to_s
10
+ end
11
+
12
+ def unbound_vars
13
+ (args.flat_map(&:unbound_vars) + return_type.unbound_vars)
14
+ .to_set.to_a
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,17 @@
1
+ module Jade
2
+ module Type
3
+ PartialApplication = Data.define(:constructor, :args) do
4
+ include Base
5
+
6
+ def to_s
7
+ args.empty? ?
8
+ constructor.to_s :
9
+ "#{constructor}(_, #{args.map(&:to_s).join(', ')})"
10
+ end
11
+
12
+ def unbound_vars
13
+ constructor.unbound_vars + args.flat_map(&:unbound_vars)
14
+ end
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,15 @@
1
+ module Jade
2
+ module Type
3
+ Unit = Data.define() do
4
+ include Base
5
+
6
+ def unbound_vars
7
+ []
8
+ end
9
+
10
+ def to_s
11
+ '()'
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,21 @@
1
+ module Jade
2
+ module Type
3
+ Var = Data.define(:id, :name) do
4
+ include Base
5
+
6
+ def to_s
7
+ name || id
8
+ end
9
+
10
+ def unbound_vars
11
+ [self]
12
+ end
13
+
14
+ def ==(other)
15
+ return false unless other.is_a?(Var)
16
+
17
+ id == other.id
18
+ end
19
+ end
20
+ end
21
+ end
data/lib/jade/type.rb ADDED
@@ -0,0 +1,259 @@
1
+ require 'jade/type/base'
2
+
3
+ require 'jade/type/constraint'
4
+ require 'jade/type/anonymous_record'
5
+ require 'jade/type/application'
6
+ require 'jade/type/partial_application'
7
+ require 'jade/type/constructor'
8
+ require 'jade/type/function'
9
+ require 'jade/type/var'
10
+
11
+ module Jade
12
+ module Type
13
+ extend self
14
+
15
+ def from_symbol(symbol, registry, var_gen)
16
+ from_symbol_r(symbol, registry, var_gen, {})
17
+ .then { |type, constraints, _| [type, constraints] }
18
+ end
19
+
20
+ def var(id, name = nil)
21
+ Var[id, name]
22
+ end
23
+
24
+ def int
25
+ constructor('Basics.Int').apply([])
26
+ end
27
+
28
+ def unit
29
+ constructor('Basics.Unit').apply([])
30
+ end
31
+
32
+ def float
33
+ constructor('Basics.Float').apply([])
34
+ end
35
+
36
+ def string
37
+ constructor('String.String').apply([])
38
+ end
39
+
40
+ def bool
41
+ constructor('Basics.Bool').apply([])
42
+ end
43
+
44
+ def list
45
+ constructor('List.List')
46
+ end
47
+
48
+ CONSTRUCTORS = {}
49
+
50
+ def constructor(name)
51
+ CONSTRUCTORS[name] ||= Constructor[name].freeze
52
+ end
53
+
54
+ def function(args, return_type)
55
+ Function[args, return_type]
56
+ end
57
+
58
+ def signature(fn_type)
59
+ fn_type => Function(args:, return_type:)
60
+ [args, return_type]
61
+ end
62
+
63
+ def anonymous_record(fields, row_var)
64
+ AnonymousRecord[fields, row_var]
65
+ end
66
+
67
+ def constraint(interface_id, type, origin, index: :unindex)
68
+ fail unless interface_id in String
69
+ Constraint[interface_id, type, origin, index]
70
+ end
71
+
72
+ private
73
+
74
+ def from_symbol_r(symbol, registry, var_gen, var_map)
75
+ case symbol
76
+ in Symbol::Variable(name:)
77
+ if var_map[name]
78
+ [var_map[name], [], var_map]
79
+ else
80
+ var_gen
81
+ .next(name)
82
+ .then { [it, [], var_map.merge(name => it)] }
83
+ end
84
+
85
+ in Symbol::TypeRef | Symbol::ValueRef
86
+ registry
87
+ .lookup(symbol)
88
+ .then { from_symbol_r(it, registry, var_gen, var_map) }
89
+
90
+ in Symbol::Union
91
+ union_vars, union_cs, union_map = symbol
92
+ .type_params
93
+ .reduce([[], [], var_map]) do |(types, cs, local_map), sym|
94
+ from_symbol_r(sym, registry, var_gen, local_map)
95
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
96
+ end
97
+
98
+ Type
99
+ .constructor(symbol.qualified_name)
100
+ .then { [it.apply(union_vars), union_cs, union_map] }
101
+
102
+ in Symbol::Function
103
+ args, arg_cs, local_map = symbol
104
+ .params
105
+ .values
106
+ .reduce([[], [], {}]) do |(types, cs, local_map), sym|
107
+ from_symbol_r(sym, registry, var_gen, local_map)
108
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
109
+ end
110
+
111
+ from_symbol_r(symbol.return_type, registry, var_gen, local_map)
112
+ .then { |(t, c, _)| [Type.function(args, t), c + arg_cs] }
113
+ .then { it + [var_map] }
114
+
115
+ in Symbol::StdlibFunction
116
+ args, arg_cs, local_map = symbol
117
+ .params
118
+ .values
119
+ .reduce([[], [], {}]) do |(types, cs, local_map), sym|
120
+ from_symbol_r(sym, registry, var_gen, local_map)
121
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
122
+ end
123
+
124
+ ret_type, ret_cs, local_map = from_symbol_r(symbol.return_type, registry, var_gen, local_map)
125
+
126
+ extra_cs = symbol.constraints.map { |iface, var_name|
127
+ Type.constraint(iface, local_map.fetch(var_name), nil)
128
+ }
129
+
130
+ [Type.function(args, ret_type), ret_cs + arg_cs + extra_cs, var_map]
131
+
132
+ in Symbol::FunctionType
133
+ # Same as function and stdlib but without keyed params.
134
+ # Use var_map (not {}) so inline function type vars share the outer scope's bindings.
135
+ args, arg_cs, local_map = symbol
136
+ .params
137
+ .reduce([[], [], var_map]) do |(types, cs, local_map), sym|
138
+ from_symbol_r(sym, registry, var_gen, local_map)
139
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
140
+ end
141
+
142
+ from_symbol_r(symbol.return_type, registry, var_gen, local_map)
143
+ .then { |(t, c, updated_map)| [Type.function(args, t), c, updated_map] }
144
+
145
+ in Symbol::InteropFunction
146
+ args, arg_cs, args_map = symbol
147
+ .params
148
+ .reduce([[], [], var_map]) do |(types, cs, local_map), sym|
149
+ from_symbol_r(sym, registry, var_gen, local_map)
150
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
151
+ end
152
+
153
+ ret_type, ret_cs, full_map = from_symbol_r(symbol.return_type, registry, var_gen, args_map)
154
+
155
+ extra_cs = symbol.constraints.map { |iface, var_name|
156
+ Type.constraint(iface, full_map.fetch(var_name), nil)
157
+ }
158
+
159
+ [Type.function(args, ret_type), ret_cs + arg_cs + extra_cs, full_map]
160
+
161
+ in Symbol::InterfaceFunction
162
+ # Same as function and stdlib but without keyed params.
163
+ args, arg_cs, local_map = symbol
164
+ .params
165
+ .reduce([[], [], {}]) do |(types, cs, local_map), sym|
166
+ from_symbol_r(sym, registry, var_gen, local_map)
167
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
168
+ end
169
+
170
+ interface = registry.lookup(symbol.interface)
171
+ constraint = Type
172
+ .constraint(
173
+ symbol.interface.qualified_name,
174
+ from_symbol_r(interface.type_param, registry, var_gen, local_map).first,
175
+ nil,
176
+ )
177
+
178
+ from_symbol_r(symbol.return_type, registry, var_gen, local_map)
179
+ .then { |(t, c, _)| [args.empty? ? t : Type.function(args, t), c + arg_cs + [constraint]] }
180
+ .then { it + [var_map] }
181
+
182
+ in Symbol::Constructor if symbol.args.empty?
183
+ from_symbol_r(symbol.parent, registry, var_gen, var_map)
184
+
185
+ in Symbol::Constructor
186
+ union_type, union_cs, union_vars =
187
+ from_symbol_r(symbol.parent, registry, var_gen, var_map)
188
+
189
+ args, arg_cs, args_map = symbol
190
+ .args
191
+ .reduce([[], [], union_vars]) do |(types, cs, local_map), sym|
192
+ from_symbol_r(sym, registry, var_gen, local_map)
193
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
194
+ end
195
+
196
+ Type
197
+ .function(
198
+ args,
199
+ union_type,
200
+ )
201
+ .then { [it, union_cs + arg_cs, args_map] }
202
+
203
+ in Symbol::AnonymousRecord(fields:)
204
+ fields
205
+ .map { |k, _| [k, var_gen.next(k)] }.to_h
206
+ .then { Type.anonymous_record(it, nil) }
207
+ .then { [it, [], var_map] }
208
+
209
+ in Symbol::Struct(record_type:)
210
+ struct_vars, struct_cs, struct_map = symbol
211
+ .type_params
212
+ .reduce([[], [], var_map]) do |(types, cs, local_map), sym|
213
+ from_symbol_r(sym, registry, var_gen, local_map)
214
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
215
+ end
216
+
217
+ Type
218
+ .constructor(symbol.qualified_name)
219
+ .then { [it.apply(struct_vars), struct_cs, struct_map] }
220
+
221
+ in Symbol::RecordType(fields:, row_var:)
222
+ row, _, row_map = row_var
223
+ &.then { from_symbol_r(row_var, registry, var_gen, var_map) } ||
224
+ [nil, [], var_map]
225
+
226
+ fields
227
+ .reduce([{}, [], row_map]) do |(type, cs, local_map), (k, v)|
228
+ from_symbol_r(v, registry, var_gen, local_map)
229
+ .then { |(t, c, new_map)| [type.merge(k => t), c + cs, new_map] }
230
+ end
231
+ .then { |t, cs, map| [Type.anonymous_record(t, row), cs, map] }
232
+
233
+ in Symbol::PartialApplication(constructor:, args:)
234
+ constructor_type, union_cs, union_vars =
235
+ from_symbol_r(constructor, registry, var_gen, var_map)
236
+
237
+ arg_types, args_cs, args_map = args
238
+ .reduce([[], [], union_vars]) do |(types, cs, local_map), sym|
239
+ from_symbol_r(sym, registry, var_gen, local_map)
240
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
241
+ end
242
+
243
+ [Type::Application[constructor_type, arg_types], union_cs + args_cs, args_map]
244
+
245
+ in Symbol::TypeApplication(constructor:, args:)
246
+ constructor_type, union_cs, union_vars =
247
+ from_symbol_r(constructor, registry, var_gen, var_map)
248
+
249
+ arg_types, args_cs, args_map = args
250
+ .reduce([[], [], union_vars]) do |(types, cs, local_map), sym|
251
+ from_symbol_r(sym, registry, var_gen, local_map)
252
+ .then { |(t, c, new_map)| [types + [t], cs + c, new_map] }
253
+ end
254
+
255
+ [Type.constructor(constructor.qualified_name).apply(arg_types), union_cs + args_cs, args_map]
256
+ end
257
+ end
258
+ end
259
+ end
@@ -0,0 +1,3 @@
1
+ module Jade
2
+ VERSION = '0.1.0'
3
+ end
data/lib/jade.rb ADDED
@@ -0,0 +1,55 @@
1
+ require 'jade/version'
2
+ require 'jade/did_you_mean'
3
+ require 'jade/symbol'
4
+ require 'jade/registry'
5
+ require 'jade/type'
6
+ require 'jade/frontend'
7
+ require 'jade/parsing'
8
+ require 'jade/lexer'
9
+ require 'jade/ast'
10
+ require 'jade/codegen'
11
+ require 'jade/compiler'
12
+ require 'jade/interop'
13
+ require 'jade/stdlib'
14
+ require 'jade/diagnostics'
15
+ require 'jade/diagnostics/renderer'
16
+
17
+ module Jade
18
+ class CompilationError < StandardError
19
+ attr_reader :diagnostics
20
+
21
+ def initialize(diagnostics)
22
+ @diagnostics = diagnostics
23
+ super(diagnostics.items.map(&:message).join(", "))
24
+ end
25
+ end
26
+
27
+ extend self
28
+
29
+ def register_extension(root)
30
+ extensions << root
31
+ end
32
+
33
+ # Convenience for extension gem entry files: registers `<entry>/<basename>`
34
+ # by convention. Pass `__FILE__` from `lib/jade-foo.rb` to register
35
+ # `lib/jade-foo/` as the search root.
36
+ def extension(entry_file)
37
+ register_extension(entry_file.delete_suffix('.rb'))
38
+ end
39
+
40
+ def extensions
41
+ @extensions ||= []
42
+ end
43
+
44
+ def setup(&block)
45
+ @compiler = Compiler.new(&block)
46
+ end
47
+
48
+ def require(path)
49
+ @compiler ||= Compiler.new
50
+ @compiler.require(path)
51
+ rescue CompilationError => e
52
+ $stderr.puts Diagnostics::Renderer.new.render_all(e.diagnostics)
53
+ exit 1
54
+ end
55
+ end