@adeficior/data-modifier 1.0.0-rc.11 → 1.0.0-rc.13

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 (236) hide show
  1. package/dist/common/id.d.ts +1 -0
  2. package/dist/common/id.js +4 -0
  3. package/dist/common/id.js.map +1 -1
  4. package/dist/common/ingredient/filter.d.ts +6 -0
  5. package/dist/common/ingredient/filter.js +97 -0
  6. package/dist/common/ingredient/filter.js.map +1 -0
  7. package/dist/common/ingredient/index.d.ts +74 -0
  8. package/dist/common/ingredient/index.js +112 -0
  9. package/dist/common/ingredient/index.js.map +1 -0
  10. package/dist/common/ingredient/input.d.ts +3 -0
  11. package/dist/common/ingredient/input.js +1 -0
  12. package/dist/common/ingredient/input.js.map +1 -0
  13. package/dist/common/ingredient/serializer.d.ts +17 -0
  14. package/dist/common/ingredient/serializer.js +112 -0
  15. package/dist/common/ingredient/serializer.js.map +1 -0
  16. package/dist/common/predicates.d.ts +2 -1
  17. package/dist/common/predicates.js.map +1 -1
  18. package/dist/common/result/filter.d.ts +6 -0
  19. package/dist/common/result/filter.js +68 -0
  20. package/dist/common/result/filter.js.map +1 -0
  21. package/dist/common/result/index.d.ts +41 -0
  22. package/dist/common/result/index.js +59 -0
  23. package/dist/common/result/index.js.map +1 -0
  24. package/dist/common/result/input.d.ts +3 -0
  25. package/dist/common/result/input.js +1 -0
  26. package/dist/common/result/input.js.map +1 -0
  27. package/dist/common/result/serializer.d.ts +15 -0
  28. package/dist/common/result/serializer.js +81 -0
  29. package/dist/common/result/serializer.js.map +1 -0
  30. package/dist/common/serializable.d.ts +6 -0
  31. package/dist/common/serializable.js +1 -0
  32. package/dist/common/serializable.js.map +1 -0
  33. package/dist/common/units.d.ts +1 -0
  34. package/dist/common/units.js +2 -0
  35. package/dist/common/units.js.map +1 -0
  36. package/dist/emit/blacklist.d.ts +4 -6
  37. package/dist/emit/blacklist.js +19 -21
  38. package/dist/emit/blacklist.js.map +1 -1
  39. package/dist/emit/data/loot.d.ts +6 -7
  40. package/dist/emit/data/loot.js +14 -13
  41. package/dist/emit/data/loot.js.map +1 -1
  42. package/dist/emit/data/recipe.d.ts +18 -16
  43. package/dist/emit/data/recipe.js +28 -22
  44. package/dist/emit/data/recipe.js.map +1 -1
  45. package/dist/emit/data/tags.d.ts +1 -1
  46. package/dist/emit/data/tags.js.map +1 -1
  47. package/dist/emit/polytoneTabs.d.ts +1 -1
  48. package/dist/emit/polytoneTabs.js +1 -2
  49. package/dist/emit/polytoneTabs.js.map +1 -1
  50. package/dist/emit/rule/lootTable.d.ts +2 -1
  51. package/dist/emit/rule/lootTable.js +4 -2
  52. package/dist/emit/rule/lootTable.js.map +1 -1
  53. package/dist/emit/rule/recipe.d.ts +4 -2
  54. package/dist/emit/rule/recipe.js.map +1 -1
  55. package/dist/emit/ruled.d.ts +2 -1
  56. package/dist/emit/ruled.js +5 -2
  57. package/dist/emit/ruled.js.map +1 -1
  58. package/dist/index.d.ts +1 -4
  59. package/dist/index.js +1 -2
  60. package/dist/index.js.map +1 -1
  61. package/dist/loader/context.d.ts +12 -0
  62. package/dist/loader/context.js +1 -0
  63. package/dist/loader/context.js.map +1 -0
  64. package/dist/loader/pack.d.ts +15 -8
  65. package/dist/loader/pack.js +43 -25
  66. package/dist/loader/pack.js.map +1 -1
  67. package/dist/loader/recipe.d.ts +8 -4
  68. package/dist/loader/recipe.js +41 -47
  69. package/dist/loader/recipe.js.map +1 -1
  70. package/dist/loader/registry/dump.d.ts +0 -2
  71. package/dist/loader/registry/dump.js +0 -11
  72. package/dist/loader/registry/dump.js.map +1 -1
  73. package/dist/loader/registry/index.d.ts +0 -2
  74. package/dist/loader/registry/wrapped.d.ts +13 -0
  75. package/dist/loader/registry/wrapped.js +26 -0
  76. package/dist/loader/registry/wrapped.js.map +1 -0
  77. package/dist/loader/tags.d.ts +1 -1
  78. package/dist/loader/tags.js.map +1 -1
  79. package/dist/packFormat.d.ts +11 -0
  80. package/dist/packFormat.js +59 -0
  81. package/dist/packFormat.js.map +1 -0
  82. package/dist/parser/adAstra.d.ts +5 -11
  83. package/dist/parser/adAstra.js +5 -5
  84. package/dist/parser/adAstra.js.map +1 -1
  85. package/dist/parser/botania.d.ts +10 -20
  86. package/dist/parser/botania.js +10 -10
  87. package/dist/parser/botania.js.map +1 -1
  88. package/dist/parser/create.d.ts +2 -4
  89. package/dist/parser/create.js +2 -2
  90. package/dist/parser/create.js.map +1 -1
  91. package/dist/parser/index.d.ts +6 -12
  92. package/dist/parser/index.js +6 -6
  93. package/dist/parser/index.js.map +1 -1
  94. package/dist/parser/lootTable.d.ts +7 -6
  95. package/dist/parser/lootTable.js +25 -23
  96. package/dist/parser/lootTable.js.map +1 -1
  97. package/dist/parser/recipe/adAstra/conversion.d.ts +15 -14
  98. package/dist/parser/recipe/adAstra/conversion.js +26 -19
  99. package/dist/parser/recipe/adAstra/conversion.js.map +1 -1
  100. package/dist/parser/recipe/adAstra/hammering.d.ts +3 -17
  101. package/dist/parser/recipe/adAstra/hammering.js +2 -25
  102. package/dist/parser/recipe/adAstra/hammering.js.map +1 -1
  103. package/dist/parser/recipe/adAstra/inputOutput.d.ts +16 -19
  104. package/dist/parser/recipe/adAstra/inputOutput.js +37 -29
  105. package/dist/parser/recipe/adAstra/inputOutput.js.map +1 -1
  106. package/dist/parser/recipe/adAstra/nasaWorkbench.d.ts +3 -19
  107. package/dist/parser/recipe/adAstra/nasaWorkbench.js +2 -28
  108. package/dist/parser/recipe/adAstra/nasaWorkbench.js.map +1 -1
  109. package/dist/parser/recipe/adAstra/spaceStation.d.ts +15 -14
  110. package/dist/parser/recipe/adAstra/spaceStation.js +33 -14
  111. package/dist/parser/recipe/adAstra/spaceStation.js.map +1 -1
  112. package/dist/parser/recipe/botania/apothecary.d.ts +17 -14
  113. package/dist/parser/recipe/botania/apothecary.js +26 -17
  114. package/dist/parser/recipe/botania/apothecary.js.map +1 -1
  115. package/dist/parser/recipe/botania/blocks.d.ts +21 -0
  116. package/dist/parser/recipe/botania/blocks.js +77 -0
  117. package/dist/parser/recipe/botania/blocks.js.map +1 -0
  118. package/dist/parser/recipe/botania/brew.d.ts +13 -12
  119. package/dist/parser/recipe/botania/brew.js +16 -11
  120. package/dist/parser/recipe/botania/brew.js.map +1 -1
  121. package/dist/parser/recipe/botania/elvenTrade.d.ts +8 -13
  122. package/dist/parser/recipe/botania/elvenTrade.js +11 -22
  123. package/dist/parser/recipe/botania/elvenTrade.js.map +1 -1
  124. package/dist/parser/recipe/botania/gogWrapper.d.ts +12 -12
  125. package/dist/parser/recipe/botania/gogWrapper.js +12 -13
  126. package/dist/parser/recipe/botania/gogWrapper.js.map +1 -1
  127. package/dist/parser/recipe/botania/manaInfusion.d.ts +18 -15
  128. package/dist/parser/recipe/botania/manaInfusion.js +29 -21
  129. package/dist/parser/recipe/botania/manaInfusion.js.map +1 -1
  130. package/dist/parser/recipe/botania/nbtWrapper.d.ts +12 -12
  131. package/dist/parser/recipe/botania/nbtWrapper.js +10 -11
  132. package/dist/parser/recipe/botania/nbtWrapper.js.map +1 -1
  133. package/dist/parser/recipe/botania/orechid.d.ts +3 -30
  134. package/dist/parser/recipe/botania/orechid.js +2 -72
  135. package/dist/parser/recipe/botania/orechid.js.map +1 -1
  136. package/dist/parser/recipe/botania/pureDaisy.d.ts +3 -18
  137. package/dist/parser/recipe/botania/pureDaisy.js +2 -28
  138. package/dist/parser/recipe/botania/pureDaisy.js.map +1 -1
  139. package/dist/parser/recipe/botania/runicAltar.d.ts +8 -13
  140. package/dist/parser/recipe/botania/runicAltar.js +11 -22
  141. package/dist/parser/recipe/botania/runicAltar.js.map +1 -1
  142. package/dist/parser/recipe/botania/terraPlate.d.ts +4 -16
  143. package/dist/parser/recipe/botania/terraPlate.js +2 -25
  144. package/dist/parser/recipe/botania/terraPlate.js.map +1 -1
  145. package/dist/parser/recipe/create/assembly.d.ts +18 -17
  146. package/dist/parser/recipe/create/assembly.js +27 -27
  147. package/dist/parser/recipe/create/assembly.js.map +1 -1
  148. package/dist/parser/recipe/create/processing.d.ts +4 -16
  149. package/dist/parser/recipe/create/processing.js +2 -25
  150. package/dist/parser/recipe/create/processing.js.map +1 -1
  151. package/dist/parser/recipe/farmersdelight/cooking.d.ts +16 -12
  152. package/dist/parser/recipe/farmersdelight/cooking.js +27 -15
  153. package/dist/parser/recipe/farmersdelight/cooking.js.map +1 -1
  154. package/dist/parser/recipe/farmersdelight/cutting.d.ts +14 -14
  155. package/dist/parser/recipe/farmersdelight/cutting.js +32 -29
  156. package/dist/parser/recipe/farmersdelight/cutting.js.map +1 -1
  157. package/dist/parser/recipe/forge/conditional.d.ts +10 -10
  158. package/dist/parser/recipe/forge/conditional.js +13 -17
  159. package/dist/parser/recipe/forge/conditional.js.map +1 -1
  160. package/dist/parser/recipe/index.d.ts +21 -12
  161. package/dist/parser/recipe/index.js +10 -3
  162. package/dist/parser/recipe/index.js.map +1 -1
  163. package/dist/parser/recipe/ingredientMap.d.ts +12 -0
  164. package/dist/parser/recipe/ingredientMap.js +17 -0
  165. package/dist/parser/recipe/ingredientMap.js.map +1 -0
  166. package/dist/parser/recipe/manyToMany.d.ts +20 -0
  167. package/dist/parser/recipe/manyToMany.js +33 -0
  168. package/dist/parser/recipe/manyToMany.js.map +1 -0
  169. package/dist/parser/recipe/manyToOne.d.ts +20 -0
  170. package/dist/parser/recipe/manyToOne.js +33 -0
  171. package/dist/parser/recipe/manyToOne.js.map +1 -0
  172. package/dist/parser/recipe/oneToOne.d.ts +20 -0
  173. package/dist/parser/recipe/oneToOne.js +33 -0
  174. package/dist/parser/recipe/oneToOne.js.map +1 -0
  175. package/dist/parser/recipe/roots/component.d.ts +13 -12
  176. package/dist/parser/recipe/roots/component.js +16 -11
  177. package/dist/parser/recipe/roots/component.js.map +1 -1
  178. package/dist/parser/recipe/roots/ritual.d.ts +14 -15
  179. package/dist/parser/recipe/roots/ritual.js +18 -25
  180. package/dist/parser/recipe/roots/ritual.js.map +1 -1
  181. package/dist/parser/recipe/sullys/polishing.d.ts +4 -16
  182. package/dist/parser/recipe/sullys/polishing.js +2 -25
  183. package/dist/parser/recipe/sullys/polishing.js.map +1 -1
  184. package/dist/parser/recipe/thermal/catalyst.d.ts +13 -12
  185. package/dist/parser/recipe/thermal/catalyst.js +16 -11
  186. package/dist/parser/recipe/thermal/catalyst.js.map +1 -1
  187. package/dist/parser/recipe/thermal/fuel.d.ts +13 -12
  188. package/dist/parser/recipe/thermal/fuel.js +17 -11
  189. package/dist/parser/recipe/thermal/fuel.js.map +1 -1
  190. package/dist/parser/recipe/thermal/index.d.ts +16 -14
  191. package/dist/parser/recipe/thermal/index.js +35 -24
  192. package/dist/parser/recipe/thermal/index.js.map +1 -1
  193. package/dist/parser/recipe/thermal/ingredient.d.ts +4 -21
  194. package/dist/parser/recipe/thermal/ingredient.js +40 -33
  195. package/dist/parser/recipe/thermal/ingredient.js.map +1 -1
  196. package/dist/parser/recipe/thermal/treeExtraction.d.ts +17 -17
  197. package/dist/parser/recipe/thermal/treeExtraction.js +29 -30
  198. package/dist/parser/recipe/thermal/treeExtraction.js.map +1 -1
  199. package/dist/parser/recipe/vanilla/shaped.d.ts +17 -13
  200. package/dist/parser/recipe/vanilla/shaped.js +21 -16
  201. package/dist/parser/recipe/vanilla/shaped.js.map +1 -1
  202. package/dist/parser/recipe/vanilla/shapeless.d.ts +3 -17
  203. package/dist/parser/recipe/vanilla/shapeless.js +2 -25
  204. package/dist/parser/recipe/vanilla/shapeless.js.map +1 -1
  205. package/dist/parser/recipe/vanilla/smelting.d.ts +16 -13
  206. package/dist/parser/recipe/vanilla/smelting.js +21 -15
  207. package/dist/parser/recipe/vanilla/smelting.js.map +1 -1
  208. package/dist/parser/recipe/vanilla/smithing.d.ts +18 -14
  209. package/dist/parser/recipe/vanilla/smithing.js +25 -16
  210. package/dist/parser/recipe/vanilla/smithing.js.map +1 -1
  211. package/dist/parser/recipe/vanilla/stonecutting.d.ts +15 -13
  212. package/dist/parser/recipe/vanilla/stonecutting.js +22 -24
  213. package/dist/parser/recipe/vanilla/stonecutting.js.map +1 -1
  214. package/dist/parser/roots.d.ts +2 -4
  215. package/dist/parser/roots.js +2 -2
  216. package/dist/parser/roots.js.map +1 -1
  217. package/dist/parser/thermal.d.ts +4 -10
  218. package/dist/parser/thermal.js +4 -5
  219. package/dist/parser/thermal.js.map +1 -1
  220. package/dist/schema/data/recipe.d.ts +2 -1
  221. package/package.json +3 -2
  222. package/dist/common/ingredient.d.ts +0 -49
  223. package/dist/common/ingredient.js +0 -108
  224. package/dist/common/ingredient.js.map +0 -1
  225. package/dist/common/result.d.ts +0 -48
  226. package/dist/common/result.js +0 -37
  227. package/dist/common/result.js.map +0 -1
  228. package/dist/parser/recipe/adAstra/index.d.ts +0 -5
  229. package/dist/parser/recipe/adAstra/index.js +0 -1
  230. package/dist/parser/recipe/adAstra/index.js.map +0 -1
  231. package/dist/parser/recipe/ignored.d.ts +0 -10
  232. package/dist/parser/recipe/ignored.js +0 -16
  233. package/dist/parser/recipe/ignored.js.map +0 -1
  234. package/dist/parser/recipe/quark/exclusion.d.ts +0 -20
  235. package/dist/parser/recipe/quark/exclusion.js +0 -32
  236. package/dist/parser/recipe/quark/exclusion.js.map +0 -1
