isaacscript-common 14.1.2 → 14.2.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 (494) hide show
  1. package/dist/index.d.ts +954 -158
  2. package/dist/isaacscript-common.lua +4099 -1066
  3. package/dist/src/callbacks.d.ts +102 -20
  4. package/dist/src/callbacks.d.ts.map +1 -1
  5. package/dist/src/callbacks.lua +124 -1
  6. package/dist/src/classes/ModFeature.d.ts +16 -4
  7. package/dist/src/classes/ModFeature.d.ts.map +1 -1
  8. package/dist/src/classes/ModFeature.lua +67 -4
  9. package/dist/src/classes/ModUpgraded.d.ts +10 -10
  10. package/dist/src/classes/ModUpgraded.d.ts.map +1 -1
  11. package/dist/src/classes/ModUpgraded.lua +35 -16
  12. package/dist/src/classes/callbacks/PostCustomRevive.d.ts +5 -2
  13. package/dist/src/classes/callbacks/PostCustomRevive.d.ts.map +1 -1
  14. package/dist/src/classes/callbacks/PostCustomRevive.lua +12 -4
  15. package/dist/src/classes/callbacks/PostGridEntityBroken.lua +1 -1
  16. package/dist/src/classes/callbacks/PostGridEntityCollision.lua +1 -1
  17. package/dist/src/classes/callbacks/PostGridEntityCustomBroken.lua +1 -1
  18. package/dist/src/classes/callbacks/PostGridEntityCustomCollision.lua +1 -1
  19. package/dist/src/classes/callbacks/PostGridEntityCustomInit.lua +1 -1
  20. package/dist/src/classes/callbacks/PostGridEntityCustomRemove.lua +1 -1
  21. package/dist/src/classes/callbacks/PostGridEntityCustomRender.d.ts +6 -0
  22. package/dist/src/classes/callbacks/PostGridEntityCustomRender.d.ts.map +1 -0
  23. package/dist/src/classes/callbacks/PostGridEntityCustomRender.lua +17 -0
  24. package/dist/src/classes/callbacks/PostGridEntityCustomStateChanged.lua +1 -1
  25. package/dist/src/classes/callbacks/PostGridEntityCustomUpdate.lua +1 -1
  26. package/dist/src/classes/callbacks/PostGridEntityInit.lua +1 -1
  27. package/dist/src/classes/callbacks/PostGridEntityRemove.lua +1 -1
  28. package/dist/src/classes/callbacks/PostGridEntityRender.d.ts +6 -0
  29. package/dist/src/classes/callbacks/PostGridEntityRender.d.ts.map +1 -0
  30. package/dist/src/classes/callbacks/PostGridEntityRender.lua +17 -0
  31. package/dist/src/classes/callbacks/PostGridEntityStateChanged.lua +1 -1
  32. package/dist/src/classes/callbacks/PostGridEntityUpdate.lua +1 -1
  33. package/dist/src/classes/callbacks/PostHolyMantleRemoved.d.ts +1 -1
  34. package/dist/src/classes/callbacks/PostHolyMantleRemoved.d.ts.map +1 -1
  35. package/dist/src/classes/callbacks/PostHolyMantleRemoved.lua +3 -4
  36. package/dist/src/classes/callbacks/PostItemDischarge.d.ts +43 -0
  37. package/dist/src/classes/callbacks/PostItemDischarge.d.ts.map +1 -0
  38. package/dist/src/classes/callbacks/PostItemDischarge.lua +113 -0
  39. package/dist/src/classes/callbacks/PostItemPickup.d.ts +6 -0
  40. package/dist/src/classes/callbacks/PostItemPickup.d.ts.map +1 -0
  41. package/dist/src/classes/callbacks/PostItemPickup.lua +17 -0
  42. package/dist/src/classes/callbacks/PostLaserInitLate.d.ts +12 -0
  43. package/dist/src/classes/callbacks/PostLaserInitLate.d.ts.map +1 -0
  44. package/dist/src/classes/callbacks/PostLaserInitLate.lua +27 -0
  45. package/dist/src/classes/callbacks/PostNPCInitLate.d.ts +12 -0
  46. package/dist/src/classes/callbacks/PostNPCInitLate.d.ts.map +1 -0
  47. package/dist/src/classes/callbacks/PostNPCInitLate.lua +27 -0
  48. package/dist/src/classes/callbacks/PostNPCStateChanged.d.ts +14 -0
  49. package/dist/src/classes/callbacks/PostNPCStateChanged.d.ts.map +1 -0
  50. package/dist/src/classes/callbacks/PostNPCStateChanged.lua +33 -0
  51. package/dist/src/classes/callbacks/PostPickupCollect.d.ts +12 -0
  52. package/dist/src/classes/callbacks/PostPickupCollect.d.ts.map +1 -0
  53. package/dist/src/classes/callbacks/PostPickupCollect.lua +35 -0
  54. package/dist/src/classes/callbacks/PostPickupInitFirst.d.ts +12 -0
  55. package/dist/src/classes/callbacks/PostPickupInitFirst.d.ts.map +1 -0
  56. package/dist/src/classes/callbacks/PostPickupInitFirst.lua +32 -0
  57. package/dist/src/classes/callbacks/PostPickupInitLate.d.ts +12 -0
  58. package/dist/src/classes/callbacks/PostPickupInitLate.d.ts.map +1 -0
  59. package/dist/src/classes/callbacks/PostPickupInitLate.lua +27 -0
  60. package/dist/src/classes/callbacks/PostPickupStateChanged.d.ts +13 -0
  61. package/dist/src/classes/callbacks/PostPickupStateChanged.d.ts.map +1 -0
  62. package/dist/src/classes/callbacks/PostPickupStateChanged.lua +33 -0
  63. package/dist/src/classes/callbacks/PostPitUpdate.d.ts +7 -0
  64. package/dist/src/classes/callbacks/PostPitUpdate.d.ts.map +1 -0
  65. package/dist/src/classes/callbacks/PostPitUpdate.lua +24 -0
  66. package/dist/src/classes/callbacks/PostPlayerChangeHealth.d.ts +15 -0
  67. package/dist/src/classes/callbacks/PostPlayerChangeHealth.d.ts.map +1 -0
  68. package/dist/src/classes/callbacks/PostPlayerChangeHealth.lua +52 -0
  69. package/dist/src/classes/callbacks/PostPlayerChangeStat.d.ts +16 -0
  70. package/dist/src/classes/callbacks/PostPlayerChangeStat.d.ts.map +1 -0
  71. package/dist/src/classes/callbacks/PostPlayerChangeStat.lua +94 -0
  72. package/dist/src/classes/callbacks/PostPlayerChangeType.d.ts +15 -0
  73. package/dist/src/classes/callbacks/PostPlayerChangeType.d.ts.map +1 -0
  74. package/dist/src/classes/callbacks/PostPlayerChangeType.lua +37 -0
  75. package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.d.ts +6 -0
  76. package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.d.ts.map +1 -0
  77. package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.lua +17 -0
  78. package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.d.ts +6 -0
  79. package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.d.ts.map +1 -0
  80. package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.lua +17 -0
  81. package/dist/src/classes/callbacks/PostPlayerInitFirst.d.ts +8 -0
  82. package/dist/src/classes/callbacks/PostPlayerInitFirst.d.ts.map +1 -0
  83. package/dist/src/classes/callbacks/PostPlayerInitFirst.lua +39 -0
  84. package/dist/src/classes/callbacks/PostPlayerInitLate.d.ts +13 -0
  85. package/dist/src/classes/callbacks/PostPlayerInitLate.d.ts.map +1 -0
  86. package/dist/src/classes/callbacks/PostPlayerInitLate.lua +29 -0
  87. package/dist/src/classes/callbacks/PostPoopRender.d.ts +7 -0
  88. package/dist/src/classes/callbacks/PostPoopRender.d.ts.map +1 -0
  89. package/dist/src/classes/callbacks/PostPoopRender.lua +24 -0
  90. package/dist/src/classes/callbacks/PostPoopUpdate.d.ts +7 -0
  91. package/dist/src/classes/callbacks/PostPoopUpdate.d.ts.map +1 -0
  92. package/dist/src/classes/callbacks/PostPoopUpdate.lua +24 -0
  93. package/dist/src/classes/callbacks/PostPressurePlateRender.d.ts +7 -0
  94. package/dist/src/classes/callbacks/PostPressurePlateRender.d.ts.map +1 -0
  95. package/dist/src/classes/callbacks/PostPressurePlateRender.lua +24 -0
  96. package/dist/src/classes/callbacks/PostPressurePlateUpdate.d.ts +7 -0
  97. package/dist/src/classes/callbacks/PostPressurePlateUpdate.d.ts.map +1 -0
  98. package/dist/src/classes/callbacks/PostPressurePlateUpdate.lua +24 -0
  99. package/dist/src/classes/callbacks/PostProjectileInitLate.d.ts +12 -0
  100. package/dist/src/classes/callbacks/PostProjectileInitLate.d.ts.map +1 -0
  101. package/dist/src/classes/callbacks/PostProjectileInitLate.lua +27 -0
  102. package/dist/src/classes/callbacks/PostPurchase.d.ts +18 -0
  103. package/dist/src/classes/callbacks/PostPurchase.d.ts.map +1 -0
  104. package/dist/src/classes/callbacks/PostPurchase.lua +56 -0
  105. package/dist/src/classes/callbacks/PostRockRender.d.ts +7 -0
  106. package/dist/src/classes/callbacks/PostRockRender.d.ts.map +1 -0
  107. package/dist/src/classes/callbacks/PostRockRender.lua +24 -0
  108. package/dist/src/classes/callbacks/PostRockUpdate.d.ts +7 -0
  109. package/dist/src/classes/callbacks/PostRockUpdate.d.ts.map +1 -0
  110. package/dist/src/classes/callbacks/PostRockUpdate.lua +24 -0
  111. package/dist/src/classes/callbacks/PostSacrifice.d.ts +15 -0
  112. package/dist/src/classes/callbacks/PostSacrifice.d.ts.map +1 -0
  113. package/dist/src/classes/callbacks/PostSacrifice.lua +52 -0
  114. package/dist/src/classes/callbacks/PostSlotAnimationChanged.d.ts +6 -0
  115. package/dist/src/classes/callbacks/PostSlotAnimationChanged.d.ts.map +1 -0
  116. package/dist/src/classes/callbacks/PostSlotAnimationChanged.lua +17 -0
  117. package/dist/src/classes/callbacks/PostSlotCollision.d.ts +7 -0
  118. package/dist/src/classes/callbacks/PostSlotCollision.d.ts.map +1 -0
  119. package/dist/src/classes/callbacks/PostSlotCollision.lua +25 -0
  120. package/dist/src/classes/callbacks/PostSlotDestroyed.d.ts +14 -0
  121. package/dist/src/classes/callbacks/PostSlotDestroyed.d.ts.map +1 -0
  122. package/dist/src/classes/callbacks/PostSlotDestroyed.lua +65 -0
  123. package/dist/src/classes/callbacks/PostSlotInit.d.ts +6 -0
  124. package/dist/src/classes/callbacks/PostSlotInit.d.ts.map +1 -0
  125. package/dist/src/classes/callbacks/PostSlotInit.lua +17 -0
  126. package/dist/src/classes/callbacks/PostSlotRender.d.ts +6 -0
  127. package/dist/src/classes/callbacks/PostSlotRender.d.ts.map +1 -0
  128. package/dist/src/classes/callbacks/PostSlotRender.lua +17 -0
  129. package/dist/src/classes/callbacks/PostSlotUpdate.d.ts +6 -0
  130. package/dist/src/classes/callbacks/PostSlotUpdate.d.ts.map +1 -0
  131. package/dist/src/classes/callbacks/PostSlotUpdate.lua +17 -0
  132. package/dist/src/classes/callbacks/PostSpikesUpdate.d.ts +7 -0
  133. package/dist/src/classes/callbacks/PostSpikesUpdate.d.ts.map +1 -0
  134. package/dist/src/classes/callbacks/PostSpikesUpdate.lua +24 -0
  135. package/dist/src/classes/callbacks/PostTNTRender.d.ts +7 -0
  136. package/dist/src/classes/callbacks/PostTNTRender.d.ts.map +1 -0
  137. package/dist/src/classes/callbacks/PostTNTRender.lua +24 -0
  138. package/dist/src/classes/callbacks/PostTNTUpdate.d.ts +7 -0
  139. package/dist/src/classes/callbacks/PostTNTUpdate.d.ts.map +1 -0
  140. package/dist/src/classes/callbacks/PostTNTUpdate.lua +24 -0
  141. package/dist/src/classes/callbacks/PostTearInitLate.d.ts +12 -0
  142. package/dist/src/classes/callbacks/PostTearInitLate.d.ts.map +1 -0
  143. package/dist/src/classes/callbacks/PostTearInitLate.lua +27 -0
  144. package/dist/src/classes/callbacks/PostTearInitVeryLate.d.ts +12 -0
  145. package/dist/src/classes/callbacks/PostTearInitVeryLate.d.ts.map +1 -0
  146. package/dist/src/classes/callbacks/PostTearInitVeryLate.lua +30 -0
  147. package/dist/src/classes/callbacks/PostTransformation.d.ts +18 -0
  148. package/dist/src/classes/callbacks/PostTransformation.d.ts.map +1 -0
  149. package/dist/src/classes/callbacks/PostTransformation.lua +53 -0
  150. package/dist/src/classes/callbacks/PreBerserkDeath.d.ts +1 -1
  151. package/dist/src/classes/callbacks/PreBerserkDeath.d.ts.map +1 -1
  152. package/dist/src/classes/callbacks/PreBerserkDeath.lua +3 -4
  153. package/dist/src/classes/callbacks/PreItemPickup.d.ts +6 -0
  154. package/dist/src/classes/callbacks/PreItemPickup.d.ts.map +1 -0
  155. package/dist/src/classes/callbacks/PreItemPickup.lua +17 -0
  156. package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.d.ts +10 -0
  157. package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.d.ts.map +1 -0
  158. package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.lua +19 -0
  159. package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.d.ts +11 -0
  160. package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.d.ts.map +1 -0
  161. package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.lua +22 -0
  162. package/dist/src/classes/callbacks/validation/CustomCallbackLaser.d.ts +10 -0
  163. package/dist/src/classes/callbacks/validation/CustomCallbackLaser.d.ts.map +1 -0
  164. package/dist/src/classes/callbacks/validation/CustomCallbackLaser.lua +19 -0
  165. package/dist/src/classes/callbacks/validation/{CustomCallbackRevive.d.ts → CustomCallbackNPC.d.ts} +4 -4
  166. package/dist/src/classes/callbacks/validation/CustomCallbackNPC.d.ts.map +1 -0
  167. package/dist/src/classes/callbacks/validation/CustomCallbackNPC.lua +22 -0
  168. package/dist/src/classes/callbacks/validation/CustomCallbackPickup.d.ts +12 -0
  169. package/dist/src/classes/callbacks/validation/CustomCallbackPickup.d.ts.map +1 -0
  170. package/dist/src/classes/callbacks/validation/CustomCallbackPickup.lua +22 -0
  171. package/dist/src/classes/callbacks/validation/CustomCallbackPlayer.d.ts +5 -2
  172. package/dist/src/classes/callbacks/validation/CustomCallbackPlayer.d.ts.map +1 -1
  173. package/dist/src/classes/callbacks/validation/CustomCallbackPoop.d.ts +10 -0
  174. package/dist/src/classes/callbacks/validation/CustomCallbackPoop.d.ts.map +1 -0
  175. package/dist/src/classes/callbacks/validation/CustomCallbackPoop.lua +20 -0
  176. package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.d.ts +10 -0
  177. package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.d.ts.map +1 -0
  178. package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.lua +20 -0
  179. package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.d.ts +10 -0
  180. package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.d.ts.map +1 -0
  181. package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.lua +19 -0
  182. package/dist/src/classes/callbacks/validation/CustomCallbackRock.d.ts +10 -0
  183. package/dist/src/classes/callbacks/validation/CustomCallbackRock.d.ts.map +1 -0
  184. package/dist/src/classes/callbacks/validation/CustomCallbackRock.lua +20 -0
  185. package/dist/src/classes/callbacks/validation/CustomCallbackSlot.d.ts +12 -0
  186. package/dist/src/classes/callbacks/validation/CustomCallbackSlot.d.ts.map +1 -0
  187. package/dist/src/classes/callbacks/validation/CustomCallbackSlot.lua +19 -0
  188. package/dist/src/classes/callbacks/validation/CustomCallbackSpikes.lua +4 -4
  189. package/dist/src/classes/callbacks/validation/CustomCallbackTNT.d.ts +10 -0
  190. package/dist/src/classes/callbacks/validation/CustomCallbackTNT.d.ts.map +1 -0
  191. package/dist/src/classes/callbacks/validation/CustomCallbackTNT.lua +20 -0
  192. package/dist/src/classes/callbacks/validation/CustomCallbackTear.d.ts +10 -0
  193. package/dist/src/classes/callbacks/validation/CustomCallbackTear.d.ts.map +1 -0
  194. package/dist/src/classes/callbacks/validation/CustomCallbackTear.lua +19 -0
  195. package/dist/src/classes/features/callbackLogic/CustomGridEntities.d.ts +1 -1
  196. package/dist/src/classes/features/callbackLogic/CustomGridEntities.d.ts.map +1 -1
  197. package/dist/src/classes/features/callbackLogic/CustomGridEntities.lua +27 -30
  198. package/dist/src/classes/features/callbackLogic/CustomRevive.d.ts +2 -2
  199. package/dist/src/classes/features/callbackLogic/CustomRevive.d.ts.map +1 -1
  200. package/dist/src/classes/features/callbackLogic/CustomRevive.lua +6 -6
  201. package/dist/src/classes/features/callbackLogic/EsauJrDetection.d.ts.map +1 -1
  202. package/dist/src/classes/features/callbackLogic/GameReorderedCallbacks.d.ts.map +1 -1
  203. package/dist/src/classes/features/callbackLogic/GameReorderedCallbacks.lua +3 -18
  204. package/dist/src/classes/features/callbackLogic/GridEntityCollisionDetection.d.ts.map +1 -1
  205. package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.d.ts +12 -0
  206. package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.d.ts.map +1 -0
  207. package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.lua +33 -0
  208. package/dist/src/classes/features/callbackLogic/{GridEntityDetection.d.ts → GridEntityUpdateDetection.d.ts} +3 -3
  209. package/dist/src/classes/features/callbackLogic/GridEntityUpdateDetection.d.ts.map +1 -0
  210. package/dist/src/classes/features/callbackLogic/{GridEntityDetection.lua → GridEntityUpdateDetection.lua} +11 -14
  211. package/dist/src/classes/features/callbackLogic/ItemPickupDetection.d.ts +20 -0
  212. package/dist/src/classes/features/callbackLogic/ItemPickupDetection.d.ts.map +1 -0
  213. package/dist/src/classes/features/callbackLogic/ItemPickupDetection.lua +60 -0
  214. package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.d.ts +47 -0
  215. package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.d.ts.map +1 -0
  216. package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.lua +154 -0
  217. package/dist/src/classes/features/callbackLogic/SlotRenderDetection.d.ts +18 -0
  218. package/dist/src/classes/features/callbackLogic/SlotRenderDetection.d.ts.map +1 -0
  219. package/dist/src/classes/features/callbackLogic/SlotRenderDetection.lua +51 -0
  220. package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.d.ts +17 -0
  221. package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.d.ts.map +1 -0
  222. package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.lua +45 -0
  223. package/dist/src/classes/features/other/RunInNFrames.d.ts.map +1 -1
  224. package/dist/src/classes/features/other/RunInNFrames.lua +9 -0
  225. package/dist/src/classes/features/other/SaveDataManager.d.ts +215 -0
  226. package/dist/src/classes/features/other/SaveDataManager.d.ts.map +1 -0
  227. package/dist/src/classes/features/other/SaveDataManager.lua +190 -0
  228. package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.d.ts +6 -0
  229. package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.d.ts.map +1 -0
  230. package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.lua +98 -0
  231. package/dist/src/classes/features/other/saveDataManager/loadFromDisk.d.ts +6 -0
  232. package/dist/src/classes/features/other/saveDataManager/loadFromDisk.d.ts.map +1 -0
  233. package/dist/src/classes/features/other/saveDataManager/loadFromDisk.lua +81 -0
  234. package/dist/src/classes/features/other/saveDataManager/restoreDefaults.d.ts +7 -0
  235. package/dist/src/classes/features/other/saveDataManager/restoreDefaults.d.ts.map +1 -0
  236. package/dist/src/classes/features/other/saveDataManager/restoreDefaults.lua +69 -0
  237. package/dist/src/classes/features/other/saveDataManager/saveToDisk.d.ts +5 -0
  238. package/dist/src/classes/features/other/saveDataManager/saveToDisk.d.ts.map +1 -0
  239. package/dist/src/classes/features/other/saveDataManager/saveToDisk.lua +46 -0
  240. package/dist/src/classes/private/CustomCallback.d.ts +2 -3
  241. package/dist/src/classes/private/CustomCallback.d.ts.map +1 -1
  242. package/dist/src/classes/private/CustomCallback.lua +2 -5
  243. package/dist/src/classes/private/Feature.d.ts +1 -0
  244. package/dist/src/classes/private/Feature.d.ts.map +1 -1
  245. package/dist/src/classes/private/Feature.lua +1 -0
  246. package/dist/src/core/upgradeMod.d.ts +2 -5
  247. package/dist/src/core/upgradeMod.d.ts.map +1 -1
  248. package/dist/src/decorators.d.ts +1 -1
  249. package/dist/src/decorators.d.ts.map +1 -1
  250. package/dist/src/decorators.lua +6 -8
  251. package/dist/src/enums/ISCFeature.d.ts +15 -9
  252. package/dist/src/enums/ISCFeature.d.ts.map +1 -1
  253. package/dist/src/enums/ISCFeature.lua +30 -9
  254. package/dist/src/enums/ModCallbackCustom.d.ts +34 -20
  255. package/dist/src/enums/ModCallbackCustom.d.ts.map +1 -1
  256. package/dist/src/enums/ModCallbackCustom2.d.ts +61 -20
  257. package/dist/src/enums/ModCallbackCustom2.d.ts.map +1 -1
  258. package/dist/src/enums/ModCallbackCustom2.lua +102 -20
  259. package/dist/src/enums/{private/SerializationBrand.d.ts → SerializationBrand.d.ts} +6 -1
  260. package/dist/src/enums/SerializationBrand.d.ts.map +1 -0
  261. package/dist/src/enums/{private/SerializationBrand.lua → SerializationBrand.lua} +1 -0
  262. package/dist/src/features/customItemPool.d.ts +52 -0
  263. package/dist/src/features/customItemPool.d.ts.map +1 -0
  264. package/dist/src/features/customItemPool.lua +111 -0
  265. package/dist/src/features/deployJSONRoom.d.ts +6 -4
  266. package/dist/src/features/deployJSONRoom.d.ts.map +1 -1
  267. package/dist/src/features/deployJSONRoom.lua +6 -4
  268. package/dist/src/features/fadeInRemover.d.ts.map +1 -1
  269. package/dist/src/features/fadeInRemover.lua +4 -16
  270. package/dist/src/features/saveDataManager/exports.d.ts +14 -4
  271. package/dist/src/features/saveDataManager/exports.d.ts.map +1 -1
  272. package/dist/src/features/saveDataManager/exports.lua +38 -0
  273. package/dist/src/features/saveDataManager/load.d.ts +2 -1
  274. package/dist/src/features/saveDataManager/load.d.ts.map +1 -1
  275. package/dist/src/features/saveDataManager/load.lua +10 -4
  276. package/dist/src/features/saveDataManager/main.d.ts.map +1 -1
  277. package/dist/src/features/saveDataManager/main.lua +12 -5
  278. package/dist/src/features/saveDataManager/maps.d.ts +14 -0
  279. package/dist/src/features/saveDataManager/maps.d.ts.map +1 -1
  280. package/dist/src/features/saveDataManager/maps.lua +7 -0
  281. package/dist/src/features.d.ts +31 -12
  282. package/dist/src/features.d.ts.map +1 -1
  283. package/dist/src/features.lua +24 -6
  284. package/dist/src/functions/array.d.ts.map +1 -1
  285. package/dist/src/functions/array.lua +4 -5
  286. package/dist/src/functions/bitSet128.d.ts +2 -2
  287. package/dist/src/functions/bitSet128.lua +3 -3
  288. package/dist/src/functions/color.d.ts +2 -2
  289. package/dist/src/functions/color.lua +3 -3
  290. package/dist/src/functions/decorators.d.ts +28 -6
  291. package/dist/src/functions/decorators.d.ts.map +1 -1
  292. package/dist/src/functions/decorators.lua +24 -5
  293. package/dist/src/functions/deepCopy.d.ts +11 -4
  294. package/dist/src/functions/deepCopy.d.ts.map +1 -1
  295. package/dist/src/functions/deepCopy.lua +84 -32
  296. package/dist/src/functions/deepCopyTests.lua +1 -1
  297. package/dist/src/functions/initArray.d.ts +4 -4
  298. package/dist/src/functions/initArray.d.ts.map +1 -1
  299. package/dist/src/functions/initArray.lua +6 -12
  300. package/dist/src/functions/jsonRoom.d.ts +11 -0
  301. package/dist/src/functions/jsonRoom.d.ts.map +1 -1
  302. package/dist/src/functions/jsonRoom.lua +11 -0
  303. package/dist/src/functions/kColor.d.ts +2 -2
  304. package/dist/src/functions/kColor.lua +3 -3
  305. package/dist/src/functions/logMisc.d.ts +9 -2
  306. package/dist/src/functions/logMisc.d.ts.map +1 -1
  307. package/dist/src/functions/logMisc.lua +32 -2
  308. package/dist/src/functions/merge.d.ts +40 -0
  309. package/dist/src/functions/merge.d.ts.map +1 -0
  310. package/dist/src/{features/saveDataManager → functions}/merge.lua +84 -37
  311. package/dist/src/functions/mergeTests.d.ts +1 -2
  312. package/dist/src/functions/mergeTests.d.ts.map +1 -1
  313. package/dist/src/functions/mergeTests.lua +3 -4
  314. package/dist/src/functions/rng.d.ts +2 -2
  315. package/dist/src/functions/rng.lua +3 -3
  316. package/dist/src/functions/serialization.d.ts.map +1 -1
  317. package/dist/src/functions/serialization.lua +22 -0
  318. package/dist/src/functions/tstlClass.d.ts +0 -10
  319. package/dist/src/functions/tstlClass.d.ts.map +1 -1
  320. package/dist/src/functions/tstlClass.lua +2 -42
  321. package/dist/src/functions/vector.d.ts +2 -2
  322. package/dist/src/functions/vector.lua +3 -3
  323. package/dist/src/functions/weighted.d.ts +12 -1
  324. package/dist/src/functions/weighted.d.ts.map +1 -1
  325. package/dist/src/functions/weighted.lua +27 -10
  326. package/dist/src/index.d.ts +5 -0
  327. package/dist/src/index.d.ts.map +1 -1
  328. package/dist/src/index.lua +24 -0
  329. package/dist/src/interfaces/SaveData.d.ts +3 -7
  330. package/dist/src/interfaces/SaveData.d.ts.map +1 -1
  331. package/dist/src/interfaces/SaveData.lua +0 -11
  332. package/dist/src/interfaces/private/AddCallbackParametersCustom2.d.ts +195 -2
  333. package/dist/src/interfaces/private/AddCallbackParametersCustom2.d.ts.map +1 -1
  334. package/dist/src/objects/isaacAPIClassTypeToBrand.d.ts +1 -1
  335. package/dist/src/objects/isaacAPIClassTypeToBrand.d.ts.map +1 -1
  336. package/dist/src/objects/isaacAPIClassTypeToBrand.lua +1 -1
  337. package/dist/src/types/AnyClass.d.ts +2 -0
  338. package/dist/src/types/AnyClass.d.ts.map +1 -0
  339. package/dist/src/types/AnyClass.lua +2 -0
  340. package/dist/src/types/AnyFunction.d.ts +6 -0
  341. package/dist/src/types/AnyFunction.d.ts.map +1 -0
  342. package/dist/src/types/AnyFunction.lua +2 -0
  343. package/dist/src/types/FunctionTuple.d.ts +2 -4
  344. package/dist/src/types/FunctionTuple.d.ts.map +1 -1
  345. package/dist/src/types/HasFunction.d.ts +5 -0
  346. package/dist/src/types/HasFunction.d.ts.map +1 -0
  347. package/dist/src/types/HasFunction.lua +2 -0
  348. package/package.json +1 -1
  349. package/src/callbacks.ts +88 -5
  350. package/src/classes/ModFeature.ts +96 -6
  351. package/src/classes/ModUpgraded.ts +57 -32
  352. package/src/classes/callbacks/PostCustomRevive.ts +22 -2
  353. package/src/classes/callbacks/PostGridEntityBroken.ts +1 -1
  354. package/src/classes/callbacks/PostGridEntityCollision.ts +1 -1
  355. package/src/classes/callbacks/PostGridEntityCustomBroken.ts +1 -1
  356. package/src/classes/callbacks/PostGridEntityCustomCollision.ts +1 -1
  357. package/src/classes/callbacks/PostGridEntityCustomInit.ts +1 -1
  358. package/src/classes/callbacks/PostGridEntityCustomRemove.ts +1 -1
  359. package/src/classes/callbacks/PostGridEntityCustomRender.ts +11 -0
  360. package/src/classes/callbacks/PostGridEntityCustomStateChanged.ts +1 -1
  361. package/src/classes/callbacks/PostGridEntityCustomUpdate.ts +1 -1
  362. package/src/classes/callbacks/PostGridEntityInit.ts +1 -1
  363. package/src/classes/callbacks/PostGridEntityRemove.ts +1 -1
  364. package/src/classes/callbacks/PostGridEntityRender.ts +11 -0
  365. package/src/classes/callbacks/PostGridEntityStateChanged.ts +1 -1
  366. package/src/classes/callbacks/PostGridEntityUpdate.ts +1 -1
  367. package/src/classes/callbacks/PostHolyMantleRemoved.ts +5 -8
  368. package/src/classes/callbacks/PostItemDischarge.ts +181 -0
  369. package/src/classes/callbacks/PostItemPickup.ts +11 -0
  370. package/src/classes/callbacks/PostLaserInitLate.ts +28 -0
  371. package/src/classes/callbacks/PostNPCInitLate.ts +28 -0
  372. package/src/classes/callbacks/PostNPCStateChanged.ts +37 -0
  373. package/src/classes/callbacks/PostPickupCollect.ts +37 -0
  374. package/src/classes/callbacks/PostPickupInitFirst.ts +34 -0
  375. package/src/classes/callbacks/PostPickupInitLate.ts +28 -0
  376. package/src/classes/callbacks/PostPickupStateChanged.ts +35 -0
  377. package/src/classes/callbacks/PostPitUpdate.ts +21 -0
  378. package/src/classes/callbacks/PostPlayerChangeHealth.ts +57 -0
  379. package/src/classes/callbacks/PostPlayerChangeStat.ts +102 -0
  380. package/src/classes/callbacks/PostPlayerChangeType.ts +44 -0
  381. package/src/classes/callbacks/PostPlayerCollectibleAdded.ts +11 -0
  382. package/src/classes/callbacks/PostPlayerCollectibleRemoved.ts +11 -0
  383. package/src/classes/callbacks/PostPlayerInitFirst.ts +44 -0
  384. package/src/classes/callbacks/PostPlayerInitLate.ts +32 -0
  385. package/src/classes/callbacks/PostPoopRender.ts +21 -0
  386. package/src/classes/callbacks/PostPoopUpdate.ts +21 -0
  387. package/src/classes/callbacks/PostPressurePlateRender.ts +21 -0
  388. package/src/classes/callbacks/PostPressurePlateUpdate.ts +21 -0
  389. package/src/classes/callbacks/PostProjectileInitLate.ts +28 -0
  390. package/src/classes/callbacks/PostPurchase.ts +87 -0
  391. package/src/classes/callbacks/PostRockRender.ts +21 -0
  392. package/src/classes/callbacks/PostRockUpdate.ts +21 -0
  393. package/src/classes/callbacks/PostSacrifice.ts +89 -0
  394. package/src/classes/callbacks/PostSlotAnimationChanged.ts +11 -0
  395. package/src/classes/callbacks/PostSlotCollision.ts +26 -0
  396. package/src/classes/callbacks/PostSlotDestroyed.ts +79 -0
  397. package/src/classes/callbacks/PostSlotInit.ts +11 -0
  398. package/src/classes/callbacks/PostSlotRender.ts +11 -0
  399. package/src/classes/callbacks/PostSlotUpdate.ts +11 -0
  400. package/src/classes/callbacks/PostSpikesUpdate.ts +21 -0
  401. package/src/classes/callbacks/PostTNTRender.ts +21 -0
  402. package/src/classes/callbacks/PostTNTUpdate.ts +21 -0
  403. package/src/classes/callbacks/PostTearInitLate.ts +28 -0
  404. package/src/classes/callbacks/PostTearInitVeryLate.ts +33 -0
  405. package/src/classes/callbacks/PostTransformation.ts +71 -0
  406. package/src/classes/callbacks/PreBerserkDeath.ts +5 -8
  407. package/src/classes/callbacks/PreItemPickup.ts +11 -0
  408. package/src/classes/callbacks/validation/CustomCallbackCollectibleType.ts +32 -0
  409. package/src/classes/callbacks/validation/CustomCallbackItemPickup.ts +48 -0
  410. package/src/classes/callbacks/validation/CustomCallbackLaser.ts +27 -0
  411. package/src/classes/callbacks/validation/CustomCallbackNPC.ts +34 -0
  412. package/src/classes/callbacks/validation/CustomCallbackPickup.ts +41 -0
  413. package/src/classes/callbacks/validation/CustomCallbackPlayer.ts +25 -2
  414. package/src/classes/callbacks/validation/CustomCallbackPoop.ts +28 -0
  415. package/src/classes/callbacks/validation/CustomCallbackPressurePlate.ts +31 -0
  416. package/src/classes/callbacks/validation/CustomCallbackProjectile.ts +28 -0
  417. package/src/classes/callbacks/validation/CustomCallbackRock.ts +30 -0
  418. package/src/classes/callbacks/validation/CustomCallbackSlot.ts +37 -0
  419. package/src/classes/callbacks/validation/CustomCallbackSpikes.ts +4 -4
  420. package/src/classes/callbacks/validation/CustomCallbackTNT.ts +28 -0
  421. package/src/classes/callbacks/validation/CustomCallbackTear.ts +27 -0
  422. package/src/classes/features/callbackLogic/CustomGridEntities.ts +32 -36
  423. package/src/classes/features/callbackLogic/CustomRevive.ts +14 -21
  424. package/src/classes/features/callbackLogic/EsauJrDetection.ts +0 -4
  425. package/src/classes/features/callbackLogic/GameReorderedCallbacks.ts +7 -9
  426. package/src/classes/features/callbackLogic/GridEntityCollisionDetection.ts +0 -4
  427. package/src/classes/features/callbackLogic/GridEntityRenderDetection.ts +42 -0
  428. package/src/classes/features/callbackLogic/{GridEntityDetection.ts → GridEntityUpdateDetection.ts} +4 -20
  429. package/src/classes/features/callbackLogic/ItemPickupDetection.ts +91 -0
  430. package/src/classes/features/callbackLogic/PlayerCollectibleDetection.ts +245 -0
  431. package/src/classes/features/callbackLogic/SlotRenderDetection.ts +64 -0
  432. package/src/classes/features/callbackLogic/SlotUpdateDetection.ts +57 -0
  433. package/src/classes/features/other/RunInNFrames.ts +7 -0
  434. package/src/classes/features/other/SaveDataManager.ts +492 -0
  435. package/src/classes/features/other/saveDataManager/glowingHourGlass.ts +138 -0
  436. package/src/classes/features/other/saveDataManager/loadFromDisk.ts +99 -0
  437. package/src/classes/features/other/saveDataManager/restoreDefaults.ts +116 -0
  438. package/src/classes/features/other/saveDataManager/saveToDisk.ts +70 -0
  439. package/src/classes/private/CustomCallback.ts +2 -6
  440. package/src/classes/private/Feature.ts +1 -0
  441. package/src/core/upgradeMod.ts +6 -13
  442. package/src/decorators.ts +17 -16
  443. package/src/enums/ISCFeature.ts +44 -39
  444. package/src/enums/ModCallbackCustom.ts +34 -20
  445. package/src/enums/ModCallbackCustom2.ts +53 -5
  446. package/src/enums/{private/SerializationBrand.ts → SerializationBrand.ts} +8 -2
  447. package/src/features/customItemPool.ts +133 -0
  448. package/src/features/deployJSONRoom.ts +6 -4
  449. package/src/features/fadeInRemover.ts +4 -22
  450. package/src/features/saveDataManager/exports.ts +62 -3
  451. package/src/features/saveDataManager/load.ts +4 -1
  452. package/src/features/saveDataManager/main.ts +5 -3
  453. package/src/features/saveDataManager/maps.ts +16 -0
  454. package/src/features.ts +39 -4
  455. package/src/functions/array.ts +8 -9
  456. package/src/functions/bitSet128.ts +3 -3
  457. package/src/functions/color.ts +3 -3
  458. package/src/functions/decorators.ts +83 -12
  459. package/src/functions/deepCopy.ts +83 -17
  460. package/src/functions/deepCopyTests.ts +1 -1
  461. package/src/functions/initArray.ts +6 -11
  462. package/src/functions/jsonRoom.ts +11 -0
  463. package/src/functions/kColor.ts +3 -3
  464. package/src/functions/logMisc.ts +28 -2
  465. package/src/{features/saveDataManager → functions}/merge.ts +79 -45
  466. package/src/functions/mergeTests.ts +2 -3
  467. package/src/functions/rng.ts +3 -3
  468. package/src/functions/serialization.ts +25 -1
  469. package/src/functions/table.ts +1 -1
  470. package/src/functions/tstlClass.ts +3 -57
  471. package/src/functions/vector.ts +3 -3
  472. package/src/functions/weighted.ts +28 -11
  473. package/src/index.ts +5 -0
  474. package/src/interfaces/SaveData.ts +3 -34
  475. package/src/interfaces/private/AddCallbackParametersCustom2.ts +298 -7
  476. package/src/objects/isaacAPIClassTypeToBrand.ts +1 -1
  477. package/src/types/AnyClass.ts +1 -0
  478. package/src/types/AnyFunction.ts +5 -0
  479. package/src/types/FunctionTuple.ts +3 -4
  480. package/src/types/HasFunction.ts +7 -0
  481. package/dist/src/classes/callbacks/validation/CustomCallbackRevive.d.ts.map +0 -1
  482. package/dist/src/classes/callbacks/validation/CustomCallbackRevive.lua +0 -19
  483. package/dist/src/classes/features/callbackLogic/GridEntityDetection.d.ts.map +0 -1
  484. package/dist/src/enums/private/SerializationBrand.d.ts.map +0 -1
  485. package/dist/src/features/saveDataManager/merge.d.ts +0 -26
  486. package/dist/src/features/saveDataManager/merge.d.ts.map +0 -1
  487. package/dist/src/features/saveDataManager/serializationBrands.d.ts +0 -2
  488. package/dist/src/features/saveDataManager/serializationBrands.d.ts.map +0 -1
  489. package/dist/src/features/saveDataManager/serializationBrands.lua +0 -19
  490. package/dist/src/indexLua.d.ts +0 -199
  491. package/dist/src/indexLua.d.ts.map +0 -1
  492. package/dist/src/indexLua.lua +0 -1354
  493. package/src/classes/callbacks/validation/CustomCallbackRevive.ts +0 -27
  494. package/src/features/saveDataManager/serializationBrands.ts +0 -16
