RedWire's Plugin is a thing that I've been using mostly to help with my own mod-making experience. Hopefully, some of the additions from this plugin will be useful to other people :)
I'm not downgrading this plugin/supporting lower versions. Anyone is allowed to as long as I am credited but I won't be doing it myself.
Current mod versions: Forge 1.20.1, NeoForge 1.21.1
Current MCreator versions: 2024.1, 2024.2, 2024.3, 2024.4
(2024.1 and 2024.2 are only there because I still support Forge 1.20.1)
Procedures:
Actions:
- Copy properties of [block] onto [block] -- Copies all enum properties of the first blockstate onto the second blockstate
- Deal [number] custom damage to [entity] localized as [text] (.player/.item) with custom source [damagesource] -- The old "deal custom damage" procedure block, except with a completely customizable death message and editable procedure. I am aware this is not very useful with the creation of damage sources, however... I still have some uses for this so.. yeah. Also, since the official block has been deleted as of 2024.1, I unofficially declare this its successor.
- Execute command / [cmd] in the name of [entity] with permission level [number] -- Same thing as the regular "execute command" procedure block, except you can control how high the permissions can go. For example: If you have a command that executes a sub-command as a string, you can prevent players using /ban if they do not have OP privileges.
- Execute command / [cmd] at [x] [y] [z] with permission level [number] -- same thing as #3, but from a position instead of from a player.
- FORCE-add potion [potioneffect] with level [level] for [duration] ticks ambient [isambient] particles [showparticles] to [entity] - Allows you to give potion effects to entities that are normally immune to certain/all effects. In the instance of vanilla minecraft, you can apply whatever you want to the Wither and Ender dragon.
- Set attack target of [entity] to nothing -- Resets the attack target. Yes, this also exists within procedures+ but... I've only used 2 procedures from that plugin so.. sorry marwinekk256 ;(
- Set NoAI of [entity] to [boolean]
- Get object from registry [builtinregistry] class type: [class] registry id: [stringid] (Var name: "_regobject") -- This is something more catered to my mod specifically. With this, you can get a specific object that matches the given stringid. This does not have to include the namespace (ex: "minecraft:sharpness" OR "sharpness"), however, you should beware if there are conflicting mods that share the same id of the same object.
- Repeat [number] times as timedloopiterator with tick wait time [tick] -- Allows you to do something in a loop but have every action be delayed.
- (Break out/Continue with next iteration) of timed loop -- The normal break out/continue with next iteration block won't work with the timed loop block because the procedure uses a recursive call instead of an actual loop.
- Set invulnerable time of [entity] to [number] ticks -- Sets the invincibility-frames (AKA I-Frames) to the given number.
- For each text in [textToSplit] split as [Splitter] as stringiterator do [foreach] (or whole text if array is empty) -- The String.split method, but for mcreator use
- Un-tame [entity] -- Self-explanatory.
- For each entity in the current world as entityiterator do [foreach] -- Didn't like the range limit with the given entity iterator for MCreator, so I made my own version.
- Set ticks in timed loop to [number] -- Changes the tick wait time in #9 while the iteration is occurring.
- Set carried block of enderman [entity] to [blockstate] -- Changes the block the Enderman is carrying (if the entity is an Enderman)
- Remove block enderman [entity] is carrying -- Removes the block the Enderman is carrying (if the Entity is an Enderman)
- Directly set itemstack [variable] to [itemstack] -- The 2024.4 update made it so that setting itemstack variables will always return a copy of said variable instead of the direct itemstack. This procedure not only allows you to set itemstack variables to the direct item, but also removes ".copy()" from the inserted itemstack code, allowing you to always get the direct itemstack (exception being itemstack iterator). NOTE: There is a reason why Klemen changed this, only use this if you are sure this won't cause issues.
Data:
- Get (display) name of [blockstate]
- Is sound played same as [soundevent] (any sound played event)
- Get string id of dimension [entity] is in -- (example: minecraft:nether or minecraft:overworld)
- Get permission level of [entity] -- Always is 0 for non-player entities
- Has [entity] No AI
- Get distance between [entity] and [sourceentity] -- If sourceentity is null, returns -1
- Get distance between [x1] [y1] [z1] and [x2] [y2] [z2]
- Get entity from UUID [stringUUID] -- also exists within procedures+. I'm not stealing ideas i swear
- Get invulnerable time of [entity] in ticks
- Get display name of mod from id [modid] -- This applies only to currently active mods in your mod folder.
- Get version string of mod from id [modid] -- This applies only to currently active mods in your mod folder.
- Is [entity] moving - Requested by someone in the NeoToolKit discord.
- Get string id of the current worlds dimension
- Can [entity] find [sourceentity] -- Checks if sourceentity isn't obscured from entity behind blocks. Always returns false if the distance is greater than 128 (this is not my doing, just something that is part of the method I used)
- Create a clone of [entity]
- Is [entity] spectating [sourceentity]
- Get entity [entity] is spectating
- Get block that enderman [entity] is carrying
- Get X position of block inbetween [entity] and [sourceentity] -- Returns 0 if there is no block in the way
- Get Y position of block inbetween [entity] and [sourceentity] -- Returns 0 if there is no block in the way
- Get Z position of block inbetween [entity] and [sourceentity] -- Returns 0 if there is no block in the way
- Is [entity] flying
- Get the fall distance of [entity]
- Are Overlays hidden -- Overlays are hidden when you press F1, with this procedure check you can make your custom overlays also hide when F1 is pressed.
Event-specific Actions:
- Set damage to [amount] (before entity is hurt)
- Set output to [itemstack] (On anvil updated)
- Set break chance to [number] (Item output taken from anvil)
- Set break speed to [breakspeed] (Player block speed tick) -- Changes your break speed of the block to the given number
- Set canHarvest of block to [boolean] (Player harvest block tick) -- Whether or not the block being mined should drop its loot (does not act as the "silk touch" enchantment, so breaking a glass block with an item without the enchantment will still drop nothing)
- Set level cost to [amount] (On anvil updated) -- The level XP needed to upgrade an anvil item. The minimum amount needed is 1. Setting it to 0 will make it impossible to take the anvil output.
- Set material cost to [amount] (On anvil updated) -- The stack of items needed in item slot 2 to upgrade the item in slot 1
- Change sound to [soundevent] (Any sound played event)
- Is Entity Teleport event caused by [event type]
Global triggers:
- Entity teleports
- On anvil updated
- Item output taken from anvil
- Player harvest block tick -- does not fire for unbreakable blocks, such as bedrock.
- Player block speed tick -- does not fire for unbreakable blocks, such as bedrock. The breakspeed number variable represents your break speed, not the blocks hardness.
- Sound played at position
- Sound played from entity -- (Some sounds - from both sound events - cannot be changed unfortunately. Some of these i've noticed are block breaking sounds and the glass shattering sound when throwing a potion)
- Chunk loaded into world -- The isNewChunk variable will only return true in the serverside
- Entity being converted -- NOTE: the "entityOutcome" for this event isn't the actual entity it transforms to considering event.getOutcome() only returns an EntityType for LivingConversionEvent.Pre. Basically, this just means its a reference to the entity it transforms to, not the actual transformed entity.
Changelog
for the full list of changes, check this file
v3.4.0
- Added global trigger "Entity being converted"
- Added procedure "Is [entity] flying"
- Added procedure "Get the fall distance of [entity]"
- Added procedure "Are Overlays hidden"
- Added procedure "Directly set itemstack [variable] to [itemstack]"
Comments
if you know how to use basic code for code blocks, the thing to get invulnerablity time is "entity.invulnerableTime"
so if you wanna grab that value, you can use "Set number [variable name] to" and put "entity.invulnerableTime" with a code snippet
to change it, use the other custom code snippet. for example if I wanna change it to 0 to make an entity able to be hurt again, simply do "entity.invulnerableTime = 0;"
OH SORRY! I THOUGHT THAN "SET NOAI" IS ADDED WITH THIS PLUGIN BUT IT STILL GOOD!