Jump to content

Version-independent mod?


Kinniken

Recommended Posts

Hi guys,

 

Is there any doc somewhere on releasing a version-independent mod? I know it's supposed to be possible now but couldn't find any instructions. Just using the compiled but not reobfuscated code from mcp/bin doesn't work for me, I get this early in my mod's loading (probably the first call to an MC method):

 

java.lang.NoSuchMethodError: net.minecraft.client.Minecraft.getMinecraftDir()Ljava/io/File;

 

I'm not so much interested in releasing version-independent client versions (even without the reobf my experience is that every MC releases except for some bug fix ones break Millénaire anyway) but in testing MCPC+ for 1.5.1.

 

Thanks

 

K.

Link to comment
Share on other sites

OK, so I went looking at this.

 

What is the farthest back a mod can be and still make use of the version independence?  There's a guy going around on the Minecraft forums telling all the 1.4.7 mod owners to "reobfuscate with the latest reobfuscale_srg" and it'll magically update them to 1.5.1

 

But I can't seem to get it to work.

 

I can't just add "--srgnames" to the end of the reobfuscate.bat file, I get an error:

 

reobfuscate.py: error: no such option: --srgnames

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

No things don't get 'magically updated' Especially between 1.4 and 1.5

You will ALWAYS have to update to handle changes in minecraft with things you interact with.

However, 1.5 and 1.5.1 is the perfect example of why runtime deobfusication is a good thing.

The obfusication changed between 1.5 and 1.5.1 because there were a few new classes introduced. HOWEVER no real functionality changed.

There were a few changes with the MC Realms stuff but nobody uses that.

So any real mod who was made for 1.5 and reobfusicated to srg names will most likely works fine for 1.5.1.

 

Basically, the real benifits are for things between minor mc releases.

For example, if we had this in 1.4, it is quite likely that most mods would not of had to update for 1.4.1, 1.4.2, 1.4.3, 1.4.4, 1.4.5, or 1.4.6 {kinda seeing why its a good thing?}

 

I've explained this many times before. However I guess I will do it again.

There are 3 'types' of names for minecraft:

 

Notch, or Obfusicated: Classes named crap: 'a', 'b', 'asd', Fields/Methods name really useless names like 'a', 'b', 'qwe', these change between EVERY minecraft version.

 

SRG Names: Classes receive good names 'Item', 'Block', and all Fields/Methods get unique names 'field_1234_b', these names are designed to be constant cross minecraft versions, unless minecraft actually removes/changes signatures the names will be the same.

 

Mapped Names: Based off SRG names, but fields/methods are given community names such as 'getMiencraftDir', 'update' etc.. The problem with these names is that they are community based. And change on whims.

 

So, its the logical choice for us to go with SRG names as they are stable cross versions.

 

So basically. if you reobfuscate to srg names, your mod MAY be able to work cross obfusication changes. If you don't it has ZERO chance.

 

You would only have to update your mod if minecraft changes things that you mod actually uses.

As the vast majority of minecraft is stable code, the vast majority of mods will be able to have a stable platform.

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

Link to comment
Share on other sites

Ok, thanks for the review LexManos. I had not realised that the "srg" names were the "field_1234_b" ones, not the user-friendly ones.

 

With that setup yes most mods should indeed work across bug fixes. IIRC when I updated Millénaire to 1.5.1 the only compilation errors were due to mapped names changing.

 

Any performance hit in that new setup though? The srg names must be remapped to the obfuscated ones when MC runs right, doesn't that slow thing down a bit?

Link to comment
Share on other sites

Any performance hit in that new setup though? The srg names must be remapped to the obfuscated ones when MC runs right, doesn't that slow thing down a bit?

Actually its the opposite. FML deobfuscates everything to srgnames at runtime, including Minecraft itself. Runtime deobfuscation is always enabled [1], so obfuscated mods will be deobfuscated at runtime as well, though version-independent mods won't need deobfuscation. But the transformer still runs, and several other transformers run as well (for access, siding, coremods, etc.); I would not expect you to see any noticeable performance difference from version-independent/version-dependent mods (but I haven't benchmarked anything, FWIW). Also note the transformation only applies at class load time - once the classes are loaded, they are as fast as any other class.

 