package/src/callbacks.ts CHANGED
@@ -27,26 +27,67 @@ import { PostGridEntityCustomBroken } from "./classes/callbacks/PostGridEntityCu
27
27
  import { PostGridEntityCustomCollision } from "./classes/callbacks/PostGridEntityCustomCollision";
28
28
  import { PostGridEntityCustomInit } from "./classes/callbacks/PostGridEntityCustomInit";
29
29
  import { PostGridEntityCustomRemove } from "./classes/callbacks/PostGridEntityCustomRemove";
30
+ import { PostGridEntityCustomRender } from "./classes/callbacks/PostGridEntityCustomRender";
30
31
  import { PostGridEntityCustomStateChanged } from "./classes/callbacks/PostGridEntityCustomStateChanged";
31
32
  import { PostGridEntityCustomUpdate } from "./classes/callbacks/PostGridEntityCustomUpdate";
32
33
  import { PostGridEntityInit } from "./classes/callbacks/PostGridEntityInit";
33
34
  import { PostGridEntityRemove } from "./classes/callbacks/PostGridEntityRemove";
35
+ import { PostGridEntityRender } from "./classes/callbacks/PostGridEntityRender";
34
36
  import { PostGridEntityStateChanged } from "./classes/callbacks/PostGridEntityStateChanged";