@@ -0,0 +1,59 @@
1
+ import { encodeId } from "../id";
2
+ import { BUCKET } from "../units";
3
+ export class Result {
4
+ validate(_) { }
5
+ }
6
+ export class ItemResult extends Result {
7
+ id;
8
+ count;
9
+ chance;
10
+ constructor(id, count = 1, chance) {
11
+ super();
12
+ this.id = id;
13
+ this.count = count;
14
+ this.chance = chance;
15
+ }
16
+ toJSON(_packFormat) {
17
+ const { chance } = this;
18
+ const count = this.count === 1 ? undefined : this.count;
19
+ const id = encodeId(this.id);
20
+ return { item: id, count, chance };
21
+ }
22
+ validate(lookup) {
23
+ lookup?.validateEntry("minecraft:item", this.id);
24
+ }
25
+ }
26
+ export class FluidResult extends Result {
27
+ id;
28
+ amount;
29
+ chance;
30
+ constructor(id, amount = BUCKET, chance) {
31
+ super();
32
+ this.id = id;
33
+ this.amount = amount;
34
+ this.chance = chance;
35
+ }
36
+ toJSON(_packFormat) {
37
+ const { amount, chance } = this;
38
+ const id = encodeId(this.id);
39
+ return { fluid: id, amount, chance };
40
+ }
41
+ validate(lookup) {
42
+ lookup?.validateEntry("minecraft:fluid", this.id);
43
+ }
44
+ }
45
+ export class BlockResult extends Result {
46
+ id;
47
+ constructor(id) {
48
+ super();
49
+ this.id = id;
50
+ }
51
+ toJSON(_packFormat) {
52
+ const id = encodeId(this.id);
53
+ return { block: id };
54
+ }
55
+ validate(lookup) {
56
+ lookup?.validateEntry("minecraft:block", this.id);
57
+ }
58
+ }
59
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/result/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,QAAQ,EAAgB,MAAM,OAAO,CAAC;AAE/C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,MAAM,OAAgB,MAAM;IAC1B,QAAQ,CAAC,CAAkB,IAAS,CAAC;CAEtC;AAED,MAAM,OAAO,UAAW,SAAQ,MAAM;IAElB;IACA;IACA;IAHlB,YACkB,EAAmB,EACnB,QAAQ,CAAC,EACT,MAAe;QAE/B,KAAK,EAAE,CAAC;QAJQ,OAAE,GAAF,EAAE,CAAiB;QACnB,UAAK,GAAL,KAAK,CAAI;QACT,WAAM,GAAN,MAAM,CAAS;IAGjC,CAAC;IAED,MAAM,CAAC,WAAwB;QAC7B,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QACxD,MAAM,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC7B,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;IACrC,CAAC;IAEQ,QAAQ,CAAC,MAAuB;QACvC,MAAM,EAAE,aAAa,CAAC,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IACnD,CAAC;CACF;AAED,MAAM,OAAO,WAAY,SAAQ,MAAM;IAEnB;IACA;IACA;IAHlB,YACkB,EAAoB,EACpB,SAAiB,MAAM,EACvB,MAAe;QAE/B,KAAK,EAAE,CAAC;QAJQ,OAAE,GAAF,EAAE,CAAkB;QACpB,WAAM,GAAN,MAAM,CAAiB;QACvB,WAAM,GAAN,MAAM,CAAS;IAGjC,CAAC;IAED,MAAM,CAAC,WAAwB;QAC7B,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QAChC,MAAM,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC7B,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;IACvC,CAAC;IAEQ,QAAQ,CAAC,MAAuB;QACvC,MAAM,EAAE,aAAa,CAAC,iBAAiB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IACpD,CAAC;CACF;AAED,MAAM,OAAO,WAAY,SAAQ,MAAM;IACT;IAA5B,YAA4B,EAAoB;QAC9C,KAAK,EAAE,CAAC;QADkB,OAAE,GAAF,EAAE,CAAkB;IAEhD,CAAC;IAED,MAAM,CAAC,WAAwB;QAC7B,MAAM,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC7B,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;IACvB,CAAC;IAEQ,QAAQ,CAAC,MAAuB;QACvC,MAAM,EAAE,aAAa,CAAC,iBAAiB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IACpD,CAAC;CACF"}
@@ -0,0 +1,3 @@
1
+ import type { ItemId } from "@adeficior/data-modifier/generated";
2
+ import type { Result } from ".";
3
+ export type ResultInput = ItemId | Result;
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"input.js","sourceRoot":"","sources":["../../../src/common/result/input.ts"],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import { Result } from ".";
2
+ import type RegistryLookup from "../../loader/registry";
3
+ import type { SemVerInput } from "../../packFormat";
4
+ export default class ResultSerializer {
5
+ private readonly packFormat;
6
+ private readonly lookup;
7
+ private readonly deserializer;
8
+ constructor(packFormat: SemVerInput, lookup: RegistryLookup);
9
+ serialize(result: Result): Record<string, unknown>;
10
+ serializeList(results: Result[]): Record<string, unknown>[];
11
+ private deserialize;
12
+ create(input: unknown): Result;
13
+ validated<T extends Result>(result: T): T;
14
+ createList(input: unknown[]): Result[];
15
+ }
@@ -0,0 +1,81 @@
1
+ import z from "zod";
2
+ import { BlockResult, FluidResult, ItemResult, Result } from ".";
3
+ import { IllegalShapeError } from "../../error";
4
+ import { IdSchema } from "../id";
5
+ class OldDeserializer {
6
+ schemas = {
7
+ itemStack: z.object({
8
+ item: IdSchema,
9
+ count: z.number().int().optional(),
10
+ chance: z.number().optional(),
11
+ }),
12
+ fluidStack: z.object({
13
+ fluid: IdSchema,
14
+ amount: z.number(),
15
+ chance: z.number().optional(),
16
+ }),
17
+ block: z.object({
18
+ block: IdSchema,
19
+ }),
20
+ };
21
+ deserialize(input) {
22
+ if ("block" in input) {
23
+ const parsed = this.schemas.block.parse(input);
24
+ return new BlockResult(parsed.block);
25
+ }
26
+ if ("item" in input) {
27
+ const parsed = this.schemas.itemStack.parse(input);
28
+ return new ItemResult(parsed.item, parsed.count, parsed.chance);
29
+ }
30
+ if ("fluid" in input) {
31
+ const parsed = this.schemas.fluidStack.parse(input);
32
+ return new FluidResult(parsed.fluid, parsed.amount, parsed.chance);
33
+ }
34
+ return null;
35
+ }
36
+ }
37
+ export default class ResultSerializer {
38
+ packFormat;
39
+ lookup;
40
+ deserializer;
41
+ constructor(packFormat, lookup) {
42
+ this.packFormat = packFormat;
43
+ this.lookup = lookup;
44
+ this.deserializer = new OldDeserializer();
45
+ }
46
+ serialize(result) {
47
+ return result.toJSON(this.packFormat);
48
+ }
49
+ serializeList(results) {
50
+ return results.map((it) => this.serialize(it));
51
+ }
52
+ deserialize(input) {
53
+ if (input instanceof Result)
54
+ return input;
55
+ if (!input)
56
+ throw new IllegalShapeError("result input may not be null");
57
+ if (typeof input === "string") {
58
+ this.lookup.validateEntry("minecraft:item", input);
59
+ return new ItemResult(input);
60
+ }
61
+ if (typeof input === "object") {
62
+ const deserialized = this.deserializer.deserialize(input);
63
+ if (deserialized)
64
+ return deserialized;
65
+ }
66
+ throw new IllegalShapeError(`unknown result shape`, input);
67
+ }
68
+ create(input) {
69
+ const deserialized = this.deserialize(input);
70
+ deserialized.validate(this.lookup);
71
+ return deserialized;
72
+ }
73
+ validated(result) {
74
+ result.validate(this.lookup);
75
+ return result;
76
+ }
77
+ createList(input) {
78
+ return input.map((it) => this.create(it));
79
+ }
80
+ }
81
+ //# sourceMappingURL=serializer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serializer.js","sourceRoot":"","sources":["../../../src/common/result/serializer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type RegistryLookup from "../loader/registry";
2
+ import type { SemVerInput } from "../packFormat";
3
+ export interface Serializable {
4
+ toJSON(packFormat: SemVerInput): unknown;
5
+ validate(lookup?: RegistryLookup): void;
6
+ }
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=serializable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"serializable.js","sourceRoot":"","sources":["../../src/common/serializable.ts"],"names":[],"mappings":""}
@@ -0,0 +1 @@
1
+ export declare const BUCKET = 1000;
@@ -0,0 +1,2 @@
1
+ export const BUCKET = 1000;
2
+ //# sourceMappingURL=units.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"units.js","sourceRoot":"","sources":["../../src/common/units.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,MAAM,GAAG,IAAI,CAAC"}
@@ -1,8 +1,7 @@
1
1
  import type { InferIds, RegistryId } from "@adeficior/data-modifier/generated";
