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.
- package/dist/index.d.ts +954 -158
- package/dist/isaacscript-common.lua +4099 -1066
- package/dist/src/callbacks.d.ts +102 -20
- package/dist/src/callbacks.d.ts.map +1 -1
- package/dist/src/callbacks.lua +124 -1
- package/dist/src/classes/ModFeature.d.ts +16 -4
- package/dist/src/classes/ModFeature.d.ts.map +1 -1
- package/dist/src/classes/ModFeature.lua +67 -4
- package/dist/src/classes/ModUpgraded.d.ts +10 -10
- package/dist/src/classes/ModUpgraded.d.ts.map +1 -1
- package/dist/src/classes/ModUpgraded.lua +35 -16
- package/dist/src/classes/callbacks/PostCustomRevive.d.ts +5 -2
- package/dist/src/classes/callbacks/PostCustomRevive.d.ts.map +1 -1
- package/dist/src/classes/callbacks/PostCustomRevive.lua +12 -4
- package/dist/src/classes/callbacks/PostGridEntityBroken.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCollision.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomBroken.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomCollision.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomInit.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomRemove.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomRender.d.ts +6 -0
- package/dist/src/classes/callbacks/PostGridEntityCustomRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostGridEntityCustomRender.lua +17 -0
- package/dist/src/classes/callbacks/PostGridEntityCustomStateChanged.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityCustomUpdate.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityInit.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityRemove.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityRender.d.ts +6 -0
- package/dist/src/classes/callbacks/PostGridEntityRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostGridEntityRender.lua +17 -0
- package/dist/src/classes/callbacks/PostGridEntityStateChanged.lua +1 -1
- package/dist/src/classes/callbacks/PostGridEntityUpdate.lua +1 -1
- package/dist/src/classes/callbacks/PostHolyMantleRemoved.d.ts +1 -1
- package/dist/src/classes/callbacks/PostHolyMantleRemoved.d.ts.map +1 -1
- package/dist/src/classes/callbacks/PostHolyMantleRemoved.lua +3 -4
- package/dist/src/classes/callbacks/PostItemDischarge.d.ts +43 -0
- package/dist/src/classes/callbacks/PostItemDischarge.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostItemDischarge.lua +113 -0
- package/dist/src/classes/callbacks/PostItemPickup.d.ts +6 -0
- package/dist/src/classes/callbacks/PostItemPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostItemPickup.lua +17 -0
- package/dist/src/classes/callbacks/PostLaserInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostLaserInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostLaserInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostNPCInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostNPCInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostNPCInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostNPCStateChanged.d.ts +14 -0
- package/dist/src/classes/callbacks/PostNPCStateChanged.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostNPCStateChanged.lua +33 -0
- package/dist/src/classes/callbacks/PostPickupCollect.d.ts +12 -0
- package/dist/src/classes/callbacks/PostPickupCollect.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupCollect.lua +35 -0
- package/dist/src/classes/callbacks/PostPickupInitFirst.d.ts +12 -0
- package/dist/src/classes/callbacks/PostPickupInitFirst.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupInitFirst.lua +32 -0
- package/dist/src/classes/callbacks/PostPickupInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostPickupInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostPickupStateChanged.d.ts +13 -0
- package/dist/src/classes/callbacks/PostPickupStateChanged.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPickupStateChanged.lua +33 -0
- package/dist/src/classes/callbacks/PostPitUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPitUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPitUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostPlayerChangeHealth.d.ts +15 -0
- package/dist/src/classes/callbacks/PostPlayerChangeHealth.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerChangeHealth.lua +52 -0
- package/dist/src/classes/callbacks/PostPlayerChangeStat.d.ts +16 -0
- package/dist/src/classes/callbacks/PostPlayerChangeStat.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerChangeStat.lua +94 -0
- package/dist/src/classes/callbacks/PostPlayerChangeType.d.ts +15 -0
- package/dist/src/classes/callbacks/PostPlayerChangeType.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerChangeType.lua +37 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.d.ts +6 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleAdded.lua +17 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.d.ts +6 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerCollectibleRemoved.lua +17 -0
- package/dist/src/classes/callbacks/PostPlayerInitFirst.d.ts +8 -0
- package/dist/src/classes/callbacks/PostPlayerInitFirst.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerInitFirst.lua +39 -0
- package/dist/src/classes/callbacks/PostPlayerInitLate.d.ts +13 -0
- package/dist/src/classes/callbacks/PostPlayerInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPlayerInitLate.lua +29 -0
- package/dist/src/classes/callbacks/PostPoopRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPoopRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPoopRender.lua +24 -0
- package/dist/src/classes/callbacks/PostPoopUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPoopUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPoopUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostPressurePlateRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPressurePlateRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPressurePlateRender.lua +24 -0
- package/dist/src/classes/callbacks/PostPressurePlateUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostPressurePlateUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPressurePlateUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostProjectileInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostProjectileInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostProjectileInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostPurchase.d.ts +18 -0
- package/dist/src/classes/callbacks/PostPurchase.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostPurchase.lua +56 -0
- package/dist/src/classes/callbacks/PostRockRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostRockRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostRockRender.lua +24 -0
- package/dist/src/classes/callbacks/PostRockUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostRockUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostRockUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostSacrifice.d.ts +15 -0
- package/dist/src/classes/callbacks/PostSacrifice.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSacrifice.lua +52 -0
- package/dist/src/classes/callbacks/PostSlotAnimationChanged.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotAnimationChanged.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotAnimationChanged.lua +17 -0
- package/dist/src/classes/callbacks/PostSlotCollision.d.ts +7 -0
- package/dist/src/classes/callbacks/PostSlotCollision.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotCollision.lua +25 -0
- package/dist/src/classes/callbacks/PostSlotDestroyed.d.ts +14 -0
- package/dist/src/classes/callbacks/PostSlotDestroyed.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotDestroyed.lua +65 -0
- package/dist/src/classes/callbacks/PostSlotInit.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotInit.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotInit.lua +17 -0
- package/dist/src/classes/callbacks/PostSlotRender.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotRender.lua +17 -0
- package/dist/src/classes/callbacks/PostSlotUpdate.d.ts +6 -0
- package/dist/src/classes/callbacks/PostSlotUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSlotUpdate.lua +17 -0
- package/dist/src/classes/callbacks/PostSpikesUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostSpikesUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostSpikesUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostTNTRender.d.ts +7 -0
- package/dist/src/classes/callbacks/PostTNTRender.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTNTRender.lua +24 -0
- package/dist/src/classes/callbacks/PostTNTUpdate.d.ts +7 -0
- package/dist/src/classes/callbacks/PostTNTUpdate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTNTUpdate.lua +24 -0
- package/dist/src/classes/callbacks/PostTearInitLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostTearInitLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTearInitLate.lua +27 -0
- package/dist/src/classes/callbacks/PostTearInitVeryLate.d.ts +12 -0
- package/dist/src/classes/callbacks/PostTearInitVeryLate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTearInitVeryLate.lua +30 -0
- package/dist/src/classes/callbacks/PostTransformation.d.ts +18 -0
- package/dist/src/classes/callbacks/PostTransformation.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PostTransformation.lua +53 -0
- package/dist/src/classes/callbacks/PreBerserkDeath.d.ts +1 -1
- package/dist/src/classes/callbacks/PreBerserkDeath.d.ts.map +1 -1
- package/dist/src/classes/callbacks/PreBerserkDeath.lua +3 -4
- package/dist/src/classes/callbacks/PreItemPickup.d.ts +6 -0
- package/dist/src/classes/callbacks/PreItemPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/PreItemPickup.lua +17 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackCollectibleType.lua +19 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.d.ts +11 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackItemPickup.lua +22 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackLaser.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackLaser.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackLaser.lua +19 -0
- package/dist/src/classes/callbacks/validation/{CustomCallbackRevive.d.ts → CustomCallbackNPC.d.ts} +4 -4
- package/dist/src/classes/callbacks/validation/CustomCallbackNPC.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackNPC.lua +22 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPickup.d.ts +12 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPickup.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPickup.lua +22 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPlayer.d.ts +5 -2
- package/dist/src/classes/callbacks/validation/CustomCallbackPlayer.d.ts.map +1 -1
- package/dist/src/classes/callbacks/validation/CustomCallbackPoop.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPoop.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPoop.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackPressurePlate.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackProjectile.lua +19 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRock.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRock.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRock.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSlot.d.ts +12 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSlot.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSlot.lua +19 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackSpikes.lua +4 -4
- package/dist/src/classes/callbacks/validation/CustomCallbackTNT.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTNT.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTNT.lua +20 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTear.d.ts +10 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTear.d.ts.map +1 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackTear.lua +19 -0
- package/dist/src/classes/features/callbackLogic/CustomGridEntities.d.ts +1 -1
- package/dist/src/classes/features/callbackLogic/CustomGridEntities.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/CustomGridEntities.lua +27 -30
- package/dist/src/classes/features/callbackLogic/CustomRevive.d.ts +2 -2
- package/dist/src/classes/features/callbackLogic/CustomRevive.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/CustomRevive.lua +6 -6
- package/dist/src/classes/features/callbackLogic/EsauJrDetection.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/GameReorderedCallbacks.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/GameReorderedCallbacks.lua +3 -18
- package/dist/src/classes/features/callbackLogic/GridEntityCollisionDetection.d.ts.map +1 -1
- package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.d.ts +12 -0
- package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/GridEntityRenderDetection.lua +33 -0
- package/dist/src/classes/features/callbackLogic/{GridEntityDetection.d.ts → GridEntityUpdateDetection.d.ts} +3 -3
- package/dist/src/classes/features/callbackLogic/GridEntityUpdateDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/{GridEntityDetection.lua → GridEntityUpdateDetection.lua} +11 -14
- package/dist/src/classes/features/callbackLogic/ItemPickupDetection.d.ts +20 -0
- package/dist/src/classes/features/callbackLogic/ItemPickupDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/ItemPickupDetection.lua +60 -0
- package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.d.ts +47 -0
- package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/PlayerCollectibleDetection.lua +154 -0
- package/dist/src/classes/features/callbackLogic/SlotRenderDetection.d.ts +18 -0
- package/dist/src/classes/features/callbackLogic/SlotRenderDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/SlotRenderDetection.lua +51 -0
- package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.d.ts +17 -0
- package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.d.ts.map +1 -0
- package/dist/src/classes/features/callbackLogic/SlotUpdateDetection.lua +45 -0
- package/dist/src/classes/features/other/RunInNFrames.d.ts.map +1 -1
- package/dist/src/classes/features/other/RunInNFrames.lua +9 -0
- package/dist/src/classes/features/other/SaveDataManager.d.ts +215 -0
- package/dist/src/classes/features/other/SaveDataManager.d.ts.map +1 -0
- package/dist/src/classes/features/other/SaveDataManager.lua +190 -0
- package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.d.ts +6 -0
- package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/glowingHourGlass.lua +98 -0
- package/dist/src/classes/features/other/saveDataManager/loadFromDisk.d.ts +6 -0
- package/dist/src/classes/features/other/saveDataManager/loadFromDisk.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/loadFromDisk.lua +81 -0
- package/dist/src/classes/features/other/saveDataManager/restoreDefaults.d.ts +7 -0
- package/dist/src/classes/features/other/saveDataManager/restoreDefaults.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/restoreDefaults.lua +69 -0
- package/dist/src/classes/features/other/saveDataManager/saveToDisk.d.ts +5 -0
- package/dist/src/classes/features/other/saveDataManager/saveToDisk.d.ts.map +1 -0
- package/dist/src/classes/features/other/saveDataManager/saveToDisk.lua +46 -0
- package/dist/src/classes/private/CustomCallback.d.ts +2 -3
- package/dist/src/classes/private/CustomCallback.d.ts.map +1 -1
- package/dist/src/classes/private/CustomCallback.lua +2 -5
- package/dist/src/classes/private/Feature.d.ts +1 -0
- package/dist/src/classes/private/Feature.d.ts.map +1 -1
- package/dist/src/classes/private/Feature.lua +1 -0
- package/dist/src/core/upgradeMod.d.ts +2 -5
- package/dist/src/core/upgradeMod.d.ts.map +1 -1
- package/dist/src/decorators.d.ts +1 -1
- package/dist/src/decorators.d.ts.map +1 -1
- package/dist/src/decorators.lua +6 -8
- package/dist/src/enums/ISCFeature.d.ts +15 -9
- package/dist/src/enums/ISCFeature.d.ts.map +1 -1
- package/dist/src/enums/ISCFeature.lua +30 -9
- package/dist/src/enums/ModCallbackCustom.d.ts +34 -20
- package/dist/src/enums/ModCallbackCustom.d.ts.map +1 -1
- package/dist/src/enums/ModCallbackCustom2.d.ts +61 -20
- package/dist/src/enums/ModCallbackCustom2.d.ts.map +1 -1
- package/dist/src/enums/ModCallbackCustom2.lua +102 -20
- package/dist/src/enums/{private/SerializationBrand.d.ts → SerializationBrand.d.ts} +6 -1
- package/dist/src/enums/SerializationBrand.d.ts.map +1 -0
- package/dist/src/enums/{private/SerializationBrand.lua → SerializationBrand.lua} +1 -0
- package/dist/src/features/customItemPool.d.ts +52 -0
- package/dist/src/features/customItemPool.d.ts.map +1 -0
- package/dist/src/features/customItemPool.lua +111 -0
- package/dist/src/features/deployJSONRoom.d.ts +6 -4
- package/dist/src/features/deployJSONRoom.d.ts.map +1 -1
- package/dist/src/features/deployJSONRoom.lua +6 -4
- package/dist/src/features/fadeInRemover.d.ts.map +1 -1
- package/dist/src/features/fadeInRemover.lua +4 -16
- package/dist/src/features/saveDataManager/exports.d.ts +14 -4
- package/dist/src/features/saveDataManager/exports.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/exports.lua +38 -0
- package/dist/src/features/saveDataManager/load.d.ts +2 -1
- package/dist/src/features/saveDataManager/load.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/load.lua +10 -4
- package/dist/src/features/saveDataManager/main.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/main.lua +12 -5
- package/dist/src/features/saveDataManager/maps.d.ts +14 -0
- package/dist/src/features/saveDataManager/maps.d.ts.map +1 -1
- package/dist/src/features/saveDataManager/maps.lua +7 -0
- package/dist/src/features.d.ts +31 -12
- package/dist/src/features.d.ts.map +1 -1
- package/dist/src/features.lua +24 -6
- package/dist/src/functions/array.d.ts.map +1 -1
- package/dist/src/functions/array.lua +4 -5
- package/dist/src/functions/bitSet128.d.ts +2 -2
- package/dist/src/functions/bitSet128.lua +3 -3
- package/dist/src/functions/color.d.ts +2 -2
- package/dist/src/functions/color.lua +3 -3
- package/dist/src/functions/decorators.d.ts +28 -6
- package/dist/src/functions/decorators.d.ts.map +1 -1
- package/dist/src/functions/decorators.lua +24 -5
- package/dist/src/functions/deepCopy.d.ts +11 -4
- package/dist/src/functions/deepCopy.d.ts.map +1 -1
- package/dist/src/functions/deepCopy.lua +84 -32
- package/dist/src/functions/deepCopyTests.lua +1 -1
- package/dist/src/functions/initArray.d.ts +4 -4
- package/dist/src/functions/initArray.d.ts.map +1 -1
- package/dist/src/functions/initArray.lua +6 -12
- package/dist/src/functions/jsonRoom.d.ts +11 -0
- package/dist/src/functions/jsonRoom.d.ts.map +1 -1
- package/dist/src/functions/jsonRoom.lua +11 -0
- package/dist/src/functions/kColor.d.ts +2 -2
- package/dist/src/functions/kColor.lua +3 -3
- package/dist/src/functions/logMisc.d.ts +9 -2
- package/dist/src/functions/logMisc.d.ts.map +1 -1
- package/dist/src/functions/logMisc.lua +32 -2
- package/dist/src/functions/merge.d.ts +40 -0
- package/dist/src/functions/merge.d.ts.map +1 -0
- package/dist/src/{features/saveDataManager → functions}/merge.lua +84 -37
- package/dist/src/functions/mergeTests.d.ts +1 -2
- package/dist/src/functions/mergeTests.d.ts.map +1 -1
- package/dist/src/functions/mergeTests.lua +3 -4
- package/dist/src/functions/rng.d.ts +2 -2
- package/dist/src/functions/rng.lua +3 -3
- package/dist/src/functions/serialization.d.ts.map +1 -1
- package/dist/src/functions/serialization.lua +22 -0
- package/dist/src/functions/tstlClass.d.ts +0 -10
- package/dist/src/functions/tstlClass.d.ts.map +1 -1
- package/dist/src/functions/tstlClass.lua +2 -42
- package/dist/src/functions/vector.d.ts +2 -2
- package/dist/src/functions/vector.lua +3 -3
- package/dist/src/functions/weighted.d.ts +12 -1
- package/dist/src/functions/weighted.d.ts.map +1 -1
- package/dist/src/functions/weighted.lua +27 -10
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.lua +24 -0
- package/dist/src/interfaces/SaveData.d.ts +3 -7
- package/dist/src/interfaces/SaveData.d.ts.map +1 -1
- package/dist/src/interfaces/SaveData.lua +0 -11
- package/dist/src/interfaces/private/AddCallbackParametersCustom2.d.ts +195 -2
- package/dist/src/interfaces/private/AddCallbackParametersCustom2.d.ts.map +1 -1
- package/dist/src/objects/isaacAPIClassTypeToBrand.d.ts +1 -1
- package/dist/src/objects/isaacAPIClassTypeToBrand.d.ts.map +1 -1
- package/dist/src/objects/isaacAPIClassTypeToBrand.lua +1 -1
- package/dist/src/types/AnyClass.d.ts +2 -0
- package/dist/src/types/AnyClass.d.ts.map +1 -0
- package/dist/src/types/AnyClass.lua +2 -0
- package/dist/src/types/AnyFunction.d.ts +6 -0
- package/dist/src/types/AnyFunction.d.ts.map +1 -0
- package/dist/src/types/AnyFunction.lua +2 -0
- package/dist/src/types/FunctionTuple.d.ts +2 -4
- package/dist/src/types/FunctionTuple.d.ts.map +1 -1
- package/dist/src/types/HasFunction.d.ts +5 -0
- package/dist/src/types/HasFunction.d.ts.map +1 -0
- package/dist/src/types/HasFunction.lua +2 -0
- package/package.json +1 -1
- package/src/callbacks.ts +88 -5
- package/src/classes/ModFeature.ts +96 -6
- package/src/classes/ModUpgraded.ts +57 -32
- package/src/classes/callbacks/PostCustomRevive.ts +22 -2
- package/src/classes/callbacks/PostGridEntityBroken.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCollision.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomBroken.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomCollision.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomInit.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomRemove.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomRender.ts +11 -0
- package/src/classes/callbacks/PostGridEntityCustomStateChanged.ts +1 -1
- package/src/classes/callbacks/PostGridEntityCustomUpdate.ts +1 -1
- package/src/classes/callbacks/PostGridEntityInit.ts +1 -1
- package/src/classes/callbacks/PostGridEntityRemove.ts +1 -1
- package/src/classes/callbacks/PostGridEntityRender.ts +11 -0
- package/src/classes/callbacks/PostGridEntityStateChanged.ts +1 -1
- package/src/classes/callbacks/PostGridEntityUpdate.ts +1 -1
- package/src/classes/callbacks/PostHolyMantleRemoved.ts +5 -8
- package/src/classes/callbacks/PostItemDischarge.ts +181 -0
- package/src/classes/callbacks/PostItemPickup.ts +11 -0
- package/src/classes/callbacks/PostLaserInitLate.ts +28 -0
- package/src/classes/callbacks/PostNPCInitLate.ts +28 -0
- package/src/classes/callbacks/PostNPCStateChanged.ts +37 -0
- package/src/classes/callbacks/PostPickupCollect.ts +37 -0
- package/src/classes/callbacks/PostPickupInitFirst.ts +34 -0
- package/src/classes/callbacks/PostPickupInitLate.ts +28 -0
- package/src/classes/callbacks/PostPickupStateChanged.ts +35 -0
- package/src/classes/callbacks/PostPitUpdate.ts +21 -0
- package/src/classes/callbacks/PostPlayerChangeHealth.ts +57 -0
- package/src/classes/callbacks/PostPlayerChangeStat.ts +102 -0
- package/src/classes/callbacks/PostPlayerChangeType.ts +44 -0
- package/src/classes/callbacks/PostPlayerCollectibleAdded.ts +11 -0
- package/src/classes/callbacks/PostPlayerCollectibleRemoved.ts +11 -0
- package/src/classes/callbacks/PostPlayerInitFirst.ts +44 -0
- package/src/classes/callbacks/PostPlayerInitLate.ts +32 -0
- package/src/classes/callbacks/PostPoopRender.ts +21 -0
- package/src/classes/callbacks/PostPoopUpdate.ts +21 -0
- package/src/classes/callbacks/PostPressurePlateRender.ts +21 -0
- package/src/classes/callbacks/PostPressurePlateUpdate.ts +21 -0
- package/src/classes/callbacks/PostProjectileInitLate.ts +28 -0
- package/src/classes/callbacks/PostPurchase.ts +87 -0
- package/src/classes/callbacks/PostRockRender.ts +21 -0
- package/src/classes/callbacks/PostRockUpdate.ts +21 -0
- package/src/classes/callbacks/PostSacrifice.ts +89 -0
- package/src/classes/callbacks/PostSlotAnimationChanged.ts +11 -0
- package/src/classes/callbacks/PostSlotCollision.ts +26 -0
- package/src/classes/callbacks/PostSlotDestroyed.ts +79 -0
- package/src/classes/callbacks/PostSlotInit.ts +11 -0
- package/src/classes/callbacks/PostSlotRender.ts +11 -0
- package/src/classes/callbacks/PostSlotUpdate.ts +11 -0
- package/src/classes/callbacks/PostSpikesUpdate.ts +21 -0
- package/src/classes/callbacks/PostTNTRender.ts +21 -0
- package/src/classes/callbacks/PostTNTUpdate.ts +21 -0
- package/src/classes/callbacks/PostTearInitLate.ts +28 -0
- package/src/classes/callbacks/PostTearInitVeryLate.ts +33 -0
- package/src/classes/callbacks/PostTransformation.ts +71 -0
- package/src/classes/callbacks/PreBerserkDeath.ts +5 -8
- package/src/classes/callbacks/PreItemPickup.ts +11 -0
- package/src/classes/callbacks/validation/CustomCallbackCollectibleType.ts +32 -0
- package/src/classes/callbacks/validation/CustomCallbackItemPickup.ts +48 -0
- package/src/classes/callbacks/validation/CustomCallbackLaser.ts +27 -0
- package/src/classes/callbacks/validation/CustomCallbackNPC.ts +34 -0
- package/src/classes/callbacks/validation/CustomCallbackPickup.ts +41 -0
- package/src/classes/callbacks/validation/CustomCallbackPlayer.ts +25 -2
- package/src/classes/callbacks/validation/CustomCallbackPoop.ts +28 -0
- package/src/classes/callbacks/validation/CustomCallbackPressurePlate.ts +31 -0
- package/src/classes/callbacks/validation/CustomCallbackProjectile.ts +28 -0
- package/src/classes/callbacks/validation/CustomCallbackRock.ts +30 -0
- package/src/classes/callbacks/validation/CustomCallbackSlot.ts +37 -0
- package/src/classes/callbacks/validation/CustomCallbackSpikes.ts +4 -4
- package/src/classes/callbacks/validation/CustomCallbackTNT.ts +28 -0
- package/src/classes/callbacks/validation/CustomCallbackTear.ts +27 -0
- package/src/classes/features/callbackLogic/CustomGridEntities.ts +32 -36
- package/src/classes/features/callbackLogic/CustomRevive.ts +14 -21
- package/src/classes/features/callbackLogic/EsauJrDetection.ts +0 -4
- package/src/classes/features/callbackLogic/GameReorderedCallbacks.ts +7 -9
- package/src/classes/features/callbackLogic/GridEntityCollisionDetection.ts +0 -4
- package/src/classes/features/callbackLogic/GridEntityRenderDetection.ts +42 -0
- package/src/classes/features/callbackLogic/{GridEntityDetection.ts → GridEntityUpdateDetection.ts} +4 -20
- package/src/classes/features/callbackLogic/ItemPickupDetection.ts +91 -0
- package/src/classes/features/callbackLogic/PlayerCollectibleDetection.ts +245 -0
- package/src/classes/features/callbackLogic/SlotRenderDetection.ts +64 -0
- package/src/classes/features/callbackLogic/SlotUpdateDetection.ts +57 -0
- package/src/classes/features/other/RunInNFrames.ts +7 -0
- package/src/classes/features/other/SaveDataManager.ts +492 -0
- package/src/classes/features/other/saveDataManager/glowingHourGlass.ts +138 -0
- package/src/classes/features/other/saveDataManager/loadFromDisk.ts +99 -0
- package/src/classes/features/other/saveDataManager/restoreDefaults.ts +116 -0
- package/src/classes/features/other/saveDataManager/saveToDisk.ts +70 -0
- package/src/classes/private/CustomCallback.ts +2 -6
- package/src/classes/private/Feature.ts +1 -0
- package/src/core/upgradeMod.ts +6 -13
- package/src/decorators.ts +17 -16
- package/src/enums/ISCFeature.ts +44 -39
- package/src/enums/ModCallbackCustom.ts +34 -20
- package/src/enums/ModCallbackCustom2.ts +53 -5
- package/src/enums/{private/SerializationBrand.ts → SerializationBrand.ts} +8 -2
- package/src/features/customItemPool.ts +133 -0
- package/src/features/deployJSONRoom.ts +6 -4
- package/src/features/fadeInRemover.ts +4 -22
- package/src/features/saveDataManager/exports.ts +62 -3
- package/src/features/saveDataManager/load.ts +4 -1
- package/src/features/saveDataManager/main.ts +5 -3
- package/src/features/saveDataManager/maps.ts +16 -0
- package/src/features.ts +39 -4
- package/src/functions/array.ts +8 -9
- package/src/functions/bitSet128.ts +3 -3
- package/src/functions/color.ts +3 -3
- package/src/functions/decorators.ts +83 -12
- package/src/functions/deepCopy.ts +83 -17
- package/src/functions/deepCopyTests.ts +1 -1
- package/src/functions/initArray.ts +6 -11
- package/src/functions/jsonRoom.ts +11 -0
- package/src/functions/kColor.ts +3 -3
- package/src/functions/logMisc.ts +28 -2
- package/src/{features/saveDataManager → functions}/merge.ts +79 -45
- package/src/functions/mergeTests.ts +2 -3
- package/src/functions/rng.ts +3 -3
- package/src/functions/serialization.ts +25 -1
- package/src/functions/table.ts +1 -1
- package/src/functions/tstlClass.ts +3 -57
- package/src/functions/vector.ts +3 -3
- package/src/functions/weighted.ts +28 -11
- package/src/index.ts +5 -0
- package/src/interfaces/SaveData.ts +3 -34
- package/src/interfaces/private/AddCallbackParametersCustom2.ts +298 -7
- package/src/objects/isaacAPIClassTypeToBrand.ts +1 -1
- package/src/types/AnyClass.ts +1 -0
- package/src/types/AnyFunction.ts +5 -0
- package/src/types/FunctionTuple.ts +3 -4
- package/src/types/HasFunction.ts +7 -0
- package/dist/src/classes/callbacks/validation/CustomCallbackRevive.d.ts.map +0 -1
- package/dist/src/classes/callbacks/validation/CustomCallbackRevive.lua +0 -19
- package/dist/src/classes/features/callbackLogic/GridEntityDetection.d.ts.map +0 -1
- package/dist/src/enums/private/SerializationBrand.d.ts.map +0 -1
- package/dist/src/features/saveDataManager/merge.d.ts +0 -26
- package/dist/src/features/saveDataManager/merge.d.ts.map +0 -1
- package/dist/src/features/saveDataManager/serializationBrands.d.ts +0 -2
- package/dist/src/features/saveDataManager/serializationBrands.d.ts.map +0 -1
- package/dist/src/features/saveDataManager/serializationBrands.lua +0 -19
- package/dist/src/indexLua.d.ts +0 -199
- package/dist/src/indexLua.d.ts.map +0 -1
- package/dist/src/indexLua.lua +0 -1354
- package/src/classes/callbacks/validation/CustomCallbackRevive.ts +0 -27
- 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
|
-
|
|
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
|
-
|
|
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
|
|
5
|
-
*
|
|
6
|
-
*
|
|
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
|
-
|
|
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.
|
|
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.
|
|
214
|
-
|
|
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
|
-
/**
|
|
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
|
-
|
|
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
|
-
|
|
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 {
|
|
3
|
+
import {
|
|
4
|
+
CustomCallback,
|
|
5
|
+
FireArgs,
|
|
6
|
+
OptionalArgs,
|
|
7
|
+
} from "../private/CustomCallback";
|
|
4
8
|
|
|
5
|
-
|
|
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
|
}
|
|
@@ -12,7 +12,7 @@ export class PostGridEntityCollision extends CustomCallback<T> {
|
|
|
12
12
|
constructor() {
|
|
13
13
|
super();
|
|
14
14
|
|
|
15
|
-
this.featuresUsed = [ISCFeature.
|
|
15
|
+
this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
// eslint-disable-next-line class-methods-use-this
|
|
@@ -12,7 +12,7 @@ export class PostGridEntityCustomCollision extends CustomCallback<T> {
|
|
|
12
12
|
constructor() {
|
|
13
13
|
super();
|
|
14
14
|
|
|
15
|
-
this.featuresUsed = [ISCFeature.
|
|
15
|
+
this.featuresUsed = [ISCFeature.GRID_ENTITY_UPDATE_DETECTION];
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
// eslint-disable-next-line class-methods-use-this
|
|
@@ -12,7 +12,7 @@ export class PostGridEntityCustomRemove extends CustomCallback<T> {
|
|
|
12
12
|
constructor() {
|
|
13
13
|
super();
|
|
14
14
|
|
|
15
|
-
this.featuresUsed = [ISCFeature.
|
|
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
|
+
}
|
|
@@ -12,7 +12,7 @@ export class PostGridEntityRemove extends CustomCallback<T> {
|
|
|
12
12
|
constructor() {
|
|
13
13
|
super();
|
|
14
14
|
|
|
15
|
-
this.featuresUsed = [ISCFeature.
|
|
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
|
+
}
|
|
@@ -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.
|
|
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
|
-
//
|
|
30
|
-
private
|
|
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,
|