35
37
  import { PostGridEntityUpdate } from "./classes/callbacks/PostGridEntityUpdate";
36
38
  import { PostHolyMantleRemoved } from "./classes/callbacks/PostHolyMantleRemoved";
39
+ import { PostItemDischarge } from "./classes/callbacks/PostItemDischarge";
40
+ import { PostItemPickup } from "./classes/callbacks/PostItemPickup";
37
41
  import { PostKnifeInitLate } from "./classes/callbacks/PostKnifeInitLate";
42
+ import { PostLaserInitLate } from "./classes/callbacks/PostLaserInitLate";
38
43
  import { PostNewLevelReordered } from "./classes/callbacks/PostNewLevelReordered";
39
44
  import { PostNewRoomEarly } from "./classes/callbacks/PostNewRoomEarly";
40
45
  import { PostNewRoomReordered } from "./classes/callbacks/PostNewRoomReordered";
46
+ import { PostNPCInitLate } from "./classes/callbacks/PostNPCInitLate";
47
+ import { PostNPCStateChanged } from "./classes/callbacks/PostNPCStateChanged";
41
48
  import { PostPEffectUpdateReordered } from "./classes/callbacks/PostPEffectUpdateReordered";
49
+ import { PostPickupCollect } from "./classes/callbacks/PostPickupCollect";
50
+ import { PostPickupInitFirst } from "./classes/callbacks/PostPickupInitFirst";
51
+ import { PostPickupInitLate } from "./classes/callbacks/PostPickupInitLate";
52
+ import { PostPickupStateChanged } from "./classes/callbacks/PostPickupStateChanged";
42
53
  import { PostPitRender } from "./classes/callbacks/PostPitRender";