2
2
  import type { Acceptor, Logger } from "@adeficior/pack-resolver";
3
- import type { IngredientTest } from "../common/ingredient.js";
4
- import type RegistryLookup from "../loader/registry/index.js";
5
- import type { TagRegistryHolder } from "../loader/tags.js";
3
+ import type { IngredientTest } from "../common/ingredient/filter.js";
4
+ import type { PackContext } from "../loader/context.js";
6
5
  import type { ClearableEmitter } from "./index.js";
7
6
  export type HideMode = "jei" | "polytone";
8
7
  export interface BlacklistOptions {
@@ -15,11 +14,10 @@ export interface BlacklistRules {
15
14
  type RegistryIdInput<T extends RegistryId> = InferIds<T> | RegExp;
16
15
  export default class BlacklistEmitter implements BlacklistRules, ClearableEmitter {
17
16
  private readonly logger;
18
- private readonly tags;
19
- private readonly lookup;
17
+ private readonly context;
20
18
  private hidden;
21
19
  private readonly hideModes;
22
- constructor(logger: Logger, tags: TagRegistryHolder, lookup: () => RegistryLookup, options: BlacklistOptions);
20
+ constructor(logger: Logger, context: PackContext, options: BlacklistOptions);
23
21
  hide(...inputs: IngredientTest[]): void;
24
22
  hideEntry<T extends RegistryId>(type: T, ...entries: RegistryIdInput<T>[]): void;
25
23
  private filterIds;
@@ -1,34 +1,32 @@
1
1
  import { arrayOrSelf } from "@adeficior/pack-resolver";
2
2
  import { uniq } from "lodash-es";
3
3
  import { encodeId } from "../common/id.js";
4
- import { createIngredient, resolveIngredientTest, } from "../common/ingredient.js";
4
+ import resolveIngredientTest from "../common/ingredient/filter.js";
5
+ import { BlockIngredient, FluidIngredient, ItemIngredient, ListIngredient, } from "../common/ingredient/index.js";
5
6
  import { IllegalShapeError } from "../error.js";
6
7
  import { toJson } from "../textHelper.js";
7
8
  export default class BlacklistEmitter {
8
9
  logger;
9
- tags;
10
- lookup;
10
+ context;
11
11
  hidden = [];
12
12
  hideModes;
13
- constructor(logger, tags, lookup, options) {
13
+ constructor(logger, context, options) {
14
14
  this.logger = logger;
15
- this.tags = tags;
16
- this.lookup = lookup;
15
+ this.context = context;
17
16
  this.hideModes = arrayOrSelf(options.hideFrom);
18
17
  }
19
18
  hide(...inputs) {
20
19
  this.hidden.push(...inputs.flatMap((test) => this.resolveIds(test)).map(encodeId));
21
20
  }
22
21
  hideEntry(type, ...entries) {
23
- const lookup = this.lookup();
24
22
  const ids = entries
25
23
  .flatMap((entry) => {
26
24
  if (typeof entry === "string") {
27
- lookup.validateEntry(type, entry);
25
+ this.context.lookup.validateEntry(type, entry);
28
26
  return [entry];
29
27
  }
30
28
  else {
31
- const keys = lookup.keys(type);
29
+ const keys = this.context.lookup.keys(type);
32
30
  if (!keys)
33
31
  throw new Error(`cannot hide using regex/predicates, registry ${encodeId(type)} not loaded`);
34
32
  return [...keys].filter((it) => entry.test(it));
@@ -38,26 +36,26 @@ export default class BlacklistEmitter {
38
36
  this.hidden.push(...ids);
39
37
  }
40
38
  filterIds(test) {
41
- const keys = this.lookup().keys("minecraft:item");
39
+ const keys = this.context.lookup.keys("minecraft:item");
42
40
  if (!keys)
43
41
  throw new Error("you can only use regex/predicates to blacklist items if a registry dump is loaded");
44
- const predicate = resolveIngredientTest(test, this.tags, this.lookup());
42
+ const predicate = resolveIngredientTest(test, this.context);
45
43
  return [...keys.keys()].filter((it) => predicate(it, this.logger));
46
44
  }
47
45
  resolveIds(input) {
48
46
  if (input instanceof RegExp || typeof input === "function") {
49
47
  return this.filterIds(input);
50
48
  }
51
- const ingredient = createIngredient(input, this.lookup());
52
- if (Array.isArray(ingredient)) {
53
- return ingredient.flatMap((it) => this.resolveIds(it));
49
+ const ingredient = this.context.ingredients.create(input);
50
+ if (ingredient instanceof ListIngredient) {
51
+ return ingredient.entries.flatMap((it) => this.resolveIds(it));
52
+ }
53
+ // TODO common super class?
54
+ if (ingredient instanceof BlockIngredient ||
55
+ ingredient instanceof FluidIngredient ||
56
+ ingredient instanceof ItemIngredient) {
57
+ return [encodeId(ingredient.id)];
54
58
  }
55
- if ("item" in ingredient)
56
- return [ingredient.item];
57
- if ("fluid" in ingredient)
58
- return [ingredient.fluid];
59
- if ("block" in ingredient)
60
- return [ingredient.block];
61
59
  throw new IllegalShapeError("illegal blacklist entry", input);
62
60
  }
63
61
  async emit(acceptor) {
@@ -77,7 +75,7 @@ export default class BlacklistEmitter {
77
75
  acceptor(path, content);
78
76
  }
79
77
  async emitPolytone(acceptor, hiddenIds) {
80
- const tabs = this.lookup().keys("minecraft:creative_mode_tab");
78
+ const tabs = this.context.lookup.keys("minecraft:creative_mode_tab");
81
79
  if (!tabs)
82
80
  throw new Error("Cannot use polytone output without creative mod tab registry");
83
81
  const content = await toJson({
@@ -1 +1 @@
1
- {"version":3,"file":"blacklist.js","sourceRoot":"","sources":["../../src/emit/blacklist.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"blacklist.js","sourceRoot":"","sources":["../../src/emit/blacklist.ts"],"names":[],"mappings":"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"}
@@ -1,8 +1,9 @@
1
1
  import type { Acceptor, Logger } from "@adeficior/pack-resolver";
2
2
  import type { IdInput, NormalizedId } from "../../common/id.js";
3
- import type { CommonTest, IngredientInput, IngredientTest, Predicate } from "../../common/ingredient.js";
4
- import type RegistryLookup from "../../loader/registry/index.js";
5
- import type { TagRegistryHolder } from "../../loader/tags.js";
3
+ import type { IngredientTest } from "../../common/ingredient/filter.js";
4
+ import type { IngredientInput } from "../../common/ingredient/input.js";
5
+ import { type CommonTest, type Predicate } from "../../common/predicates.js";
6
+ import type { PackContext } from "../../loader/context.js";
6
7
  import type { LootItemInput } from "../../parser/lootTable.js";
7
8
  import type { LootModifier, LootTable } from "../../schema/data/loot.js";
8
9
  import type { ClearableEmitter, RegistryProvider } from "../index.js";
@@ -24,13 +25,11 @@ export interface LootRules {
24
25
  export default class LootTableEmitter implements LootRules, ClearableEmitter {
25
26
  private readonly logger;
26
27
  private readonly lootTables;
27
- private readonly tags;
28
- private readonly lookup;
29
- private readonly packFormat;
28
+ private readonly context;
30
29
  private readonly customTables;
31
30
  private readonly customModifiers;
32
31
  private readonly ruled;
33
- constructor(logger: Logger, lootTables: RegistryProvider<LootTable>, tags: TagRegistryHolder, lookup: () => RegistryLookup, packFormat: number);
32
+ constructor(logger: Logger, lootTables: RegistryProvider<LootTable>, context: PackContext);
34
33
  private tablePath;
35
34
  private modifierPath;
36
35
  clear(): void;
@@ -1,6 +1,7 @@
1
1
  import { encodeId, prefix } from "../../common/id.js";
2
- import { resolveIngredientTest } from "../../common/ingredient.js";
3
- import { resolveIDTest } from "../../common/predicates.js";
2
+ import resolveIngredientTest from "../../common/ingredient/filter.js";
3
+ import { resolveIDTest, } from "../../common/predicates.js";
4
+ import { isAtLeastVersion } from "../../packFormat.js";
4
5
  import { createLootEntry, replaceItemInTable } from "../../parser/lootTable.js";
5
6
  import { EmptyLootEntry, LootTableSchema } from "../../schema/data/loot.js";
6
7
  import CustomEmitter from "../custom.js";
@@ -16,22 +17,22 @@ export const EMPTY_LOOT_MODIFIER = {
16
17
  export default class LootTableEmitter {
17
18
  logger;
18
19
  lootTables;
19
- tags;
20
- lookup;
21
- packFormat;
20
+ context;
22
21
  customTables = new CustomEmitter((it) => this.tablePath(it));
23
22
  customModifiers = new CustomEmitter((it) => this.modifierPath(it));
24
23
  ruled;
25
- constructor(logger, lootTables, tags, lookup, packFormat) {
24
+ constructor(logger, lootTables, context) {
26
25
  this.logger = logger;
27
26
  this.lootTables = lootTables;
28
- this.tags = tags;
29
- this.lookup = lookup;
30
- this.packFormat = packFormat;
31
- this.ruled = new RuledEmitter(this.logger, this.lootTables, (id) => this.tablePath(id), EMPTY_LOOT_TABLE, (id) => this.customTables.has(id));
27
+ this.context = context;
28
+ this.ruled = new RuledEmitter(this.logger, this.lootTables, (id) => this.tablePath(id), EMPTY_LOOT_TABLE,
29
+ // TODO also add value object here?
30
+ (it) => it, (id) => this.customTables.has(id));
32
31
  }
33
32
  tablePath(id) {
34
- const folder = this.packFormat > 44 ? "loot_table" : "loot_tables";
33
+ const folder = isAtLeastVersion(this.context.packFormat, "44")
34
+ ? "loot_table"
35
+ : "loot_tables";
35
36
  return `data/${id.namespace}/${folder}/${id.path}.json`;
36
37
  }
37
38
  modifierPath(id) {
@@ -50,7 +51,7 @@ export default class LootTableEmitter {
50
51
  ]);
51
52
  }
52
53
  resolveIngredientTest(test) {
53
- return resolveIngredientTest(test, this.tags, this.lookup());
54
+ return resolveIngredientTest(test, this.context);
54
55
  }
55
56
  resolveLootTableTest(test) {
56
57
  const id = [];
@@ -71,7 +72,7 @@ export default class LootTableEmitter {
71
72
  replaceOutput(from, to, additionalTests = {}) {
72
73
  const predicates = this.resolveLootTableTest(additionalTests);
73
74
  const outputPredicate = this.resolveIngredientTest(from);
74
- const replacer = replaceItemInTable(outputPredicate, createLootEntry(to, this.lookup()));
75
+ const replacer = replaceItemInTable(outputPredicate, createLootEntry(to, this.context.lookup));
75
76
  this.ruled.addRule(new LootTableRule(["replace output", from, "with", to, additionalTests], predicates.id, [outputPredicate, ...predicates.output], replacer));
76
77
  }
77
78
  removeOutput(from, additionalTests) {
@@ -1 +1 @@
1
- {"version":3,"file":"loot.js","sourceRoot":"","sources":["../../../src/emit/data/loot.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"loot.js","sourceRoot":"","sources":["../../../src/emit/data/loot.ts"],"names":[],"mappings":"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"}
@@ -1,10 +1,13 @@
1
1
  import type { RecipeSerializerId } from "@adeficior/data-modifier/generated";
2
2
  import type { Acceptor, Logger } from "@adeficior/pack-resolver";
3
3
  import type { IdInput, NormalizedId } from "../../common/id.js";
4
- import type { CommonTest, Ingredient, IngredientInput, IngredientTest, Predicate } from "../../common/ingredient.js";
5
- import type { Result, ResultInput } from "../../common/result.js";
6
- import type RegistryLookup from "../../loader/registry/index.js";
7
- import type { TagRegistryHolder } from "../../loader/tags.js";
4
+ import type { IngredientTest } from "../../common/ingredient/filter.js";
5
+ import type { IngredientInput } from "../../common/ingredient/input.js";
6
+ import { type CommonTest, type Predicate } from "../../common/predicates.js";
7
+ import type { ResultTest } from "../../common/result/filter.js";
8
+ import type { ResultInput } from "../../common/result/input.js";
9
+ import type { PackContext } from "../../loader/context.js";
10
+ import type { RecipeSerializer } from "../../parser/recipe/index.js";
8
11
  import { Recipe } from "../../parser/recipe/index.js";
9
12
  import type { RecipeDefinition } from "../../schema/data/recipe.js";
10
13
  import type { ClearableEmitter, RegistryProvider } from "../index.js";
@@ -12,35 +15,34 @@ export type RecipeTest = Readonly<{
12
15
  id?: CommonTest<NormalizedId>;
13
16
  type?: CommonTest<NormalizedId<RecipeSerializerId>>;
14
17
  namespace?: string;
15
- output?: IngredientTest;
18
+ output?: ResultTest;
16
19
  input?: IngredientTest;
17
20
  optional?: boolean;
18
21
  }>;
19
22
  export interface RecipeRules {
20
- resolveIngredientTest(test?: IngredientTest): Predicate<IngredientInput>;
21
- replaceResult(test: IngredientTest, value: Result, additionalTests?: RecipeTest): void;
22
- replaceIngredient(test: IngredientTest, value: Ingredient, additionalTests?: RecipeTest): void;
23
- add<TDefinition extends RecipeDefinition, TRecipe extends Recipe<TDefinition>>(id: IdInput, value: TDefinition | TRecipe): void;
23
+ replaceResult(test: ResultTest, value: ResultInput, additionalTests?: RecipeTest): void;
24
+ replaceIngredient(test: IngredientTest, value: IngredientInput, additionalTests?: RecipeTest): void;
25
+ add(id: IdInput, value: RecipeDefinition | Recipe): void;
24
26
  remove(test: RecipeTest): void;
25
27
  }
26
28
  export declare const EMPTY_RECIPE: RecipeDefinition;
27
29
  export default class RecipeEmitter implements RecipeRules, ClearableEmitter {
28
30
  private readonly logger;
29
31
  private readonly registry;
30
- private readonly tags;
31
- private readonly lookup;
32
- private readonly packFormat;
32
+ private readonly context;
33
+ private readonly serializer;
33
34
  private readonly custom;
34
35
  private readonly ruled;
35
- constructor(logger: Logger, registry: RegistryProvider<Recipe>, tags: TagRegistryHolder, lookup: () => RegistryLookup, packFormat: number);
36
+ constructor(logger: Logger, registry: RegistryProvider<Recipe>, context: PackContext, serializer: RecipeSerializer);
36
37
  private recipePath;
37
38
  emit(acceptor: Acceptor): Promise<void>;
38
39
  resolveIngredientTest(test?: IngredientTest): Predicate<IngredientInput>;
40
+ resolveResultTest(test?: ResultTest): Predicate<ResultInput>;
39
41
  private resolveRecipeTest;
40
- add<TDefinition extends RecipeDefinition, TRecipe extends Recipe<TDefinition>>(id: IdInput, value: TDefinition | TRecipe): void;
42
+ add(id: IdInput, value: RecipeDefinition | Recipe): void;
41
43
  private addRule;
42
44
  remove(test: RecipeTest): void;
43
- replaceResult(test: IngredientTest, value: ResultInput, additionalTest?: RecipeTest): void;
44
- replaceIngredient(test: IngredientTest, value: IngredientInput, additionalTest?: RecipeTest): void;
45
+ replaceResult(test: ResultTest, input: ResultInput, additionalTest?: RecipeTest): void;
46
+ replaceIngredient(test: IngredientTest, input: IngredientInput, additionalTest?: RecipeTest): void;
45
47
  clear(): void;
46
48
  }
@@ -1,8 +1,9 @@
1
1
  import { exists } from "@adeficior/pack-resolver";
2
2
  import { encodeId } from "../../common/id.js";
3
- import { createIngredient, resolveIngredientTest, } from "../../common/ingredient.js";
4
- import { resolveIDTest } from "../../common/predicates.js";
5
- import { createResult } from "../../common/result.js";
3
+ import resolveIngredientTest from "../../common/ingredient/filter.js";
4
+ import { resolveIDTest, } from "../../common/predicates.js";
5
+ import resolveResultTest from "../../common/result/filter.js";
6
+ import { isAtLeastVersion } from "../../packFormat.js";
6
7
  import { createReplacer, Recipe } from "../../parser/recipe/index.js";
7
8
  import CustomEmitter from "../custom.js";
8
9
  import RecipeRule from "../rule/recipe.js";
@@ -27,21 +28,21 @@ export const EMPTY_RECIPE = {
27
28
  export default class RecipeEmitter {
28
29
  logger;
29
30
  registry;
30
- tags;
31
- lookup;
32
- packFormat;
31
+ context;
32
+ serializer;
33
33
  custom = new CustomEmitter((it) => this.recipePath(it));
34
34
  ruled;
35
- constructor(logger, registry, tags, lookup, packFormat) {
35
+ constructor(logger, registry, context, serializer) {
36
36
  this.logger = logger;
37
37
  this.registry = registry;
38
- this.tags = tags;
39
- this.lookup = lookup;
40
- this.packFormat = packFormat;
41
- this.ruled = new RuledEmitter(this.logger, this.registry, (id) => this.recipePath(id), EMPTY_RECIPE, (id) => this.custom.has(id));
38
+ this.context = context;
39
+ this.serializer = serializer;
40
+ this.ruled = new RuledEmitter(this.logger, this.registry, (id) => this.recipePath(id), EMPTY_RECIPE, (it) => this.serializer.serialize(it), (id) => this.custom.has(id));
42
41
  }
43
42
  recipePath(id) {
44
- const folder = this.packFormat > 44 ? "recipe" : "recipes";
43
+ const folder = isAtLeastVersion(this.context.packFormat, "44")
44
+ ? "recipe"
45
+ : "recipes";
45
46
  return `data/${id.namespace}/${folder}/${id.path}.json`;
46
47
  }
47
48
  async emit(acceptor) {
@@ -50,7 +51,12 @@ export default class RecipeEmitter {
50
51
  resolveIngredientTest(test) {
51
52
  if (!test)
52
53
  return () => true;
53
- return resolveIngredientTest(test, this.tags, this.lookup());
54
+ return resolveIngredientTest(test, this.context);
55
+ }
56
+ resolveResultTest(test) {
57
+ if (!test)
58
+ return () => true;
59
+ return resolveResultTest(test, this.context);
54
60
  }
55
61
  resolveRecipeTest(test) {
56
62
  const id = [];
@@ -64,7 +70,7 @@ export default class RecipeEmitter {
64
70
  if (test.namespace)
65
71
  id.push((id) => id.namespace === test.namespace);
66
72
  if (test.output)
67
- result.push(this.resolveIngredientTest(test.output));
73
+ result.push(this.resolveResultTest(test.output));
68
74
  if (test.input)
69
75
  ingredient.push(this.resolveIngredientTest(test.input));
70
76
  return { id, type, ingredient, result };
@@ -73,7 +79,7 @@ export default class RecipeEmitter {
73
79
  if (this.custom.has(id))
74
80
  this.logger.error(`Overwriting custom recipe with ID ${encodeId(id)}`);
75
81
  if (value instanceof Recipe)
76
- this.custom.add(id, value.toJSON());
82
+ this.custom.add(id, this.serializer.serialize(value));
77
83
  else
78
84
  this.custom.add(id, value);
79
85
  }
@@ -84,18 +90,18 @@ export default class RecipeEmitter {
84
90
  remove(test) {
85
91
  this.addRule([test], () => null, test);
86
92
  }
87
- replaceResult(test, value, additionalTest) {
88
- const predicate = this.resolveIngredientTest(test);
89
- createResult(value, this.lookup());
93
+ replaceResult(test, input, additionalTest) {
94
+ const predicate = this.resolveResultTest(test);
95
+ const value = this.context.results.create(input);
90
96
  const replacer = createReplacer(predicate, value);
91
- const replace = (it) => createResult(replacer(it));
97
+ const replace = (it) => this.context.results.create(replacer(it));
92
98
  this.addRule(["replace result", test, "with", value, additionalTest], (recipe) => recipe.replaceResult(replace), additionalTest, { result: predicate });
93
99
  }
94
- replaceIngredient(test, value, additionalTest) {
100
+ replaceIngredient(test, input, additionalTest) {
95
101
  const predicate = this.resolveIngredientTest(test);
96
- createIngredient(value, this.lookup());
102
+ const value = this.context.ingredients.create(input);
97
103
  const replacer = createReplacer(predicate, value);
98
- const replace = (it) => createIngredient(replacer(it));
104
+ const replace = (it) => this.context.ingredients.create(replacer(it));
99
105
  this.addRule(["replace ingredient", test, "with", value, additionalTest], (recipe) => recipe.replaceIngredient(replace), additionalTest, { ingredient: predicate });
100
106
  }
101
107
  clear() {