Androids don't need to breathe oxygen

This commit is contained in:
DBotThePony 2023-03-14 16:19:00 +07:00
parent 312795df93
commit 594e6c9fbf
Signed by: DBot
GPG Key ID: DCC23B5715498507
8 changed files with 139 additions and 3 deletions

View File

@ -185,6 +185,7 @@ dependencies {
val deps_mc_version: String by project
val jei_mc_version: String by project
val curios_mc_version: String by project
val ad_astra_id: String by project
implementation(fg.deobf("top.theillusivec4.curios:curios-forge:${curios_mc_version}-${curios_version}"))
implementation(fg.deobf("curse.maven:cosmetic-armor-reworked-237307:$cosmetic_armor_reworked_id"))
@ -196,6 +197,11 @@ dependencies {
runtimeOnly(fg.deobf("curse.maven:jade-324717:${jade_id}"))
runtimeOnly(fg.deobf("curse.maven:configured-457570:${configured_id}"))
implementation(fg.deobf("curse.maven:ad-astra-635042:${ad_astra_id}"))
implementation(fg.deobf("curse.maven:resourceful-lib-570073:4378849"))
implementation(fg.deobf("curse.maven:resourceful-config-714059:4394154"))
implementation(fg.deobf("curse.maven:botarium-704113:4416456"))
// runtimeOnly(fg.deobf("curse.maven:worldedit-225608:${worldedit_fileid}"))
// runtimeOnly(fg.deobf("at.ridgo8.moreoverlays:MoreOverlays-updated:${more_overlays_version}"))
@ -256,8 +262,6 @@ minecraft {
} else {
args("--username", "Dev_${System.getProperty("user.name")}")
}
args("-mixin.config=$mod_id.mixins.json")
}
create("server") {
@ -267,7 +271,7 @@ minecraft {
}
}
args("nogui", "-mixin.config=$mod_id.mixins.json")
args("nogui")
}
create("data") {
@ -287,6 +291,7 @@ minecraft {
mixin {
add(sourceSets.main.get(), "$mod_id.refmap.json")
config("$mod_id.mixins.json")
config("$mod_id.ad_astra.mixins.json")
}
minecraft.runs.all {

View File

@ -29,6 +29,7 @@ jupiter_version=5.8.2
mekanism_version=10.3.5.homebaked
curios_version=5.1.4.0
cosmetic_armor_reworked_id=4145717
ad_astra_id=4390126
jade_id=4330163
configured_id=4166861
worldedit_fileid=3922622

View File

@ -33,12 +33,14 @@ import ru.dbotthepony.mc.otm.client.model.TritaniumArmorModel;
import ru.dbotthepony.mc.otm.client.render.ShockwaveRenderer;
import ru.dbotthepony.mc.otm.client.render.blockentity.BatteryBankRenderer;
import ru.dbotthepony.mc.otm.client.render.blockentity.MatterBatteryBankRenderer;
import ru.dbotthepony.mc.otm.compat.adastra.AdAstraCompatKt;
import ru.dbotthepony.mc.otm.compat.mekanism.QIOKt;
import ru.dbotthepony.mc.otm.compat.mekanism.TooltipsKt;
import ru.dbotthepony.mc.otm.config.AndroidConfig;
import ru.dbotthepony.mc.otm.config.ClientConfig;
import ru.dbotthepony.mc.otm.config.ItemsConfig;
import ru.dbotthepony.mc.otm.config.MachinesConfig;
import ru.dbotthepony.mc.otm.config.ServerCompatConfig;
import ru.dbotthepony.mc.otm.config.ServerConfig;
import ru.dbotthepony.mc.otm.config.ToolsConfig;
import ru.dbotthepony.mc.otm.core.math.Decimal;
@ -130,6 +132,7 @@ public final class OverdriveThatMatters {
ClientConfig.INSTANCE.register();
ServerConfig.INSTANCE.register();
ServerCompatConfig.INSTANCE.register();
AndroidConfig.INSTANCE.register();
ItemsConfig.INSTANCE.register();
MachinesConfig.INSTANCE.register();
@ -195,6 +198,10 @@ public final class OverdriveThatMatters {
if (ModList.get().isLoaded("mekanism")) {
EVENT_BUS.addGenericListener(BlockEntity.class, EventPriority.NORMAL, QIOKt::attachCapabilities);
}
if (AdAstraCompatKt.isAdAstraLoaded()) {
EVENT_BUS.addListener(EventPriority.NORMAL, AdAstraCompatKt::onDamageEvent);
}
}
private void setupClient(final FMLClientSetupEvent event) {

View File

@ -0,0 +1,31 @@
package ru.dbotthepony.mc.otm.mixin.compat.ad_astra;
import earth.terrarium.ad_astra.common.entity.system.EntityOxygenSystem;
import net.minecraft.server.level.ServerLevel;
import net.minecraft.world.entity.LivingEntity;
import net.minecraft.world.entity.player.Player;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
import ru.dbotthepony.mc.otm.capability.MatteryCapability;
import ru.dbotthepony.mc.otm.config.ServerCompatConfig;
@Mixin(EntityOxygenSystem.class)
public class EntityOxygenSystemMixin {
@Inject(
method = "oxygenTick()V",
at = @At("HEAD"),
cancellable = true,
remap = false
)
private static void oxygenTick(LivingEntity entity, ServerLevel level, CallbackInfo hook) {
if (entity instanceof Player && ServerCompatConfig.AdAstra.INSTANCE.getANDROIDS_DO_NOT_NEED_OXYGEN()) {
entity.getCapability(MatteryCapability.MATTERY_PLAYER).ifPresent(it -> {
if (it.isAndroid()) {
hook.cancel();
}
});
}
}
}

View File

@ -0,0 +1,31 @@
package ru.dbotthepony.mc.otm.mixin.compat.ad_astra;
import earth.terrarium.ad_astra.common.util.OxygenUtils;
import net.minecraft.world.entity.LivingEntity;
import net.minecraft.world.entity.player.Player;
import net.minecraft.world.level.Level;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
import ru.dbotthepony.mc.otm.capability.MatteryCapability;
import ru.dbotthepony.mc.otm.config.ServerCompatConfig;
@Mixin(OxygenUtils.class)
public class OxygenUtilsMixin {
@Inject(
method = "entityHasOxygen()Z",
at = @At("HEAD"),
cancellable = true,
remap = false
)
private static void entityHasOxygen(Level level, LivingEntity entity, CallbackInfoReturnable<Boolean> hook) {
if (entity instanceof Player && ServerCompatConfig.AdAstra.INSTANCE.getANDROIDS_DO_NOT_NEED_OXYGEN()) {
entity.getCapability(MatteryCapability.MATTERY_PLAYER).ifPresent(it -> {
if (it.isAndroid()) {
hook.setReturnValue(true);
}
});
}
}
}

View File

@ -0,0 +1,28 @@
package ru.dbotthepony.mc.otm.compat.adastra
import earth.terrarium.ad_astra.AdAstra
import earth.terrarium.ad_astra.common.registry.ModDamageSource
import net.minecraft.world.entity.player.Player
import net.minecraftforge.event.entity.living.LivingHurtEvent
import net.minecraftforge.fml.ModList
import ru.dbotthepony.mc.otm.capability.matteryPlayer
import ru.dbotthepony.mc.otm.config.ServerCompatConfig
val isAdAstraLoaded by lazy {
ModList.get().isLoaded(AdAstra.MOD_ID)
}
// для надёжности
fun onDamageEvent(event: LivingHurtEvent) {
check(isAdAstraLoaded) { "Ad Astra is not loaded!" }
val ply = event.entity as? Player ?: return
if (ServerCompatConfig.AdAstra.ANDROIDS_DO_NOT_NEED_OXYGEN) {
if (ply.matteryPlayer?.isAndroid != true) return
if (event.source === ModDamageSource.OXYGEN) {
event.amount = 0f
event.isCanceled = true
}
}
}

View File

@ -0,0 +1,21 @@
package ru.dbotthepony.mc.otm.config
object ServerCompatConfig : AbstractConfig("compat-server") {
object AdAstra {
init {
builder.push("AD_ASTRA")
}
val ANDROIDS_DO_NOT_NEED_OXYGEN: Boolean by builder
.comment("Android do not need oxygen in space")
.define("ANDROIDS_DO_NOT_NEED_OXYGEN", true)
init {
builder.pop()
}
}
init {
AdAstra
}
}

View File

@ -0,0 +1,12 @@
{
"required": false,
"package": "ru.dbotthepony.mc.otm.mixin.compat.ad_astra",
"compatibilityLevel": "JAVA_17",
"minVersion": "0.8",
"refmap": "overdrive_that_matters.refmap.json",
"mixins": [
"EntityOxygenSystemMixin",
"OxygenUtilsMixin"
]
}