54
+ import { PostPitUpdate } from "./classes/callbacks/PostPitUpdate";
55
+ import { PostPlayerChangeHealth } from "./classes/callbacks/PostPlayerChangeHealth";
56
+ import { PostPlayerChangeStat } from "./classes/callbacks/PostPlayerChangeStat";
57
+ import { PostPlayerChangeType } from "./classes/callbacks/PostPlayerChangeType";
58
+ import { PostPlayerCollectibleAdded } from "./classes/callbacks/PostPlayerCollectibleAdded";
59
+ import { PostPlayerCollectibleRemoved } from "./classes/callbacks/PostPlayerCollectibleRemoved";
43
60
  import { PostPlayerFatalDamage } from "./classes/callbacks/PostPlayerFatalDamage";
61
+ import { PostPlayerInitFirst } from "./classes/callbacks/PostPlayerInitFirst";
62
+ import { PostPlayerInitLate } from "./classes/callbacks/PostPlayerInitLate";
44
63
  import { PostPlayerRenderReordered } from "./classes/callbacks/PostPlayerRenderReordered";
45
64
  import { PostPlayerUpdateReordered } from "./classes/callbacks/PostPlayerUpdateReordered";
65
+ import { PostPoopRender } from "./classes/callbacks/PostPoopRender";
66
+ import { PostPoopUpdate } from "./classes/callbacks/PostPoopUpdate";
67
+ import { PostPressurePlateRender } from "./classes/callbacks/PostPressurePlateRender";
68
+ import { PostPressurePlateUpdate } from "./classes/callbacks/PostPressurePlateUpdate";
69
+ import { PostProjectileInitLate } from "./classes/callbacks/PostProjectileInitLate";
70
+ import { PostPurchase } from "./classes/callbacks/PostPurchase";
71
+ import { PostRockRender } from "./classes/callbacks/PostRockRender";
72
+ import { PostRockUpdate } from "./classes/callbacks/PostRockUpdate";
46
73
  import { PostRoomClearChanged } from "./classes/callbacks/PostRoomClearChanged";