[1] Not quite true, FML will skip runtime deobf if it detects a non-obfuscated environment, e.g. testing with MCP's start scripts. The other instance where runtime deobf is disabled was:

 

I'm not so much interested in releasing version-independent client versions (even without the reobf my experience is that every MC releases except for some bug fix ones break Millénaire anyway) but in testing MCPC+ for 1.5.1.

I had to temporarily disable deobfuscation in the early builds of MCPC+ 1.5.1 due to an issue with the server deobfuscating itself (FML issue #210 if you're interested, some obscure edge case with overloaded fields), effectively "pre-deobfuscating" the server at compile-time. This had the consequence of only supporting version-independent mods since the deobfuscation transformer did not run for them either. But as of builds 261+, runtime deobf is now enabled, so both types of mods should load. I just tested loading Millénaire, works great (awesome mod btw, great work).

 

Going back to the question of performance, for MCPC+ I considered continuing to pre-deobfuscate the server (but enabling deobfuscation of mods), with the hope of better startup times. Forge and FML have to deobfuscate Minecraft itself due to how they are distributed (patches over vanilla classes), but since MCPC+ being based on CraftBukkit is a complete server jar, theoretically it could be deobfuscated at compile time. I.e., rather than remapping from MCP csvnames in the source code -> obfuscated names in the compiled binary -> deobfuscated srgnames at runtime, cutting out the middle step and going straight from csvnames in the source -> srgnames in the compiled binary. In fact this is how MCPC+ was built temporarily since the deobf issue was with obf -> srgnames, but now that that works, MCPC+ is compiled to obfuscated names just like a vanilla server. Maybe pre-deobfuscation is something that could be reconsidered in the future, but its probably not worth it, would be non-trivial to implement and again I expect little to no performance benefit.

 

Any particular pros and cons of using this BTW? Beyond of course that my mod will no longer be affected by changes in obfuscation

About the only con is that your mod might work when you don't want it to :).

 

What is the farthest back a mod can be and still make use of the version independence?  There's a guy going around on the Minecraft forums telling all the 1.4.7 mod owners to "reobfuscate with the latest reobfuscale_srg" and it'll magically update them to 1.5.1

"Version-independence" only guards against obfuscation changes - unfortunately not actual code changes (only real way to do this is with an API). So if Mojang changes the code a mod relies on, it may not work as intended. In 1.5, texturing significantly changed, several older methods which mods relied on no longer exist. And most all mods use textures of course. Not to mention, reobfuscate_srg was added in 1.5. But throughout the 1.5.x minor releases, you can expect version-independence to take effect. A couple mods built with srgnames for 1.5 already work for 1.5.1 (Portal Gun and Gravity Gun at least).

 

With that setup yes most mods should indeed work across bug fixes. IIRC when I updated Millénaire to 1.5.1 the only compilation errors were due to mapped names

 

This is an interesting point - as Lex explains, srgnames were chosen for FML runtime since they are as version-independent as possible. The mapped descriptive csvnames are up to the community via MCPBot submissions, so they are more volatile than srgnames. So curiously, a mod's compiled binary may be more stable across versions than its source code.

 

One way to ensure version stability of source is to write your mod using srgnames. This is the approach FML itself takes, and it works pretty well for this purpose. But the downside is the user-unfriendliness of srgnames - with FML's relatively small patches, its not too big of a deal, but if you're writing a large Forge mod using srgnames everywhere would just be unbearable, leading to unreadable code. And after all, the mapped csvnames are intended to be descriptive and human-readable.

 

Another possible solution is to use csvnames, but with a source-remapping tool to update the names automatically. We now have Srg2source, which can mass-rename large source code bases thousands of times faster than any IDE's built-in rename refactoring tool. Currently it is being used to automatically remap each commit of CraftBukkit into MCPBukkit, and it is tailored for that purpose, but in principle it could be reworked as a more general-purpose tool for modders. Something I've been wanting to look into, but haven't got around to it. A tool sort of like MCP's updatenames, but supporting not only renaming unmapped names (srgnames) to mapped names, but also arbitrary symbol renames between MCP updates.

 

However, even if such a tool was used, it wouldn't take care of all symbol changes. Renames of mapped symbols are relatively rare (MCPBot requires a force update command, and its considered polite to only rename very poorly named symbols since it can break people's mods). In the 1.4.7 to 1.5.1 update, many symbols which appear to have been renamed were actually new altogether. The world block setting methods, for one. Signature changes, new parameters, regarded as new symbols by srgnames. So a source-based remapping tool using srgnames wouldn't take care of these situations. Still would be cool to have such a tool packaged up and easily available for modders to use, though (srg2source works today for this purpose, but it may not be the easiest tool to use unless you want to read the code and see how it works, what options are required, generating the update mappings, etc).

