
Disruption
A QuiltMC mod about cave-ins and falling blocks.
About this Mod
ONLY requires server installation. Client installation is OPTIONAL.
Does NOT affect world saves or any other form of NBT data.
Configuration for values such as HardnessScaling WILL be added as soon as configuration support is added to the Quilt Loader.
A mod about cave-ins and falling blocks - Blocks fall, and can cause damage!
Heavy inspiration from ye ol' Enviromine.
Significantly more performant and advanced than its Fabric predecessor, Block Physics.
Basic logic
Blocks search, traditionally, along 8 vectors on the X-Z plane.
Picture the movement pattern of a Queen in Chess.
Blocks have larger reach depending on their Hardness (how long it takes to mine the block) and their Blast Resistance (self-explanatory).
The equation for reach is: Math.max(Hardness * HardnessScaling, BlastResistance * BlastResistanceScaling), with reach having a maximum of 50 blocks.
The default HardnessScaling is 2, while BlastResistanceScaling is 1.
Along these vectors, blocks search for supports.
'Supports' are pillars of any number of blocks below a given position on a vector that reaches an encased position or a 'floating' block.
Encased positions are positions where a block is surrounded by other blocks on nearly all vectors in 3D space.
Disruption Events
Blocks only validate their supports, and check if they need to fall, if there is a Disruption Event.
Furthermore, only a limited range of blocks are validated per Disruption Event. This is defined by MaxBlockUpdates, whose default is 50.
Disruption Events are Game Events who fit into any or all of the related tags:
- [disruption:disruption] - Checks the position, and its neighbors.
- [disruption:entity_disruption] - The above, but only if there is an entity who caused the event.
- [disruption:neighbor_disruption] - Checks the position's neighbors only.
- [disruption:entity_neighbor_disruption] - The above, but only if there is an entity who caused the event.
The default set of Game Events are:
- [minecraft:block_place] in [disruption:entity_disruption], occurs when a block is placed.
- [minecraft:block_destroy] in [disruption:entity_neighbor_disruption], occurs when a block is destroyed.
- [disruption:fire_spread] in [disruption:neighbor_disruption], occurs when fire incinerates a block.
- [disruption:block_exploded] in [disruption:neighbor_disruption], occurs when a block is exploded (and subsequently destroyed).
Damage logic
Like Anvils, falling blocks deal damage based on the distance they fall.
The equation for the resultant damage is: (FallDistance - 1) * DamageModifier, where the maximum is DamageMax.
DamageModifier and DamageMax are calculated as so:
The default CaveInDamageScaling is 1.
DamageModifier = Hardness * 0.4 * CaveInDamageScaling
DamageMax = DamageModifier * 20
The reason why we calculate damage this way is to match the damage scaling of an Anvil, whose Hardness is 5.
'Floating' blocks
Floating blocks are blocks that do not require a support, and therefor float. They also act as a support to other blocks.
There are three reasons why such blocks exist:
- To lessen the impact this mod has on vanilla contraptions.
- To prevent this mod from impacting generated structures whose material is supposed to be unbreakable or nigh unbreakable.
- To allow Players to create floating structures.
Floating blocks fulfill any or all of the conditions below:
- Has a Blast Resistance of 1200 (Obsidian's Blast Resistance) or higher
- Is in the [disruption:floats] block tag
'Hanging' blocks
Hanging blocks are blocks whose supports can go upwards as well as downwards.
There are three reasons why such blocks exist:
- To prevent the Nether from caving-in every nanosecond.
- To allow End Islands to float.
- To allow Players to hang things from ceilings.
Hanging blocks fulfill any or all of the conditions below:
- Emits light
- Has the Glass sound effect, but is not slippery (slipperiness <= 0.6)
- Is in the [disruption:hangs] block tag
'Protected' blocks
Protected blocks are blocks whose calculated reach is always at least 3 blocks.
There are three reasons why such blocks exist:
- To prevent trees and giant mushrooms from COMPLETELY pruning themselves
- To prevent Glass and Glass-like blocks from being overly unstable
- To prevent cave-ins from happening too often.
Protected blocks fulfill any or all of the conditions below:
- Has the Glass sound effect
- Is in the [disruption:protected] block tag
'Buoyant' blocks
Buoyant blocks are blocks that do not begin to fall if they are resting upon a liquid.
Keep in mind that the liquid does not count as a 'support' for these blocks.
There are three reasons why such blocks exist:
- To prevent ice and ice sheets from falling into the sea.
- To prevent magma blocks from falling into lava.
- To allow Players to create boats and bridges on water/lava without the need of supports.
Buoyant blocks fulfill any or all of the conditions below:
- Is flammable
- Is slippery (slipperiness > 0.6)
- Is in the [disruption:buoyant] block tag
Available Versions
How to Install Disruption on Your Server
Order Server
Order a Minecraft Java server with at least 3 GB RAM (4 GB recommended).
Set quilt Loader
In the panel under "Egg", select the quilt loader and matching Minecraft version (1.18.2).
Install Mod
Open the mod browser in the dashboard and search for "Disruption". Click "Install" – done! Alternatively, upload the .jar via SFTP to the /mods folder.
Compatibility
Mod Loaders
Minecraft Versions
1.18.2
Server-side
✓ RequiredRecommended RAM
4 GB(min. 3 GB)Frequently Asked Questions
Disruption server crashes on startup – what to do?
Most common cause: wrong quilt version or insufficient RAM. Check the server log (latest.log) for "OutOfMemoryError" or "Mixin" errors. With Mado Hosting: ensure at least 3 GB RAM is allocated and the loader matches the mod version (1.18.2). You can switch loaders with one click in the panel.
Is Disruption compatible with quilt?
Disruption officially supports quilt for Minecraft 1.18.2. The Mado dashboard automatically detects incompatible loader combinations.
Server lagging with Disruption – how to optimize performance?
Recommended RAM: 4 GB (per 8 players). Use /spark profiler to check if Disruption consumes the most tick time. Common fixes: reduce server view-distance to 8-10, install "performant" or "starlight" as supplementary mods on Forge. With Mado Hosting, your server runs on NVMe SSDs with dedicated CPU cores for minimal latency.
Similar Mods
Rent Modded Server
Install Disruption with just one click on your server.