74
+ import { PostSacrifice } from "./classes/callbacks/PostSacrifice";
75
+ import { PostSlotAnimationChanged } from "./classes/callbacks/PostSlotAnimationChanged";
76
+ import { PostSlotCollision } from "./classes/callbacks/PostSlotCollision";
77
+ import { PostSlotDestroyed } from "./classes/callbacks/PostSlotDestroyed";
78
+ import { PostSlotInit } from "./classes/callbacks/PostSlotInit";
79
+ import { PostSlotRender } from "./classes/callbacks/PostSlotRender";
80
+ import { PostSlotUpdate } from "./classes/callbacks/PostSlotUpdate";
47
81
  import { PostSpikesRender } from "./classes/callbacks/PostSpikesRender";
82
+ import { PostSpikesUpdate } from "./classes/callbacks/PostSpikesUpdate";
83
+ import { PostTearInitLate } from "./classes/callbacks/PostTearInitLate";
84
+ import { PostTearInitVeryLate } from "./classes/callbacks/PostTearInitVeryLate";
85
+ import { PostTNTRender } from "./classes/callbacks/PostTNTRender";
86
+ import { PostTNTUpdate } from "./classes/callbacks/PostTNTUpdate";
87
+ import { PostTransformation } from "./classes/callbacks/PostTransformation";
48
88
  import { PreBerserkDeath } from "./classes/callbacks/PreBerserkDeath";