Link to comment
Share on other sites

Thanks for all the information, it makes things clearer. I hadn't realised that Forge ran Minecraft in deobf mode. BTW if you tested Millénaire using the latest version (4.6) it was a version-independent one.

 

And yes I know MCP is conservative when it comes to renaming methods. For my 1.5.1 update most of them were indeed new 1.5 methods getting a proper name for the first time. In the past I've noticed real renames mainly on major version bump - I assume because they felt that it's the good time to do it, as people have to update anyway (and I agree).

 

Anyway, so with no speed difference to speak of, I guess I'll continue using the new feature. That it works over bug fix versions is really nice. My only concern is that for major updates it will likely "mostly work" with unpredictable crashes wherever Mojang changed the code. That could potentially lead to nasty bugs, maybe data-destroying ones (hard to say since it will depend on what has changed, of course). Maybe a setting could be added to forbid a mod from running in a different major version?

 

And good luck with MCPC+, it's really a cool product.

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Ok so, i managed to fix it, if you have zombie awarness it requires coroutil, even if the mod page doesn't say it needs it it does.  
    • Did you check the getRenderShape method of your block to ensure it's returning the correct enum value?
    • new to messing with modpacks. the server starts and the pack is playable on personal worlds, but every time i try to enter the server, i get "internal exception: io.netty.handler.codec.DecoderException: java.lang.IllegalArgumentException: Payload may not be larger than 1048576 bytes" and it boots me. not sure what this means. the debug log is essentially gibberish to me and i'm not sure... about anything. is it saying that it's sending me too much data? if it helps at all, my mc username is "leucanella", and the disconnect reasons are near the very bottom (at least once was due to mismatched modlists, but i got that fixed i'm pretty sure). i just can't make sense of it myself. https://gist.github.com/idlebird/c5269e80434a501104f6b99ebc16be46
    • We somehow figured out the issue: Whenever we try to eat a food item from the mod "[Let's Do] Candlelight" that can be eaten multiple times using a feeding upgrade from "Sophisticated Backpacks", that's when we crash. Food items include: - Beef Wellington - Bolognese - Chicken Alfredo - Chicken with Vegetables - Cooked Beef - Fricasse with Hash Browns - Lasagna - Lettuce with Steak - Lettuce with Tomatoes, Potatoes and Carrots - Mushroom Soup - Pasta with Bolognese - Pasta with Tomato Sauce - Pork Ribs - Roastbeef with Carrots - Salmon with White Wine Sauce - Tomato Mozzarella Salad - Tomato Soup - Tropical Fish Supreme
    • Me and my sister are playing on a modded minecraft server, but recently she has been crashing at random intervals and no one I've talked with knows why. There's no crash report on my sister's side, but in the log of the server there appears a bunch of lines every time she crashes. They appear to be mostly similar with different mods changing each crash. Minecraft Version: 1.20.1 Forge version: forge-47.2.20 Server log: [07May2024 18:13:29.067] [Server thread/ERROR] [net.minecraftforge.eventbus.EventBus/EVENTBUS]: Exception caught during firing event: null     Index: 12     Listeners:         0: NORMAL         1: ASM: com.github.alexthe666.citadel.server.CitadelEvents@28c884eb onEntityUpdateDebug(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         2: net.minecraftforge.eventbus.EventBus$$Lambda$4374/0x00007f0098c72da0@10f79ae2         3: ASM: com.github.alexthe666.alexsmobs.event.ServerEvents@6f4126f3 onLivingUpdateEvent(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         4: ASM: class tallestegg.illagersweararmor.IWASpawnEvents tickEntity(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         5: ASM: class io.github.lightman314.lightmanscurrency.common.EventHandler entityTick(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         6: ASM: com.github.L_Ender.cataclysm.event.ServerEventHandler@1bbd60d8 onLivingUpdateEvent(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         7: ASM: class io.github.edwinmindcraft.apoli.common.ApoliPowerEventHandler playerTick(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         8: ASM: class io.github.edwinmindcraft.apoli.common.ApoliEventHandler livingTick(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         9: net.minecraftforge.eventbus.EventBus$$Lambda$4374/0x00007f0098c72da0@1e30768c         10: ASM: class net.mcreator.borninchaosv.init.EntityAnimationFactory onEntityTick(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         11: ASM: squeek.appleskin.network.SyncHandler@29e380f7 onLivingTickEvent(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V         12: ASM: top.theillusivec4.curios.common.event.CuriosEventHandler@55b4416c tick(Lnet/minecraftforge/event/entity/living/LivingEvent$LivingTickEvent;)V java.lang.ArrayIndexOutOfBoundsException [07May2024 18:13:29.146] [Server thread/WARN] [net.minecraft.server.network.ServerConnectionListener/]: Failed to handle packet for /OMITTED IP net.minecraft.ReportedException: Ticking player     at net.minecraft.server.level.ServerPlayer.m_9240_(ServerPlayer.java:530) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.network.ServerGamePacketListenerImpl.m_9933_(ServerGamePacketListenerImpl.java:262) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.network.Connection.m_129483_(Connection.java:263) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.network.ServerConnectionListener.m_9721_(ServerConnectionListener.java:142) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.MinecraftServer.m_5703_(MinecraftServer.java:907) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.dedicated.DedicatedServer.m_5703_(DedicatedServer.java:283) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.MinecraftServer.m_5705_(MinecraftServer.java:814) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.MinecraftServer.m_130011_(MinecraftServer.java:661) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at net.minecraft.server.MinecraftServer.m_206580_(MinecraftServer.java:251) ~[server-1.20.1-20230612.114412-srg.jar%23461!/:?]     at java.lang.Thread.run(Thread.java:833) ~[?:?] Caused by: java.lang.ArrayIndexOutOfBoundsException Mod List: SecurityCraft v1.9.9.jar additional_lights-1.20.1-2.1.7.jar advancements_tracker_1.20.1-6.1.0.jar AI-Improvements-1.20-0.5.2.jar alexsdelight-1.5.jar alexsmobs-1.22.8.jar AmbientSounds_FORGE_v5.3.9_mc1.20.1.jar amendments-1.20-1.1.26.jar appleskin-forge-mc1.20.1-2.5.1.jar Aquaculture-1.20.1-2.5.1.jar aquaculture_delight_1.0.0_forge_1.20.1.jar architectury-9.2.14-forge.jar Arda's Sculks 1.3.2 [FORGE] [1.20.1].jar artifacts-forge-9.5.3.jar async-locator-forge-1.20-1.3.0.jar athena-forge-1.20.1-3.1.2.jar AttributeFix-Forge-1.20.1-21.0.4.jar BadOptimizations-2.1.1.jar badpackets-forge-0.4.3.jar balm-forge-1.20.1-7.2.2.jar beautify-2.0.2.jar BetterAdvancements-1.20.1-0.3.2.162.jar bettercombat-forge-1.8.5+1.20.1.jar BetterF3-7.0.2-Forge-1.20.1.jar betterfarmerscombat-1.2-1.20.1.jar BetterThirdPerson-Forge-1.20-1.9.0.jar BiomesOPlenty-1.20.1-18.0.0.598.jar Bookshelf-Forge-1.20.1-20.1.10.jar born_in_chaos_[Forge]1.20.1_1.2.jar Bountiful-6.0.3+1.20.1-forge.jar caelus-forge-3.2.0+1.20.1.jar camera-forge-1.20.1-1.0.8.jar canary-mc1.20.1-0.3.3.jar chat_heads-0.10.32-forge-1.20.jar Chimes-v2.0.1-1.20.1.jar Chipped-forge-1.20.1-3.0.6.jar chunksending-1.20.1-2.8.jar Chunky-1.3.136.jar citadel-2.5.4-1.20.1.jar cloth-config-11.1.118-forge.jar Clumps-forge-1.20.1-12.0.0.3.jar cluttered-2.1-1.20.1.jar connectedglass-1.1.11-forge-mc1.20.1.jar Controlling-forge-1.20.1-12.0.2.jar corpse-forge-1.20.1-1.0.12.jar cosmeticarmorreworked-1.20.1-v1a.jar CreativeCore_FORGE_v2.11.27_mc1.20.1.jar creeperoverhaul-3.0.2-forge.jar Croptopia-1.20.1-FORGE-3.0.4.jar ctia-1.20.1-forge-2.0.9.jar cupboard-1.20.1-2.6.jar curios-forge-5.9.0+1.20.1.jar CustomPlayerModels-1.20-0.6.16c.jar darktimer-forge-1.20.1-1.0.9.jar dotbe-1.20.1-1.5.5.jar dummmmmmy-1.20-1.8.14.jar DungeonsArise-1.20.x-2.1.58-release.jar DungeonsAriseSevenSeas-1.20.x-1.0.2-forge.jar dye_depot-1.0.0-forge.jar dynamiclights-v1.7.1-mc1.17x-1.20x-mod.jar easy_mob_farm_1.20.1-7.1.0.jar elevatorid-1.20.1-lex-1.9.jar embeddium-0.3.17+mc1.20.1-all.jar embeddiumplus-1.20.1-v1.2.8.jar emotecraft-for-MC1.20.1-2.2.7-b.build.50-forge.jar EnchantmentDescriptions-Forge-1.20.1-17.0.14.jar EnderMail-1.20.1-1.2.9.jar endermanoverhaul-forge-1.20.1-1.0.4.jar endersdelight-1.20.1-1.0.3.jar entityculling-forge-1.6.2-mc1.20.1.jar EpheroLib-1.20.1-FORGE-1.2.0.jar fantasyfurniture-1.20.1-9.0.0.jar FarmersDelight-1.20.1-1.2.4.jar farmersutils-1.0.5-1.20.1.jar Fastload-Reforged-mc1.20.1-3.4.0.jar fastpaintings-1.20-1.2.5.jar ferritecore-6.0.1-forge.jar friendsandfoes-forge-mc1.20.1-2.0.10.jar ftb-essentials-forge-2001.2.2.jar ftb-library-forge-2001.2.1.jar fusion-1.1.1-forge-mc1.20.1.jar geckolib-forge-1.20.1-4.4.4.jar getittogetherdrops-forge-1.20-1.3.jar handcrafted-forge-1.20.1-3.0.6.jar IllagerInvasion-v8.0.5-1.20.1-Forge.jar illagersweararmor-1.20.1-1.3.4.jar ImmediatelyFast-Forge-1.2.13+1.20.4.jar immersive_melodies-0.1.0+1.20.1-forge.jar Incendium_1.20.4_v5.3.4.jar Item_Obliterator-FORGE-MC1.20.1-1.7.0.jar Jade-1.20.1-forge-11.8.0.jar jei-1.20.1-forge-15.3.0.4.jar journeymap-1.20.1-5.9.20-forge.jar Kambrik-6.1.1+1.20.1-forge.jar kotlinforforge-4.10.0-all.jar L_Enders_Cataclysm-1.99.2 -1.20.1.jar LeavesBeGone-v8.0.0-1.20.1-Forge.jar letmedespawn-forge-1.20.x-1.2.0.jar letsdo-addon-compat-forge-v1.4.1.jar letsdo-API-forge-1.2.9-forge.jar letsdo-bakery-forge-1.1.8.jar letsdo-beachparty-forge-1.1.4-1.jar letsdo-brewery-forge-1.1.6.jar letsdo-candlelight-forge-1.2.11.jar letsdo-herbalbrews-forge-1.0.6.jar letsdo-meadow-forge-1.3.8.jar letsdo-nethervinery-forge-1.2.10.jar letsdo-vinery-forge-1.4.15.jar lightmanscurrency-1.20.1-2.2.1.3b.jar lionfishapi-1.8.jar magicvibedecorations-HALLOWEEN 1.5.0 1.20.1 forge.jar make_bubbles_pop-0.2.0-forge-mc1.19.4+.jar memoryleakfix-forge-1.17+-1.1.5.jar MobLassos-v8.0.1-1.20.1-Forge.jar modelfix-1.15.jar moonlight-1.20-2.11.14-forge.jar morediscs-1.20.1-33-forge.jar MouseTweaks-forge-mc1.20-2.25.jar Necronomicon-Forge-1.4.2.jar nether-s-exoticism-1.20.1-1.2.7.jar nethersdelight-1.20.1-4.0.jar nomowanderer-1.20.1_1.6.4.jar oculus-mc1.20.1-1.7.0.jar origins-forge-1.20.1-1.10.0.7-all.jar origins-plus-plus-2.2-forge.jar Paraglider-forge-20.1.3.jar Patchouli-1.20.1-84-FORGE.jar Paxi-1.20-Forge-4.0.jar Pehkui-3.8.0+1.20.1-forge.jar player-animation-lib-forge-1.0.2-rc1+1.20.jar PlayerRevive_FORGE_v2.0.24_mc1.20.1.jar plushies-1.4.0-forge.jar polymorph-forge-0.49.3+1.20.1.jar projectvibrantjourneys-1.20.1-6.0.0.jar PuzzlesLib-v8.1.18-1.20.1-Forge.jar resourcefulconfig-forge-1.20.1-2.1.2.jar resourcefullib-forge-1.20.1-2.1.24.jar right-click-harvest-3.2.3+1.20.1-forge.jar rubidium-extra-0.5.4.3+mc1.20.1-build.121.jar Runelic-Forge-1.20.1-18.0.2.jar saturn-mc1.20.1-0.1.3.jar sawmill-1.20-1.3.13.jar scholar-1.20.1-1.0.0-forge.jar screenshot_viewer-1.2.1-forge-mc1.20.1.jar Searchables-forge-1.20.1-1.0.2.jar selfexpression-2.8 1.20.1.jar servercore-forge-1.5.1+1.20.1.jar ShulkerArmory_1.20.1_1.2.1_hotfix.jar simplehats-forge-1.20.1-0.2.4.jar simplevoicechat_broadcast-mc1.20.1-1.0.1.jar simplyswords-forge-1.55.0-1.20.1.jar smoothboot(reloaded)-mc1.20.1-0.0.4.jar Sniffer+-forge-1.20.1-0.3.0.jar sophisticatedbackpacks-1.20.1-3.20.5.1044.jar sophisticatedcore-1.20.1-0.6.21.609.jar sophisticatedstorage-1.20.1-0.10.21.793.jar spark-1.10.53-forge.jar stalwart-dungeons-1.20.1-1.2.8.jar starlight-1.1.2+forge.1cda73c.jar step-1.20.1-1.2.2.jar supermartijn642corelib-1.1.17-forge-mc1.20.1.jar supplementaries-1.20-2.8.10.jar temporalapi-1.5.0.jar TerraBlender-forge-1.20.1-3.0.1.4.jar Terralith_1.20.4_v2.4.11.jar toms_storage-1.20-1.6.6.jar torchmaster-20.1.6.jar trashslot-forge-1.20-15.1.0.jar treasuredistance-1.20-1.2.jar tru.e-ending-v1.1.0c.jar v_slab_compat-1.20-2.3.jar vintagedelight-0.0.12.jar vmp-fabric-mc1.20.1-0.2.0+beta.7.101-all.jar voicechat-forge-1.20.1-2.5.11.jar waystones-forge-1.20-14.1.3.jar WI-Zoom-1.5-MC1.20.1-Forge.jar worldedit-mod-7.2.15.jar wsopulence1.2.0_Forge_MC1.20.1-1.20.4.jar xlpackets-1.18.2-2.1.jar YungsApi-1.20-Forge-4.0.4.jar YungsBetterEndIsland-1.20-Forge-2.0.6.jar YungsBetterNetherFortresses-1.20-Forge-2.0.6.jar YungsBetterOceanMonuments-1.20-Forge-3.0.4.jar YungsBetterStrongholds-1.20-Forge-4.0.3.jar
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.