isaacscript-common 4.0.0 → 4.0.1-dev.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 (387) hide show
  1. package/cachedClasses.ts +39 -0
  2. package/callbacks/customRevive.lua +2 -1
  3. package/callbacks/customRevive.ts +215 -0
  4. package/callbacks/itemPickup.ts +101 -0
  5. package/callbacks/postAmbush.ts +73 -0
  6. package/callbacks/postBombExploded.ts +26 -0
  7. package/callbacks/postBombInitLate.ts +36 -0
  8. package/callbacks/postBoneSwing.ts +64 -0
  9. package/callbacks/postCollectibleInitFirst.ts +40 -0
  10. package/callbacks/postCursedTeleport.ts +183 -0
  11. package/callbacks/postCustomDoorEnter.lua +0 -7
  12. package/callbacks/postCustomDoorEnter.ts +292 -0
  13. package/callbacks/postDiceRoomActivated.ts +60 -0
  14. package/callbacks/postDoorRender.ts +26 -0
  15. package/callbacks/postDoorUpdate.ts +26 -0
  16. package/callbacks/postEffectInitLate.ts +36 -0
  17. package/callbacks/postEffectStateChanged.ts +43 -0
  18. package/callbacks/postEsauJr.ts +107 -0
  19. package/callbacks/postFamiliarInitLate.ts +36 -0
  20. package/callbacks/postFamiliarStateChanged.ts +43 -0
  21. package/callbacks/postFlip.ts +88 -0
  22. package/callbacks/postGreedModeWave.ts +41 -0
  23. package/callbacks/postGridEntity.ts +164 -0
  24. package/callbacks/postGridEntityCollision.ts +69 -0
  25. package/callbacks/postGridEntityRender.ts +26 -0
  26. package/callbacks/postHolyMantleRemoved.ts +55 -0
  27. package/callbacks/postItemDischarged.ts +149 -0
  28. package/callbacks/postKnifeInitLate.ts +36 -0
  29. package/callbacks/postLaserInitLate.ts +36 -0
  30. package/callbacks/postNPCInitLate.ts +36 -0
  31. package/callbacks/postNPCStateChanged.ts +42 -0
  32. package/callbacks/postNewRoomEarly.ts +90 -0
  33. package/callbacks/postPickupCollect.ts +48 -0
  34. package/callbacks/postPickupInitFirst.ts +70 -0
  35. package/callbacks/postPickupInitLate.ts +36 -0
  36. package/callbacks/postPickupStateChanged.ts +43 -0
  37. package/callbacks/postPitRender.ts +26 -0
  38. package/callbacks/postPitUpdate.ts +26 -0
  39. package/callbacks/postPlayerChangeHealth.ts +62 -0
  40. package/callbacks/postPlayerChangeType.ts +56 -0
  41. package/callbacks/postPlayerCollectible.ts +113 -0
  42. package/callbacks/postPlayerFatalDamage.ts +141 -0
  43. package/callbacks/postPlayerInitLate.ts +37 -0
  44. package/callbacks/postPlayerReordered.ts +142 -0
  45. package/callbacks/postPoopRender.ts +26 -0
  46. package/callbacks/postPoopUpdate.ts +26 -0
  47. package/callbacks/postPressurePlateRender.ts +26 -0
  48. package/callbacks/postPressurePlateUpdate.ts +26 -0
  49. package/callbacks/postProjectileInitLate.ts +36 -0
  50. package/callbacks/postPurchase.ts +64 -0
  51. package/callbacks/postRockRender.ts +26 -0
  52. package/callbacks/postRockUpdate.ts +26 -0
  53. package/callbacks/postRoomClearChanged.ts +57 -0
  54. package/callbacks/postSacrifice.ts +62 -0
  55. package/callbacks/postSlotDestroyed.ts +92 -0
  56. package/callbacks/postSlotInitUpdate.ts +68 -0
  57. package/callbacks/postSlotRender.ts +69 -0
  58. package/callbacks/postSpikesRender.ts +26 -0
  59. package/callbacks/postSpikesUpdate.ts +26 -0
  60. package/callbacks/postTNTRender.ts +26 -0
  61. package/callbacks/postTNTUpdate.ts +26 -0
  62. package/callbacks/postTearInitLate.ts +36 -0
  63. package/callbacks/postTearInitVeryLate.ts +41 -0
  64. package/callbacks/postTransformation.ts +59 -0
  65. package/callbacks/postTrinketBreak.ts +110 -0
  66. package/callbacks/preBerserkDeath.ts +49 -0
  67. package/callbacks/preNewLevel.ts +55 -0
  68. package/callbacks/reorderedCallbacks.ts +166 -0
  69. package/callbacks/subscriptions/postAmbushFinished.ts +32 -0
  70. package/callbacks/subscriptions/postAmbushStarted.ts +32 -0
  71. package/callbacks/subscriptions/postBombInitLate.ts +32 -0
  72. package/callbacks/subscriptions/postBoneExploded.ts +32 -0
  73. package/callbacks/subscriptions/postBoneSwing.ts +24 -0
  74. package/callbacks/subscriptions/postCollectibleInitFirst.ts +37 -0
  75. package/callbacks/subscriptions/postCursedTeleport.ts +24 -0
  76. package/callbacks/subscriptions/postCustomDoorEnter.ts +45 -0
  77. package/callbacks/subscriptions/postCustomRevive.ts +36 -0
  78. package/callbacks/subscriptions/postDiceRoomActivated.ts +38 -0
  79. package/callbacks/subscriptions/postDoorRender.ts +35 -0
  80. package/callbacks/subscriptions/postDoorUpdate.ts +35 -0
  81. package/callbacks/subscriptions/postEffectInitLate.ts +32 -0
  82. package/callbacks/subscriptions/postEffectStateChanged.ts +40 -0
  83. package/callbacks/subscriptions/postEsauJr.ts +24 -0
  84. package/callbacks/subscriptions/postFamiliarInitLate.ts +32 -0
  85. package/callbacks/subscriptions/postFamiliarStateChanged.ts +40 -0
  86. package/callbacks/subscriptions/postFirstEsauJr.ts +24 -0
  87. package/callbacks/subscriptions/postFirstFlip.ts +24 -0
  88. package/callbacks/subscriptions/postFlip.ts +22 -0
  89. package/callbacks/subscriptions/postGameStartedReordered.ts +24 -0
  90. package/callbacks/subscriptions/postGreedModeWave.ts +24 -0
  91. package/callbacks/subscriptions/postGridEntityBroken.ts +51 -0
  92. package/callbacks/subscriptions/postGridEntityCollision.ts +54 -0
  93. package/callbacks/subscriptions/postGridEntityInit.ts +51 -0
  94. package/callbacks/subscriptions/postGridEntityRemove.ts +52 -0
  95. package/callbacks/subscriptions/postGridEntityRender.ts +51 -0
  96. package/callbacks/subscriptions/postGridEntityStateChanged.ts +55 -0
  97. package/callbacks/subscriptions/postGridEntityUpdate.ts +51 -0
  98. package/callbacks/subscriptions/postHolyMantleRemoved.ts +48 -0
  99. package/callbacks/subscriptions/postItemDischarged.ts +43 -0
  100. package/callbacks/subscriptions/postItemPickup.ts +64 -0
  101. package/callbacks/subscriptions/postKnifeInitLate.ts +32 -0
  102. package/callbacks/subscriptions/postLaserInitLate.ts +32 -0
  103. package/callbacks/subscriptions/postNPCInitLate.ts +32 -0
  104. package/callbacks/subscriptions/postNPCStateChanged.ts +42 -0
  105. package/callbacks/subscriptions/postNewLevelReordered.ts +22 -0
  106. package/callbacks/subscriptions/postNewRoomEarly.ts +22 -0
  107. package/callbacks/subscriptions/postNewRoomReordered.ts +22 -0
  108. package/callbacks/subscriptions/postPEffectUpdateReordered.ts +40 -0
  109. package/callbacks/subscriptions/postPickupCollect.ts +35 -0
  110. package/callbacks/subscriptions/postPickupInitFirst.ts +32 -0
  111. package/callbacks/subscriptions/postPickupInitLate.ts +32 -0
  112. package/callbacks/subscriptions/postPickupStateChanged.ts +40 -0
  113. package/callbacks/subscriptions/postPitRender.ts +35 -0
  114. package/callbacks/subscriptions/postPitUpdate.ts +35 -0
  115. package/callbacks/subscriptions/postPlayerChangeHealth.ts +49 -0
  116. package/callbacks/subscriptions/postPlayerChangeType.ts +40 -0
  117. package/callbacks/subscriptions/postPlayerCollectibleAdded.ts +38 -0
  118. package/callbacks/subscriptions/postPlayerCollectibleRemoved.ts +38 -0
  119. package/callbacks/subscriptions/postPlayerFatalDamage.d.ts +1 -1
  120. package/callbacks/subscriptions/postPlayerFatalDamage.ts +68 -0
  121. package/callbacks/subscriptions/postPlayerInitLate.ts +40 -0
  122. package/callbacks/subscriptions/postPlayerInitReordered.ts +40 -0
  123. package/callbacks/subscriptions/postPlayerRenderReordered.ts +40 -0
  124. package/callbacks/subscriptions/postPlayerUpdateReordered.ts +40 -0
  125. package/callbacks/subscriptions/postPoopRender.ts +35 -0
  126. package/callbacks/subscriptions/postPoopUpdate.ts +35 -0
  127. package/callbacks/subscriptions/postPressurePlateRender.ts +37 -0
  128. package/callbacks/subscriptions/postPressurePlateUpdate.ts +37 -0
  129. package/callbacks/subscriptions/postProjectileInitLate.ts +35 -0
  130. package/callbacks/subscriptions/postPurchase.ts +31 -0
  131. package/callbacks/subscriptions/postRockRender.ts +35 -0
  132. package/callbacks/subscriptions/postRockUpdate.ts +35 -0
  133. package/callbacks/subscriptions/postRoomClearChanged.ts +30 -0
  134. package/callbacks/subscriptions/postSacrifice.ts +43 -0
  135. package/callbacks/subscriptions/postSlotAnimationChanged.ts +40 -0
  136. package/callbacks/subscriptions/postSlotDestroyed.ts +55 -0
  137. package/callbacks/subscriptions/postSlotInit.ts +32 -0
  138. package/callbacks/subscriptions/postSlotRender.ts +32 -0
  139. package/callbacks/subscriptions/postSlotUpdate.ts +32 -0
  140. package/callbacks/subscriptions/postSpikesRender.ts +35 -0
  141. package/callbacks/subscriptions/postSpikesUpdate.ts +35 -0
  142. package/callbacks/subscriptions/postTNTRender.ts +35 -0
  143. package/callbacks/subscriptions/postTNTUpdate.ts +35 -0
  144. package/callbacks/subscriptions/postTearInitLate.ts +32 -0
  145. package/callbacks/subscriptions/postTearInitVeryLate.ts +32 -0
  146. package/callbacks/subscriptions/postTransformation.ts +40 -0
  147. package/callbacks/subscriptions/postTrinketBreak.ts +38 -0
  148. package/callbacks/subscriptions/preBerserkDeath.ts +42 -0
  149. package/callbacks/subscriptions/preCustomRevive.d.ts +1 -1
  150. package/callbacks/subscriptions/preCustomRevive.ts +46 -0
  151. package/callbacks/subscriptions/preItemPickup.ts +64 -0
  152. package/callbacks/subscriptions/preNewLevel.ts +24 -0
  153. package/classes/DefaultMap.ts +174 -0
  154. package/classes/ModUpgraded.ts +77 -0
  155. package/constants.ts +162 -0
  156. package/constantsFirstLast.ts +217 -0
  157. package/enums/AmbushType.ts +4 -0
  158. package/enums/HealthType.ts +16 -0
  159. package/enums/ModCallbackCustom.d.ts +2 -2
  160. package/enums/ModCallbackCustom.ts +1278 -0
  161. package/enums/PocketItemType.ts +8 -0
  162. package/enums/SerializationType.ts +5 -0
  163. package/enums/SlotDestructionType.ts +4 -0
  164. package/enums/private/CopyableIsaacAPIClassType.ts +7 -0
  165. package/enums/private/SaveDataKey.ts +14 -0
  166. package/enums/private/SerializationBrand.ts +42 -0
  167. package/features/characterHealthConversion.lua +2 -9
  168. package/features/characterHealthConversion.ts +111 -0
  169. package/features/characterStats.ts +61 -0
  170. package/features/debugDisplay/debugDisplay.ts +221 -0
  171. package/features/debugDisplay/exports.ts +368 -0
  172. package/features/debugDisplay/v.ts +65 -0
  173. package/features/deployJSONRoom.ts +743 -0
  174. package/features/disableInputs.ts +193 -0
  175. package/features/disableSound.ts +77 -0
  176. package/features/extraConsoleCommands/commandsDisplay.ts +290 -0
  177. package/features/extraConsoleCommands/commandsSubroutines.ts +139 -0
  178. package/features/extraConsoleCommands/init.ts +334 -0
  179. package/features/extraConsoleCommands/listCommands.ts +1299 -0
  180. package/features/extraConsoleCommands/v.ts +14 -0
  181. package/features/fadeInRemover.ts +60 -0
  182. package/features/fastReset.ts +75 -0
  183. package/features/forgottenSwitch.ts +50 -0
  184. package/features/getCollectibleItemPoolType.ts +66 -0
  185. package/features/persistentEntities.ts +183 -0
  186. package/features/playerInventory.ts +133 -0
  187. package/features/ponyDetection.ts +74 -0
  188. package/features/preventCollectibleRotation.ts +115 -0
  189. package/features/runInNFrames.ts +148 -0
  190. package/features/saveDataManager/constants.ts +4 -0
  191. package/features/saveDataManager/exports.ts +229 -0
  192. package/features/saveDataManager/load.ts +99 -0
  193. package/features/saveDataManager/main.ts +195 -0
  194. package/features/saveDataManager/maps.ts +13 -0
  195. package/features/saveDataManager/merge.ts +194 -0
  196. package/features/saveDataManager/save.ts +74 -0
  197. package/features/saveDataManager/serializationBrand.ts +16 -0
  198. package/features/sirenHelpers.ts +129 -0
  199. package/features/taintedLazarusPlayers.ts +113 -0
  200. package/featuresInitialized.ts +20 -0
  201. package/functions/ambush.ts +47 -0
  202. package/functions/array.ts +410 -0
  203. package/functions/benchmark.ts +36 -0
  204. package/functions/bitwise.ts +24 -0
  205. package/functions/bombs.ts +12 -0
  206. package/functions/boss.ts +227 -0
  207. package/functions/cacheFlag.ts +12 -0
  208. package/functions/cards.ts +271 -0
  209. package/functions/challenges.ts +13 -0
  210. package/functions/character.ts +126 -0
  211. package/functions/charge.ts +237 -0
  212. package/functions/chargeBar.ts +67 -0
  213. package/functions/collectibleCacheFlag.ts +90 -0
  214. package/functions/collectibleSet.ts +56 -0
  215. package/functions/collectibleTag.ts +89 -0
  216. package/functions/collectibles.ts +659 -0
  217. package/functions/color.lua +0 -7
  218. package/functions/color.ts +128 -0
  219. package/functions/debug.ts +68 -0
  220. package/functions/deepCopy.lua +46 -51
  221. package/functions/deepCopy.ts +535 -0
  222. package/functions/deepCopyTests.ts +386 -0
  223. package/functions/direction.ts +49 -0
  224. package/functions/doors.ts +347 -0
  225. package/functions/easing.ts +182 -0
  226. package/functions/eden.ts +47 -0
  227. package/functions/effects.ts +20 -0
  228. package/functions/entity.ts +439 -0
  229. package/functions/entitySpecific.ts +889 -0
  230. package/functions/entityTypes.ts +6 -0
  231. package/functions/enums.ts +146 -0
  232. package/functions/familiars.ts +106 -0
  233. package/functions/flag.ts +165 -0
  234. package/functions/flying.ts +117 -0
  235. package/functions/globals.ts +242 -0
  236. package/functions/gridEntity.ts +511 -0
  237. package/functions/gridEntitySpecific.ts +112 -0
  238. package/functions/input.ts +139 -0
  239. package/functions/isaacAPIClass.ts +67 -0
  240. package/functions/jsonHelpers.ts +45 -0
  241. package/functions/jsonRoom.ts +100 -0
  242. package/functions/kColor.lua +0 -7
  243. package/functions/kColor.ts +129 -0
  244. package/functions/language.ts +13 -0
  245. package/functions/level.ts +31 -0
  246. package/functions/log.ts +720 -0
  247. package/functions/map.ts +56 -0
  248. package/functions/math.ts +149 -0
  249. package/functions/mergeTests.ts +288 -0
  250. package/functions/npc.ts +148 -0
  251. package/functions/pickupVariants.ts +60 -0
  252. package/functions/pickups.ts +499 -0
  253. package/functions/pills.ts +205 -0
  254. package/functions/player.lua +0 -6
  255. package/functions/player.ts +1060 -0
  256. package/functions/playerDataStructures.ts +150 -0
  257. package/functions/playerHealth.lua +28 -39
  258. package/functions/playerHealth.ts +382 -0
  259. package/functions/playerIndex.ts +195 -0
  260. package/functions/pocketItems.ts +149 -0
  261. package/functions/positionVelocity.ts +188 -0
  262. package/functions/random.ts +77 -0
  263. package/functions/revive.ts +201 -0
  264. package/functions/rng.lua +0 -7
  265. package/functions/rng.ts +172 -0
  266. package/functions/roomData.ts +199 -0
  267. package/functions/roomGrid.ts +109 -0
  268. package/functions/roomShape.ts +80 -0
  269. package/functions/rooms.ts +648 -0
  270. package/functions/run.ts +36 -0
  271. package/functions/saveFile.ts +128 -0
  272. package/functions/seeds.ts +19 -0
  273. package/functions/serialization.ts +91 -0
  274. package/functions/set.ts +95 -0
  275. package/functions/sound.ts +9 -0
  276. package/functions/spawnCollectible.ts +104 -0
  277. package/functions/sprite.ts +107 -0
  278. package/functions/stage.ts +125 -0
  279. package/functions/string.ts +47 -0
  280. package/functions/table.ts +189 -0
  281. package/functions/tears.ts +32 -0
  282. package/functions/transformations.ts +131 -0
  283. package/functions/trinketCacheFlag.ts +60 -0
  284. package/functions/trinketGive.ts +157 -0
  285. package/functions/trinkets.ts +215 -0
  286. package/functions/tstlClass.ts +157 -0
  287. package/functions/types.ts +36 -0
  288. package/functions/ui.ts +138 -0
  289. package/functions/utils.d.ts +0 -37
  290. package/functions/utils.lua +0 -35
  291. package/functions/utils.ts +189 -0
  292. package/functions/vector.lua +0 -7
  293. package/functions/vector.ts +126 -0
  294. package/index.ts +172 -0
  295. package/initCustomCallbacks.ts +132 -0
  296. package/initFeatures.ts +39 -0
  297. package/interfaces/AddCallbackParameterCustom.ts +188 -0
  298. package/interfaces/ChargeBarSprites.ts +12 -0
  299. package/interfaces/JSONDoor.d.ts +3 -3
  300. package/interfaces/JSONDoor.ts +13 -0
  301. package/interfaces/JSONEntity.d.ts +4 -4
  302. package/interfaces/JSONEntity.ts +16 -0
  303. package/interfaces/JSONRoom.d.ts +8 -8
  304. package/interfaces/JSONRoom.ts +36 -0
  305. package/interfaces/JSONRooms.ts +12 -0
  306. package/interfaces/JSONSpawn.d.ts +2 -2
  307. package/interfaces/JSONSpawn.ts +14 -0
  308. package/interfaces/PlayerHealth.ts +16 -0
  309. package/interfaces/PocketItemDescription.ts +9 -0
  310. package/interfaces/SaveData.ts +29 -0
  311. package/interfaces/TrinketSituation.ts +9 -0
  312. package/interfaces/private/TSTLClassMetatable.ts +8 -0
  313. package/maps/PHDPillConversions.ts +21 -0
  314. package/maps/cardMap.ts +209 -0
  315. package/maps/characterMap.ts +87 -0
  316. package/maps/collectibleDescriptionMap.ts +732 -0
  317. package/maps/collectibleNameMap.ts +731 -0
  318. package/maps/defaultPlayerStatMap.ts +17 -0
  319. package/maps/falsePHDPillConversions.ts +35 -0
  320. package/maps/gridEntityTypeToBrokenStateMap.ts +50 -0
  321. package/maps/gridEntityXMLMap.ts +176 -0
  322. package/maps/pillEffectMap.ts +88 -0
  323. package/maps/roomShapeToTopLeftWallGridIndexMap.ts +18 -0
  324. package/maps/roomTypeMap.ts +40 -0
  325. package/maps/trinketDescriptionMap.ts +200 -0
  326. package/maps/trinketNameMap.ts +198 -0
  327. package/objects/LRoomShapeToRectangles.ts +44 -0
  328. package/objects/callbackRegisterFunctions.ts +187 -0
  329. package/objects/cardDescriptions.ts +105 -0
  330. package/objects/cardNames.ts +105 -0
  331. package/objects/cardTypes.ts +104 -0
  332. package/objects/challengeNames.ts +52 -0
  333. package/objects/characterNames.ts +48 -0
  334. package/objects/coinSubTypeToValue.ts +14 -0
  335. package/objects/colors.ts +16 -0
  336. package/objects/directionNames.ts +11 -0
  337. package/objects/directionToDegrees.ts +11 -0
  338. package/objects/directionToVector.ts +12 -0
  339. package/objects/doorSlotFlagToDoorSlot.ts +16 -0
  340. package/objects/doorSlotToDirection.ts +14 -0
  341. package/objects/isaacAPIClassTypeToBrand.ts +11 -0
  342. package/objects/isaacAPIClassTypeToCopyFunction.ts +18 -0
  343. package/objects/languageNames.ts +13 -0
  344. package/objects/oppositeDoorSlots.ts +15 -0
  345. package/objects/pillEffectClasses.ts +63 -0
  346. package/objects/pillEffectNames.ts +57 -0
  347. package/objects/pillEffectTypes.ts +62 -0
  348. package/objects/roomShapeBounds.ts +71 -0
  349. package/objects/roomShapeLayoutSizes.ts +45 -0
  350. package/objects/roomShapeToBottomRightPosition.ts +25 -0
  351. package/objects/roomShapeToDoorSlots.ts +83 -0
  352. package/objects/roomShapeToDoorSlotsToGridIndexDelta.ts +127 -0
  353. package/objects/roomShapeToGridWidth.ts +21 -0
  354. package/objects/roomShapeToTopLeftPosition.ts +26 -0
  355. package/objects/roomShapeVolumes.ts +38 -0
  356. package/objects/roomTypeNames.ts +36 -0
  357. package/objects/serializedIsaacAPIClassTypeToIdentityFunction.ts +14 -0
  358. package/objects/stageTypeToLetter.ts +15 -0
  359. package/objects/transformationNames.d.ts +0 -1
  360. package/objects/transformationNames.lua +0 -1
  361. package/objects/transformationNames.ts +18 -0
  362. package/package.json +1 -1
  363. package/patchErrorFunctions.ts +92 -0
  364. package/sets/LRoomShapesSet.ts +8 -0
  365. package/sets/bossSets.ts +470 -0
  366. package/sets/charactersThatStartWithAnActiveItemSet.ts +16 -0
  367. package/sets/charactersWithBlackHeartFromEternalHeartSet.ts +7 -0
  368. package/sets/charactersWithFreeDevilDealsSet.ts +4 -0
  369. package/sets/charactersWithNoRedHeartsSet.ts +17 -0
  370. package/sets/charactersWithNoSoulHeartsSet.ts +14 -0
  371. package/sets/chestPickupVariantsSet.ts +16 -0
  372. package/sets/familiarsThatShootPlayerTearsSet.ts +13 -0
  373. package/sets/lostStyleCharactersSet.ts +13 -0
  374. package/sets/mineShaftRoomSubTypesSet.ts +10 -0
  375. package/sets/redHeartSubTypesSet.ts +7 -0
  376. package/sets/sinEntityTypesSet.ts +11 -0
  377. package/sets/singleUseActiveCollectibleTypesSet.ts +13 -0
  378. package/sets/storyBossesSet.ts +17 -0
  379. package/types/AnyEntity.ts +12 -0
  380. package/types/AwaitingTextInput.d.ts +2 -0
  381. package/types/CollectibleIndex.ts +16 -0
  382. package/types/PickingUpItem.ts +89 -0
  383. package/types/PlayerIndex.ts +13 -0
  384. package/types/private/IsaacAPIClass.ts +3 -0
  385. package/types/private/SerializedIsaacAPIClass.ts +3 -0
  386. package/types/private/TSTLClass.ts +3 -0
  387. package/upgradeMod.ts +55 -0