49
89
  import { PreCustomRevive } from "./classes/callbacks/PreCustomRevive";
90
+ import { PreItemPickup } from "./classes/callbacks/PreItemPickup";
50
91
  import { ModCallbackCustom2 } from "./enums/ModCallbackCustom2";
51
92
  import { getEnumValues } from "./functions/enums";
52
93
  import { newObjectWithEnumKeys } from "./functions/utils";
@@ -85,35 +126,77 @@ const MOD_CALLBACK_CUSTOM_TO_CLASS = newObjectWithEnumKeys(ModCallbackCustom2, {
85
126
  [ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_INIT]: PostGridEntityCustomInit,
86
127
  [ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_REMOVE]:
87
128
  PostGridEntityCustomRemove,
88
- // [ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_RENDER]: new PostGridEntityCustomRender(),
129
+ [ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_RENDER]:
130
+ PostGridEntityCustomRender,
89
131
  [ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_STATE_CHANGED]:
90
132
  PostGridEntityCustomStateChanged,
91
133
  [ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_UPDATE]:
92
134
  PostGridEntityCustomUpdate,
93
135
  [ModCallbackCustom2.POST_GRID_ENTITY_INIT]: PostGridEntityInit,
94
136
  [ModCallbackCustom2.POST_GRID_ENTITY_REMOVE]: PostGridEntityRemove,
95
- // [ModCallbackCustom2.POST_GRID_ENTITY_RENDER]: new PostGridEntityRender(),
137
+ [ModCallbackCustom2.POST_GRID_ENTITY_RENDER]: PostGridEntityRender,
96
138
  [ModCallbackCustom2.POST_GRID_ENTITY_STATE_CHANGED]:
97
139
  PostGridEntityStateChanged,
98
140
  [ModCallbackCustom2.POST_GRID_ENTITY_UPDATE]: PostGridEntityUpdate,
99
141
  [ModCallbackCustom2.POST_HOLY_MANTLE_REMOVED]: PostHolyMantleRemoved,
100
-
101
- // ----------------
102
-
142
+ [ModCallbackCustom2.POST_ITEM_DISCHARGE]: PostItemDischarge,
143
+ [ModCallbackCustom2.POST_ITEM_PICKUP]: PostItemPickup,
103
144
  [ModCallbackCustom2.POST_KNIFE_INIT_LATE]: PostKnifeInitLate,
145
+ [ModCallbackCustom2.POST_LASER_INIT_LATE]: PostLaserInitLate,
104
146
  [ModCallbackCustom2.POST_NEW_LEVEL_REORDERED]: PostNewLevelReordered,
105
147
  [ModCallbackCustom2.POST_NEW_ROOM_EARLY]: PostNewRoomEarly,
106
148
  [ModCallbackCustom2.POST_NEW_ROOM_REORDERED]: PostNewRoomReordered,
149
+ [ModCallbackCustom2.POST_NPC_INIT_LATE]: PostNPCInitLate,
150
+ [ModCallbackCustom2.POST_NPC_STATE_CHANGED]: PostNPCStateChanged,
107
151
  [ModCallbackCustom2.POST_PEFFECT_UPDATE_REORDERED]:
108
152
  PostPEffectUpdateReordered,
153
+ [ModCallbackCustom2.POST_PICKUP_COLLECT]: PostPickupCollect,
154
+ [ModCallbackCustom2.POST_PICKUP_INIT_FIRST]: PostPickupInitFirst,
155
+ [ModCallbackCustom2.POST_PICKUP_INIT_LATE]: PostPickupInitLate,
156
+ [ModCallbackCustom2.POST_PICKUP_STATE_CHANGED]: PostPickupStateChanged,
109
157
  [ModCallbackCustom2.POST_PIT_RENDER]: PostPitRender,
158
+ [ModCallbackCustom2.POST_PIT_UPDATE]: PostPitUpdate,
159
+ [ModCallbackCustom2.POST_PLAYER_CHANGE_HEALTH]: PostPlayerChangeHealth,
160
+ [ModCallbackCustom2.POST_PLAYER_CHANGE_STAT]: PostPlayerChangeStat,
161
+ [ModCallbackCustom2.POST_PLAYER_CHANGE_TYPE]: PostPlayerChangeType,
162
+ [ModCallbackCustom2.POST_PLAYER_COLLECTIBLE_ADDED]:
163
+ PostPlayerCollectibleAdded,
164
+ [ModCallbackCustom2.POST_PLAYER_COLLECTIBLE_REMOVED]:
165
+ PostPlayerCollectibleRemoved,
110
166
  [ModCallbackCustom2.POST_PLAYER_FATAL_DAMAGE]: PostPlayerFatalDamage,
167
+ [ModCallbackCustom2.POST_PLAYER_INIT_FIRST]: PostPlayerInitFirst,
168
+ [ModCallbackCustom2.POST_PLAYER_INIT_LATE]: PostPlayerInitLate,
111
169
  [ModCallbackCustom2.POST_PLAYER_RENDER_REORDERED]: PostPlayerRenderReordered,
112
170
  [ModCallbackCustom2.POST_PLAYER_UPDATE_REORDERED]: PostPlayerUpdateReordered,
171
+ [ModCallbackCustom2.POST_POOP_RENDER]: PostPoopRender,
172
+ [ModCallbackCustom2.POST_POOP_UPDATE]: PostPoopUpdate,
173
+ [ModCallbackCustom2.POST_PRESSURE_PLATE_RENDER]: PostPressurePlateRender,
174
+ [ModCallbackCustom2.POST_PRESSURE_PLATE_UPDATE]: PostPressurePlateUpdate,
175
+ [ModCallbackCustom2.POST_PROJECTILE_INIT_LATE]: PostProjectileInitLate,
176
+ [ModCallbackCustom2.POST_PURCHASE]: PostPurchase,
177
+ [ModCallbackCustom2.POST_ROCK_RENDER]: PostRockRender,
178
+ [ModCallbackCustom2.POST_ROCK_UPDATE]: PostRockUpdate,
113
179
  [ModCallbackCustom2.POST_ROOM_CLEAR_CHANGED]: PostRoomClearChanged,
180
+ [ModCallbackCustom2.POST_SACRIFICE]: PostSacrifice,
181
+ [ModCallbackCustom2.POST_SLOT_ANIMATION_CHANGED]: PostSlotAnimationChanged,
182
+ [ModCallbackCustom2.POST_SLOT_COLLISION]: PostSlotCollision,
183
+ [ModCallbackCustom2.POST_SLOT_DESTROYED]: PostSlotDestroyed,
184
+ [ModCallbackCustom2.POST_SLOT_INIT]: PostSlotInit,
185
+ [ModCallbackCustom2.POST_SLOT_RENDER]: PostSlotRender,
186
+ [ModCallbackCustom2.POST_SLOT_UPDATE]: PostSlotUpdate,
114
187
  [ModCallbackCustom2.POST_SPIKES_RENDER]: PostSpikesRender,
188
+ [ModCallbackCustom2.POST_SPIKES_UPDATE]: PostSpikesUpdate,
189
+ [ModCallbackCustom2.POST_TEAR_INIT_LATE]: PostTearInitLate,
190
+ [ModCallbackCustom2.POST_TEAR_INIT_VERY_LATE]: PostTearInitVeryLate,
191
+ [ModCallbackCustom2.POST_TNT_RENDER]: PostTNTRender,
192
+ [ModCallbackCustom2.POST_TNT_UPDATE]: PostTNTUpdate,
193
+ [ModCallbackCustom2.POST_TRANSFORMATION]: PostTransformation,
194
+
195
+ // ----------------
196
+
115
197
  [ModCallbackCustom2.PRE_BERSERK_DEATH]: PreBerserkDeath,
116
198
  [ModCallbackCustom2.PRE_CUSTOM_REVIVE]: PreCustomRevive,
199
+ [ModCallbackCustom2.PRE_ITEM_PICKUP]: PreItemPickup,
117
200
  } as const);
118
201
 