@@ -0,0 +1,439 @@
1
+ import { EntityType } from "isaac-typescript-definitions";
2
+ import { game } from "../cachedClasses";
3
+ import { VectorZero } from "../constants";
4
+ import { STORY_BOSSES_SET } from "../sets/storyBossesSet";
5
+ import { AnyEntity } from "../types/AnyEntity";
6
+ import { getIsaacAPIClassName } from "./isaacAPIClass";
7
+ import { getRandom } from "./random";
8
+ import { newRNG } from "./rng";
9
+ import { isPrimitive } from "./types";
10
+
11
+ /**
12
+ * Helper function to count the number of entities in room. Use this over the vanilla
13
+ * `Isaac.CountEntities` method to avoid having to specify a spawner and to handle ignoring charmed
14
+ * enemies.
15
+ *
16
+ * @param entityType Default is -1. -1 matches every entity type.
17
+ * @param variant Default is -1. -1 matches every variant.
18
+ * @param subType Default is -1. -1 matches every sub-type.
19
+ * @param ignoreFriendly Default is false.
20
+ */
21
+ export function countEntities(
22
+ entityType: EntityType = -1,
23
+ variant = -1,
24
+ subType = -1,
25
+ ignoreFriendly = false,
26
+ ): int {
27
+ if (!ignoreFriendly) {
28
+ return Isaac.CountEntities(undefined, entityType, variant, subType);
29
+ }
30
+
31
+ const entities = Isaac.FindByType(
32
+ entityType,
33
+ variant,
34
+ subType,
35
+ false,
36
+ ignoreFriendly,
37
+ );
38
+
39
+ return entities.length;
40
+ }
41
+
42
+ /**
43
+ * Helper function to check if one or more of a specific kind of entity is present in the current
44
+ * room. It uses the `countEntities` helper function to determine this.
45
+ *
46
+ * @param entityType Default is -1. -1 matches every entity type.
47
+ * @param variant Default is -1. -1 matches every variant.
48
+ * @param subType Default is -1. -1 matches every sub-type.
49
+ * @param ignoreFriendly Default is false.
50
+ */
51
+ export function doesEntityExist(
52
+ entityType: EntityType = -1,
53
+ variant = -1,
54
+ subType = -1,
55
+ ignoreFriendly = false,
56
+ ): boolean {
57
+ const count = countEntities(entityType, variant, subType, ignoreFriendly);
58
+ return count > 0;
59
+ }
60
+
61
+ /**
62
+ * Given an array of entities, this helper function returns the closest one to a provided reference
63
+ * entity.
64
+ *
65
+ * For example:
66
+ *
67
+ * ```ts
68
+ * const player = Isaac.GetPlayer();
69
+ * const gapers = getEntities(EntityType.GAPER);
70
+ * const closestGaper = getClosestEntityTo(player, gapers);
71
+ * ```
72
+ */
73
+ export function getClosestEntityTo<T extends AnyEntity>(
74
+ referenceEntity: Entity,
75
+ entities: T[],
76
+ ): T | undefined {
77
+ let closestEntity: T | undefined;
78
+ let closestDistance = math.huge;
79
+ for (const entity of entities) {
80
+ const distance = referenceEntity.Position.Distance(entity.Position);
81
+
82
+ if (distance < closestDistance) {
83
+ closestEntity = entity;
84
+ closestDistance = distance;
85
+ }
86
+ }
87
+
88
+ return closestEntity;
89
+ }
90
+
91
+ /**
92
+ * Helper function to get all of the entities in the room or all of the entities that match a
93
+ * specific entity type / variant / sub-type.
94
+ *
95
+ * Due to bugs with `Isaac.FindInRadius`, this function uses `Isaac.GetRoomEntities`, which is more
96
+ * expensive but also more robust. (If a matching entity type is provided, then `Isaac.FindByType`
97
+ * will be used instead.)
98
+ *
99
+ * For example:
100
+ *
101
+ * ```ts
102
+ * // Make all of the entities in the room invisible
103
+ * for (const entity of getEntities()) {
104
+ * entity.Visible = false;
105
+ * }
106
+ * ```
107
+ *
108
+ * @param entityType Optional. If specified, will only return NPCs that match this entity type.
109
+ * @param variant Optional. If specified, will only return NPCs that match this variant. Default is
110
+ * -1. -1 matches every variant.
111
+ * @param subType Optional. If specified, will only return NPCs that match this sub-type. Default is
112
+ * -1. -1 matches every sub-type.
113
+ * @param ignoreFriendly Optional. If set to true, it will exclude friendly NPCs from being
114
+ * returned. Default is false. Will only be taken into account if
115
+ * `matchingEntityType` is specified.
116
+ */
117
+ export function getEntities(
118
+ entityType?: EntityType,
119
+ variant = -1,
120
+ subType = -1,
121
+ ignoreFriendly = false,
122
+ ): Entity[] {
123
+ if (entityType === undefined) {
124
+ return Isaac.GetRoomEntities();
125
+ }
126
+
127
+ return Isaac.FindByType(entityType, variant, subType, ignoreFriendly);
128
+ }
129
+
130
+ /**
131
+ * Helper function to get all the fields on an entity. For example, this is useful for comparing it
132
+ * to another entity later.
133
+ *
134
+ * This function will only get fields that are equal to booleans, numbers, or strings, as comparing
135
+ * other types is non-trivial.
136
+ */
137
+ export function getEntityFields(
138
+ entity: Entity,
139
+ ): LuaTable<string, boolean | number | string> {
140
+ const entityFields = new LuaTable<string, boolean | number | string>();
141
+
142
+ const metatable = getmetatable(entity) as
143
+ | LuaTable<AnyNotNil, unknown>
144
+ | undefined;
145
+ if (metatable === undefined) {
146
+ error("Failed to get the metatable for an entity.");
147
+ }
148
+
149
+ setPrimitiveEntityFields(entity, metatable, entityFields);
150
+
151
+ // If this is a class that inherits from `Entity` (like `EntityPlayer`), the "__propget" table
152
+ // will not contain the attributes for `Entity`. Thus, if this is not an `Entity`, we have
153
+ // additional fields to add.
154
+ const className = getIsaacAPIClassName(entity);
155
+ if (className === "Entity") {
156
+ return entityFields;
157
+ }
158
+
159
+ const parentTable = metatable.get("__parent") as
160
+ | LuaTable<AnyNotNil, unknown>
161
+ | undefined;
162
+ if (parentTable === undefined) {
163
+ error('Failed to get the "__parent" table for an entity.');
164
+ }
165
+
166
+ setPrimitiveEntityFields(entity, parentTable, entityFields);
167
+
168
+ return entityFields;
169
+ }
170
+
171
+ function setPrimitiveEntityFields(
172
+ entity: Entity,
173
+ metatable: LuaTable<AnyNotNil, unknown>,
174
+ entityFields: LuaTable<string, boolean | number | string>,
175
+ ) {
176
+ const propGetTable = metatable.get("__propget") as
177
+ | LuaTable<AnyNotNil, unknown>
178
+ | undefined;
179
+ if (propGetTable === undefined) {
180
+ error('Failed to get the "__propget" table for an entity.');
181
+ }
182
+
183
+ for (const [key] of pairs(propGetTable)) {
184
+ // The values of this table are functions. Thus, we use the key to index the original entity.
185
+ const indexKey = key as keyof typeof entity;
186
+ const value = entity[indexKey];
187
+ if (isPrimitive(value)) {
188
+ entityFields.set(indexKey, value);
189
+ }
190
+ }
191
+ }
192
+
193
+ /** Helper function to return a string containing the entity's type, variant, and sub-type. */
194
+ export function getEntityID(entity: Entity): string {
195
+ return `${entity.Type}.${entity.Variant}.${entity.SubType}`;
196
+ }
197
+
198
+ /**
199
+ * Helper function to compare two different arrays of entities. Returns the entities that are in the
200
+ * second array but not in the first array.
201
+ */
202
+ export function getFilteredNewEntities<T extends AnyEntity>(
203
+ oldEntities: T[],
204
+ newEntities: T[],
205
+ ): T[] {
206
+ const oldEntitiesSet = new Set<PtrHash>();
207
+ for (const entity of oldEntities) {
208
+ const ptrHash = GetPtrHash(entity);
209
+ oldEntitiesSet.add(ptrHash);
210
+ }
211
+
212
+ return newEntities.filter((entity) => {
213
+ const ptrHash = GetPtrHash(entity);
214
+ return !oldEntitiesSet.has(ptrHash);
215
+ });
216
+ }
217
+
218
+ /**
219
+ * Helper function to measure an entity's velocity to see if it is moving.
220
+ *
221
+ * @param entity The entity whose velocity to measure.
222
+ * @param threshold Optional. The threshold from 0 to consider to be moving. Default is 0.01.
223
+ */
224
+ export function isEntityMoving(entity: Entity, threshold = 0.01): boolean {
225
+ return entity.Velocity.Length() >= threshold;
226
+ }
227
+
228
+ /**
229
+ * Helper function to determine if the specified entity type is an end-game story boss, like Isaac,
230
+ * Blue Baby, Mega Satan, The Beast, and so on. This is useful because certain effects should only
231
+ * apply to non-story bosses, like Vanishing Twin. Also see the `STORY_BOSSES` constant.
232
+ */
233
+ export function isStoryBoss(entityType: EntityType): boolean {
234
+ return STORY_BOSSES_SET.has(entityType);
235
+ }
236
+
237
+ /**
238
+ * Helper function to parse a string that contains an entity type, a variant, and a sub-type,
239
+ * separated by periods.
240
+ *
241
+ * For example, passing "45.0.1" would return an array of [45, 0, 1].
242
+ *
243
+ * Returns undefined if the string cannot be parsed.
244
+ */
245
+ export function parseEntityID(
246
+ entityID: string,
247
+ ): [entityType: EntityType, variant: int, subType: int] | undefined {
248
+ const entityIDArray = entityID.split(".");
249
+ if (entityIDArray.length !== 3) {
250
+ return undefined;
251
+ }
252
+
253
+ const [entityTypeString, variantString, subTypeString] = entityIDArray;
254
+
255
+ const entityType = tonumber(entityTypeString);
256
+ if (entityType === undefined) {
257
+ return undefined;
258
+ }
259
+
260
+ const variant = tonumber(variantString);
261
+ if (variant === undefined) {
262
+ return undefined;
263
+ }
264
+
265
+ const subType = tonumber(subTypeString);
266
+ if (subType === undefined) {
267
+ return undefined;
268
+ }
269
+
270
+ return [entityType, variant, subType];
271
+ }
272
+
273
+ /**
274
+ * Helper function to parse a string that contains an entity type and a variant separated by a
275
+ * period.
276
+ *
277
+ * For example, passing "45.0" would return an array of [45, 0].
278
+ *
279
+ * Returns undefined if the string cannot be parsed.
280
+ */
281
+ export function parseEntityTypeVariantString(
282
+ entityTypeVariantString: string,
283
+ ): [entityType: EntityType, variant: int] | undefined {
284
+ const entityTypeVariantArray = entityTypeVariantString.split(".");
285
+ if (entityTypeVariantArray.length !== 2) {
286
+ return undefined;
287
+ }
288
+
289
+ const [entityTypeString, variantString] = entityTypeVariantArray;
290
+
291
+ const entityType = tonumber(entityTypeString);
292
+ if (entityType === undefined) {
293
+ return undefined;
294
+ }
295
+
296
+ const variant = tonumber(variantString);
297
+ if (variant === undefined) {
298
+ return undefined;
299
+ }
300
+
301
+ return [entityType, variant];
302
+ }
303
+
304
+ /**
305
+ * Helper function to remove all of the matching entities in the room.
306
+ *
307
+ * @param entityType The entity type to match.
308
+ * @param entityVariant Optional. The variant to match. Default is -1. -1 matches every variant.
309
+ * @param entitySubType Optional. The sub-type to match. Default is -1. -1 matches every sub-type.
310
+ * @param cap Optional. If specified, will only remove the given amount of collectibles.
311
+ * @returns An array of the entities that were removed.
312
+ */
313
+ export function removeAllMatchingEntities(
314
+ entityType: EntityType,
315
+ entityVariant = -1,
316
+ entitySubType = -1,
317
+ cap: int | undefined = undefined,
318
+ ): Entity[] {
319
+ const entities = getEntities(entityType, entityVariant, entitySubType);
320
+ return removeEntities(entities, cap);
321
+ }
322
+
323
+ /**
324
+ * Helper function to remove all of the entities in the supplied array.
325
+ *
326
+ * @param entities The array of entities to remove.
327
+ * @param cap Optional. If specified, will only remove the given amount of entities.
328
+ * @returns An array of the entities that were removed.
329
+ */
330
+ export function removeEntities<T extends AnyEntity>(
331
+ entities: T[],
332
+ cap?: int,
333
+ ): T[] {
334
+ if (entities.length === 0) {
335
+ return [];
336
+ }
337
+
338
+ const entitiesRemoved: T[] = [];
339
+ for (const entity of entities) {
340
+ entity.Remove();
341
+
342
+ entitiesRemoved.push(entity);
343
+ if (cap !== undefined && entitiesRemoved.length >= cap) {
344
+ return entitiesRemoved;
345
+ }
346
+ }
347
+
348
+ return entitiesRemoved;
349
+ }
350
+
351
+ /**
352
+ * Helper function to reroll an enemy. Use this instead of the vanilla "Game.RerollEnemy" function
353
+ * if you want the rerolled enemy to be returned.
354
+ *
355
+ * @param entity The entity to reroll.
356
+ * @returns If the game failed to reroll the enemy, returns undefined. Otherwise, returns the
357
+ * rerolled entity.
358
+ */
359
+ export function rerollEnemy(entity: Entity): Entity | undefined {
360
+ const oldEntities = getEntities();
361
+ const wasRerolled = game.RerollEnemy(entity);
362
+ if (!wasRerolled) {
363
+ return undefined;
364
+ }
365
+
366
+ const newEntities = getEntities();
367
+ const filteredNewEntities = getFilteredNewEntities(oldEntities, newEntities);
368
+ if (filteredNewEntities.length === 0) {
369
+ error(
370
+ 'Failed to find the new entity generated by the "Game.RerollEnemy" method.',
371
+ );
372
+ }
373
+
374
+ return filteredNewEntities[0];
375
+ }
376
+
377
+ export function setEntityRandomColor(entity: Entity): void {
378
+ const rng = newRNG(entity.InitSeed);
379
+
380
+ const r = getRandom(rng);
381
+ const g = getRandom(rng);
382
+ const b = getRandom(rng);
383
+
384
+ const color = Color(r, g, b);
385
+ entity.SetColor(color, 100000, 100000, false, false);
386
+ }
387
+
388
+ /**
389
+ * Helper function to spawn an entity. Use this instead of the `Isaac.Spawn` method if you do not
390
+ * need to specify the velocity or spawner.
391
+ *
392
+ * Also see the `spawnWithSeed` helper function.
393
+ */
394
+ export function spawn(
395
+ entityType: EntityType,
396
+ variant: int,
397
+ subType: int,
398
+ position: Vector,
399
+ velocity = VectorZero,
400
+ spawner: Entity | undefined = undefined,
401
+ seed: Seed | undefined = undefined,
402
+ ): Entity {
403
+ if (seed === undefined) {
404
+ return Isaac.Spawn(
405
+ entityType,
406
+ variant,
407
+ subType,
408
+ position,
409
+ velocity,
410
+ spawner,
411
+ );
412
+ }
413
+
414
+ return game.Spawn(
415
+ entityType,
416
+ variant,
417
+ position,
418
+ velocity,
419
+ spawner,
420
+ subType,
421
+ seed,
422
+ );
423
+ }
424
+
425
+ /**
426
+ * Helper function to spawn an entity. Use this instead of the `Game.Spawn` method if you do not
427
+ * need to specify the velocity or spawner.
428
+ */
429
+ export function spawnWithSeed(
430
+ entityType: EntityType,
431
+ variant: int,
432
+ subType: int,
433
+ position: Vector,
434
+ seed: Seed,
435
+ velocity = VectorZero,
436
+ spawner: Entity | undefined = undefined,
437
+ ): Entity {
438
+ return spawn(entityType, variant, subType, position, velocity, spawner, seed);
439
+ }