119
202
  export type ModCallbackCustomToClass = {
@@ -1,14 +1,104 @@
1
+ import {
2
+ getTSTLClassConstructor,
3
+ getTSTLClassName,
4
+ } from "../functions/tstlClass";
5
+ import { isTable } from "../functions/types";
6
+ import { TSTLClassMetatable } from "../interfaces/TSTLClassMetatable";
1
7
  import { ModUpgraded } from "./ModUpgraded";
2
8
 
9
+ export const ADD_CALLBACK_ARGS_KEY = "__addCallbackArgs";
10
+ export const ADD_CALLBACK_CUSTOM_ARGS_KEY = "__addCallbackCustomArgs";
11
+
12
+ type ModFeatureConstructor = TSTLClassMetatable["constructor"] & {
13
+ [ADD_CALLBACK_ARGS_KEY]: unknown[] | undefined;
14
+ [ADD_CALLBACK_CUSTOM_ARGS_KEY]: unknown[] | undefined;
15
+ };
16
+
3
17
  /**
4
- * A helper class for a mod that wants to represent its individual features as classes. This is
5
- * useful if you are using decorators to represent class methods that should be automatically
6
- * subscribed to callbacks.
18
+ * A helper class for mods that wants to represent their individual features as classes. Extend your
19
+ * mod features from this class in order to enable the `@Callback` and `@CustomCallback` decorators
20
+ * that automatically subscribe to callbacks.
21
+ *
22
+ * For example:
23
+ *
24
+ * ```ts
25
+ * export class MyFeature extends ModFeature {
26
+ * @Callback(ModCallback.POST_GAME_STARTED)
27
+ * postGameStarted(isContinued: boolean): void {
28
+ * Isaac.DebugString(`Callback fired: POST_GAME_STARTED`);
29
+ * }
30
+ * }
31
+ * ```
7
32
  */
33
+ // eslint-disable-next-line @typescript-eslint/no-extraneous-class
8
34
  export class ModFeature {
9
- private mod: ModUpgraded;
10
-
11
35
  constructor(mod: ModUpgraded) {
12
- this.mod = mod;
36
+ const constructor = getTSTLClassConstructor(this);
37
+ if (constructor === undefined) {
38
+ error("Failed to get the TSTL class constructor for a mod feature.");
39
+ }
40
+
41
+ const modFeatureConstructor = constructor as ModFeatureConstructor;
42
+ addDecoratedCallbacks(mod, modFeatureConstructor);
43
+ addDecoratedCallbacksCustom(mod, modFeatureConstructor);
44
+ registerSaveDataManager(mod, this);
45
+ }
46
+ }
47
+
48
+ function addDecoratedCallbacks(
49
+ mod: ModUpgraded,
50
+ modFeatureConstructor: ModFeatureConstructor,
51
+ ) {
52
+ const addCallbackArgs = modFeatureConstructor[ADD_CALLBACK_ARGS_KEY];
53
+ if (addCallbackArgs === undefined) {
54
+ return;
55
+ }
56
+
57
+ for (const args of addCallbackArgs) {
58
+ // @ts-expect-error The compiler does not know that the arguments match the method.
59
+ // eslint-disable-next-line isaacscript/strict-enums
60
+ mod.AddCallback(...args);
61
+ }
62
+ }
63
+
64
+ function addDecoratedCallbacksCustom(
65
+ mod: ModUpgraded,
66
+ modFeatureConstructor: ModFeatureConstructor,
67
+ ) {
68
+ const addCallbackCustomArgs =
69
+ modFeatureConstructor[ADD_CALLBACK_CUSTOM_ARGS_KEY];
70
+ if (addCallbackCustomArgs === undefined) {
71
+ return;
72
+ }
73
+
74
+ for (const args of addCallbackCustomArgs) {
75
+ // @ts-expect-error The compiler does not know that the arguments match the method.
76
+ // eslint-disable-next-line isaacscript/strict-enums
77
+ mod.AddCallbackCustom(...args);
78
+ }
79
+ }
80
+
81
+ function registerSaveDataManager(mod: ModUpgraded, modFeature: ModFeature) {
82
+ // Do nothing if this class does not have any variables.
83
+ const { v } = modFeature as unknown as Record<string, unknown>;
84
+ if (v === undefined) {
85
+ return;
13
86
  }
87
+
88
+ if (!isTable(v)) {
89
+ error(
90
+ 'Failed to initialize a mod feature class due to having a "v" property that is not an object. (The "v" property is supposed to be an object that holds the variables for the class, managed by the save data manager.)',
91
+ );
92
+ }
93
+
94
+ // Do nothing if we have not enabled the save data manager.
95
+ const { saveDataManager } = mod as unknown as Record<string, unknown>;
96
+ if (saveDataManager === undefined) {
97
+ error(
98
+ 'Failed to initialize a mod feature class due to having a "v" object and not having the save data manager initialized. You must pass "ISCFeature.SAVE_DATA_MANAGER" to the "upgradeMod" function.',
99
+ );
100
+ }
101
+
102
+ const tstlClassName = getTSTLClassName(modFeature);
103
+ (saveDataManager as (...args: unknown[]) => void)(tstlClassName, v);
14
104
  }
@@ -5,10 +5,6 @@ import { ISCFeature } from "../enums/ISCFeature";
5
5
  import { ModCallbackCustom } from "../enums/ModCallbackCustom";
6
6
  import { ModCallbackCustom2 } from "../enums/ModCallbackCustom2";
7
7
  import { getFeatures } from "../features";
8
- import {
9
- saveDataManager,
10
- saveDataManagerRemove,
11
- } from "../features/saveDataManager/exports";
12
8
  import { getTime } from "../functions/debugFunctions";
13
9
  import { getParentFunctionDescription } from "../functions/log";
14
10
  import {
@@ -18,6 +14,7 @@ import {
18
14
  import { AddCallbackParametersCustom } from "../interfaces/private/AddCallbackParametersCustom";
19
15
  import { AddCallbackParametersCustom2 } from "../interfaces/private/AddCallbackParametersCustom2";
20
16
  import { CALLBACK_REGISTER_FUNCTIONS } from "../objects/callbackRegisterFunctions";
17
+ import { AnyFunction } from "../types/AnyFunction";
21
18
  import { FunctionTuple } from "../types/FunctionTuple";
22
19
  import { Feature } from "./private/Feature";
23
20
 
@@ -33,10 +30,6 @@ export class ModUpgraded implements Mod {
33
30
  // Vanilla variables
34
31
  // -----------------
35
32
 
36
- /**
37
- * The `RegisterMod` function stores the name of the mod on the mod object for some reason. (It is
38
- * never used or referenced.)
39
- */
40
33
  public Name: string;
41
34
 
42
35
  // ----------------
@@ -65,7 +58,7 @@ export class ModUpgraded implements Mod {
65
58
  this.debug = debug;
66
59
  this.timeThreshold = timeThreshold;
67
60
  this.callbacks = getCallbacks();
68
- this.features = getFeatures(this.callbacks);
61
+ this.features = getFeatures(mod, this.callbacks);
69
62
  }
70
63
 
71
64
  // ---------------
@@ -194,7 +187,7 @@ export class ModUpgraded implements Mod {
194
187
  ): void {
195
188
  const callbackClass = this.callbacks[modCallbackCustom];
196
189
  // @ts-expect-error The compiler is not smart enough to figure out that the parameters match.
197
- callbackClass.add(...args);
190
+ callbackClass.addSubscriber(...args);
198
191
  this.initFeature(callbackClass);
199
192
  }
200
193
 
@@ -210,34 +203,37 @@ export class ModUpgraded implements Mod {
210
203
  ): void {
211
204
  const callbackClass = this.callbacks[modCallbackCustom];
212
205
  // @ts-expect-error The compiler is not smart enough to figure out that the parameters match.
213
- callbackClass.remove(callback);
214
- if (!callbackClass.hasSubscriptions()) {
215
- this.uninitFeature(callbackClass);
216
- }
217
- }
218
-
219
- /**
220
- * This method should only be used by the `upgradeMod` function. Returns the names of the exported
221
- * class methods from the features that were added.
222
- */
223
- public initOptionalFeature(feature: ISCFeature): FunctionTuple[] {
224
- const featureClass = this.features[feature];
225
- this.initFeature(featureClass);
226
-
227
- return getExportedMethodsFromFeature(featureClass);
206
+ callbackClass.removeSubscriber(callback);
207
+ this.uninitFeature(callbackClass);
228
208
  }
229
209
 
230
210
  // ----------------------
231
211
  // Custom private methods
232
212
  // ----------------------
233
213
 
234
- /** This is used to initialize both custom callbacks and "extra features". */
214
+ /**
215
+ * This is used to initialize both custom callbacks and "extra features".
216
+ *
217
+ * This mirrors the `uninitFeature` method.
218
+ */
235
219
  private initFeature(feature: Feature): void {
220
+ feature.numConsumers++;
221
+
236
222
  if (feature.initialized) {
237
223
  return;
238
224
  }
225
+
239
226
  feature.initialized = true;
240
227
 
228
+ if (feature.v !== undefined) {
229
+ if (feature.featuresUsed === undefined) {
230
+ feature.featuresUsed = [];
231
+ }
232
+ if (!feature.featuresUsed.includes(ISCFeature.SAVE_DATA_MANAGER)) {
233
+ feature.featuresUsed.unshift(ISCFeature.SAVE_DATA_MANAGER);
234
+ }
235
+ }
236
+
241
237
  if (feature.featuresUsed !== undefined) {
242
238
  for (const featureUsed of feature.featuresUsed) {
243
239
  const featureClass = this.features[featureUsed];
@@ -264,14 +260,37 @@ export class ModUpgraded implements Mod {
264
260
  if (className === undefined) {
265
261
  error("Failed to get the name of a feature.");
266
262
  }
267
- saveDataManager(className, feature.v);
263
+ const saveDataManagerClass = this.features[ISCFeature.SAVE_DATA_MANAGER];
264
+ saveDataManagerClass.saveDataManager(className, feature.v);
268
265
  }
269
266
  }
270
267
 
268
+ /**
269
+ * This is used to uninitialize both custom callbacks and "extra features".
270
+ *
271
+ * This mirrors the `initFeature` method.
272
+ */
271
273
  private uninitFeature(feature: Feature): void {
274
+ if (feature.numConsumers <= 0) {
275
+ const className = getTSTLClassName(feature) ?? "unknown";
276
+ error(
277
+ `Failed to uninit feature "${className}" since it has ${feature.numConsumers} consumers, which should never happen.`,
278
+ );
279
+ }
280
+
272
281
  if (!feature.initialized) {
282
+ const className = getTSTLClassName(feature) ?? "unknown";
283
+ error(
284
+ `Failed to uninit feature "${className}" since it was not initialized, which should never happen.`,
285
+ );
286
+ }
287
+
288
+ feature.numConsumers--;
289
+
290
+ if (feature.numConsumers > 0) {
273
291
  return;
274
292
  }
293
+
275
294
  feature.initialized = false;
276
295
 
277
296
  if (feature.featuresUsed !== undefined) {
@@ -302,9 +321,18 @@ export class ModUpgraded implements Mod {
302
321
  if (className === undefined) {
303
322
  error("Failed to get the name of a feature.");
304
323
  }
305
- saveDataManagerRemove(className);
324
+ const saveDataManagerClass = this.features[ISCFeature.SAVE_DATA_MANAGER];
325
+ saveDataManagerClass.saveDataManagerRemove(className);
306
326
  }
307
327
  }
328
+
329
+ /** Returns the names of the exported class methods from the features that were added. */
330
+ private initOptionalFeature(feature: ISCFeature): FunctionTuple[] {
331
+ const featureClass = this.features[feature];
332
+ this.initFeature(featureClass);
333
+
334
+ return getExportedMethodsFromFeature(featureClass);
335
+ }
308
336
  }
309
337
 
310
338
  /**
@@ -324,10 +352,7 @@ function getExportedMethodsFromFeature(featureClass: unknown): FunctionTuple[] {
324
352
  ] as string[];
325
353
 
326
354
  return exportedMethodNames.map((name) => {
327
- const featureClassRecord = featureClass as Record<
328
- string,
329
- (...args: unknown[]) => unknown
330
- >;
355
+ const featureClassRecord = featureClass as Record<string, AnyFunction>;
331
356
  const method = featureClassRecord[name];
332
357
  if (method === undefined) {
333
358
  error(`Failed to find a decorated exported method: ${name}`);
@@ -1,11 +1,31 @@
1
1
  import { ISCFeature } from "../../enums/ISCFeature";
2
2
  import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
3
- import { CustomCallbackRevive } from "./validation/CustomCallbackRevive";
3
+ import {
4
+ CustomCallback,
5
+ FireArgs,
6
+ OptionalArgs,
7
+ } from "../private/CustomCallback";
4
8
 
5
- export class PostCustomRevive extends CustomCallbackRevive<ModCallbackCustom2.POST_CUSTOM_REVIVE> {
9
+ type T = ModCallbackCustom2.POST_CUSTOM_REVIVE;
10
+
11
+ export class PostCustomRevive extends CustomCallback<ModCallbackCustom2.POST_CUSTOM_REVIVE> {
6
12
  constructor() {
7
13
  super();
8
14
 
9
15
  this.featuresUsed = [ISCFeature.CUSTOM_REVIVE];
10
16
  }
17
+
18
+ // eslint-disable-next-line class-methods-use-this
19
+ protected override shouldFire(
20
+ fireArgs: FireArgs<T>,
21
+ optionalArgs: OptionalArgs<T>,
22
+ ): boolean {
23
+ const [callbackRevivalType] = optionalArgs;
24
+ if (callbackRevivalType === undefined) {
25
+ return true;
26
+ }
27
+
28
+ const [_player, revivalType] = fireArgs;
29
+ return revivalType === callbackRevivalType;
30
+ }
11
31
  }
@@ -6,6 +6,6 @@ export class PostGridEntityBroken extends CustomCallbackGridEntity<ModCallbackCu
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -12,7 +12,7 @@ export class PostGridEntityCollision extends CustomCallback<T> {
12
12
  constructor() {
13
13
  super();
14
14
 
15
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
15
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
16
16
  }
17
17
 
18
18
  // eslint-disable-next-line class-methods-use-this
@@ -6,6 +6,6 @@ export class PostGridEntityCustomBroken extends CustomCallbackGridEntityCustom<M
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -12,7 +12,7 @@ export class PostGridEntityCustomCollision extends CustomCallback<T> {
12
12
  constructor() {
13
13
  super();
14
14
 
15
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
15
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
16
16
  }
17
17
 
18
18
  // eslint-disable-next-line class-methods-use-this
@@ -6,6 +6,6 @@ export class PostGridEntityCustomInit extends CustomCallbackGridEntityCustom<Mod
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -12,7 +12,7 @@ export class PostGridEntityCustomRemove extends CustomCallback<T> {
12
12
  constructor() {
13
13
  super();
14
14
 
15
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
15
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
16
16
  }
17
17
 
18
18
  // eslint-disable-next-line class-methods-use-this
@@ -0,0 +1,11 @@
1
+ import { ISCFeature } from "../../enums/ISCFeature";
2
+ import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
3
+ import { CustomCallbackGridEntityCustom } from "./validation/CustomCallbackGridEntityCustom";
4
+
5
+ export class PostGridEntityCustomRender extends CustomCallbackGridEntityCustom<ModCallbackCustom2.POST_GRID_ENTITY_CUSTOM_RENDER> {
6
+ constructor() {
7
+ super();
8
+
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_RENDER_DETECTION];
10
+ }
11
+ }
@@ -6,6 +6,6 @@ export class PostGridEntityCustomStateChanged extends CustomCallbackGridEntityCu
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -6,6 +6,6 @@ export class PostGridEntityCustomUpdate extends CustomCallbackGridEntityCustom<M
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -6,6 +6,6 @@ export class PostGridEntityInit extends CustomCallbackGridEntity<ModCallbackCust
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -12,7 +12,7 @@ export class PostGridEntityRemove extends CustomCallback<T> {
12
12
  constructor() {
13
13
  super();
14
14
 
15
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
15
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
16
16
  }
17
17
 
18
18
  // eslint-disable-next-line class-methods-use-this
@@ -0,0 +1,11 @@
1
+ import { ISCFeature } from "../../enums/ISCFeature";
2
+ import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
3
+ import { CustomCallbackGridEntity } from "./validation/CustomCallbackGridEntity";
4
+
5
+ export class PostGridEntityRender extends CustomCallbackGridEntity<ModCallbackCustom2.POST_GRID_ENTITY_RENDER> {
6
+ constructor() {
7
+ super();
8
+
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_RENDER_DETECTION];
10
+ }
11
+ }
@@ -6,6 +6,6 @@ export class PostGridEntityStateChanged extends CustomCallbackGridEntity<ModCall
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -6,6 +6,6 @@ export class PostGridEntityUpdate extends CustomCallbackGridEntity<ModCallbackCu
6
6
  constructor() {
7
7
  super();
8
8
 
9
- this.featuresUsed = [ISCFeature.GRID_ENTITY_DETECTION];
9
+ this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
10
10
  }
11
11
  }
@@ -1,4 +1,4 @@
1
- import { CollectibleType } from "isaac-typescript-definitions";
1
+ import { CollectibleType, ModCallback } from "isaac-typescript-definitions";
2
2
  import { ModCallbackCustom2 } from "../../enums/ModCallbackCustom2";
3
3
  import {
4
4
  defaultMapGetPlayer,
@@ -18,16 +18,13 @@ export class PostHolyMantleRemoved extends CustomCallback<ModCallbackCustom2.POS
18
18
  constructor() {
19
19
  super();
20
20
 
21
- this.customCallbacksUsed = [
22
- [
23
- ModCallbackCustom2.POST_PEFFECT_UPDATE_REORDERED,
24
- [this.postPEffectUpdateReordered],
25
- ],
21
+ this.callbacksUsed = [
22
+ [ModCallback.POST_PEFFECT_UPDATE, [this.postPEffectUpdate]], // 4
26
23
  ];
27
24
  }
28
25
 
29
- // ModCallbackCustom.POST_PEFFECT_UPDATE_REORDERED
30
- private postPEffectUpdateReordered = (player: EntityPlayer): void => {
26
+ // ModCallback.POST_PEFFECT_UPDATE (4)
27
+ private postPEffectUpdate = (player: EntityPlayer): void => {
31
28
  const effects = player.GetEffects();
32
29
  const newNumHolyMantles = effects.GetCollectibleEffectNum(
33
30
  CollectibleType.HOLY_MANTLE,