61 Commits

Author SHA1 Message Date
4f78c9bd03 Update Java
Some checks failed
build / build (17) (push) Failing after 5m5s
build / upload-release (push) Has been cancelled
2025-01-21 14:58:17 +05:00
6032f8af2b Change Entity to LivingEntity 2025-01-21 14:58:06 +05:00
fc5d12980f Update Mixins from Redirect to Update Statement
Some checks failed
build / build (17) (push) Failing after 4m45s
build / upload-release (push) Has been skipped
2025-01-21 14:45:49 +05:00
824a2cf0a3 MORE UPDATES
Some checks failed
build / build (17) (push) Failing after 4m11s
build / upload-release (push) Has been skipped
2025-01-21 04:39:04 +05:00
a112b38b1c MORE UPDATES 2025-01-21 04:32:33 +05:00
2a5f442a78 MORE UPDATES 2025-01-21 04:22:27 +05:00
d3fea6ca2d Update gradle 2025-01-21 04:21:35 +05:00
baba04d179 Update workflow file 2025-01-21 04:11:54 +05:00
4f0c236cff Update workflow file 2025-01-21 04:05:22 +05:00
9f80bf51f0 Update version and build files 2025-01-21 04:05:06 +05:00
b5b84d21fc Update workflow file
Some checks failed
build / build (21) (push) Successful in 4m27s
build / upload-release (push) Failing after 8s
2025-01-21 03:43:53 +05:00
212c1c11a6 Update workflow file
Some checks failed
build / build (21) (push) Successful in 13m57s
build / upload-release (push) Failing after 8s
2025-01-21 03:28:15 +05:00
908701152e Update workflow file
Some checks failed
build / upload-release (push) Has been cancelled
build / build (21) (push) Has been cancelled
2025-01-21 03:24:20 +05:00
ac3d2b8632 Update workflow file
All checks were successful
build / build (21) (push) Successful in 14m25s
build / upload-release (push) Successful in 23s
2025-01-21 03:06:25 +05:00
3adfd20d72 Rollback
Some checks failed
build / upload-release (push) Blocked by required conditions
build / build (17) (push) Has been cancelled
2025-01-21 03:03:53 +05:00
bb1a6be978 Rollback
Some checks failed
build / upload-release (push) Blocked by required conditions
build / build (17) (push) Has been cancelled
2025-01-21 02:56:22 +05:00
58125c04df Again update workflow
Some checks failed
build / upload-release (push) Blocked by required conditions
build / build (17) (push) Has been cancelled
2025-01-21 02:55:40 +05:00
c52aebf2a8 Again update workflow
Some checks failed
build / build (17) (push) Has been cancelled
2025-01-21 02:47:25 +05:00
ccd632e0c3 Again update workflow
Some checks failed
build / build (push) Failing after 20s
2025-01-21 02:46:41 +05:00
956d2e6b53 Again update workflow
Some checks failed
build / build (push) Failing after 10s
2025-01-21 02:45:47 +05:00
ed146f441d Test 2025-01-21 02:45:24 +05:00
be9a4bdd59 Change workflow file
Some checks failed
build / build (17) (push) Failing after 2m44s
2025-01-21 02:39:28 +05:00
2c386caace Add dependency
Some checks failed
build / build (17) (push) Has been cancelled
2025-01-20 22:16:53 +05:00
b749efbbac Create get from simibubi 2024-03-12 12:08:13 +05:00
8f01df0971 More fixxxes 2024-03-12 12:04:28 +05:00
3683405780 Change create build 2024-03-12 11:37:18 +05:00
f4625f84b3 Fix? again 2024-03-12 11:37:03 +05:00
3a3b3b11fa Fix? oxygen Ad Astra 2024-03-12 10:58:41 +05:00
23667171ae Remove unusual? method 2024-03-12 10:58:27 +05:00
9d811a82af Fix? temperature for Ad Astra 2024-03-12 10:43:02 +05:00
fb97097b67 Update Gradle to 8.3 2024-03-12 09:54:58 +05:00
328ca781ff Update loom 2024-03-12 09:50:09 +05:00
429b444058 Get Create Fabric from Modrinth 2024-03-12 09:47:54 +05:00
be08c76edf Get Ad Astra from Modrinth 2024-03-12 09:34:48 +05:00
7e65f5d748 Set variable version ThinAir 2024-03-12 09:32:40 +05:00
1079b588e5 Add version for ThinAir 2024-03-12 09:30:56 +05:00
301bcad666 Update version of Create 2024-03-12 09:29:48 +05:00
2889f710fb Remove spaces 2023-11-12 23:19:23 +05:00
8862a20b6b Remove spaces 2023-11-12 23:19:12 +05:00
45c772db96 Remove force depends 2023-11-12 23:19:02 +05:00
8bed1bc0c9 Import from Create Astra Fabric 2023-11-12 23:18:44 +05:00
8d34b157ca Import from Create Astra Fabric 2023-11-12 23:18:42 +05:00
b584e7d956 Rewrite for compatibility 2023-11-12 23:18:17 +05:00
570842eab6 Mixin Loader 2023-11-12 23:17:59 +05:00
6915429319 Add Mixin Loader 2023-11-12 23:17:44 +05:00
eb4bc5643b Add Ad Astra 2023-11-12 23:17:26 +05:00
b1dd1f0d95 Add Ad Astra 2023-11-12 23:17:12 +05:00
1c5d916ff4 Add Ad Astra 2023-11-12 23:16:54 +05:00
46a668339c Move maven from CurseForge to Modrinth 2023-11-09 22:35:15 +05:00
58a5175ed9 Rewrite Air function 2023-11-09 22:25:08 +05:00
7ccdf8d063 Update depend Thin Air 2023-11-09 22:24:48 +05:00
5bf98c8248 Make lower version of loader 2023-11-08 20:50:40 +05:00
3e3ab91895 Add depend Thin Air 2023-11-08 20:50:20 +05:00
2bbd719a5f Update Logo
Some checks failed
build / build (17) (push) Has been cancelled
2023-11-03 23:16:13 +05:00
44b85603da Add UI render in Bad Air (thanx to silopante)
Some checks failed
build / build (17) (push) Has been cancelled
2023-11-01 13:24:41 +05:00
36942712f1 Merge remote-tracking branch 'origin/main'
Some checks failed
build / build (17) (push) Failing after 1m8s
2023-10-31 23:04:09 +05:00
fd5ef6c9f7 Little updates 2023-10-31 23:02:15 +05:00
82e8b27221 Обновить .gitea/workflows/build.yml
Some checks failed
build / build (17) (push) Failing after 2m47s
2023-10-31 16:05:53 +00:00
8a31930866 Обновить build.gradle
Some checks failed
build / build (17) (push) Failing after 6s
2023-10-31 16:03:56 +00:00
a1b720f918 Обновить .gitea/workflows/build.yml
Some checks failed
build / build (17) (push) Failing after 2m15s
2023-10-31 15:42:19 +00:00
30cdf291a6 Обновить .gitea/workflows/build.yml 2023-10-31 15:41:44 +00:00
14 changed files with 309 additions and 121 deletions

View File

@ -1,38 +1,62 @@
name: build name: build
on: [ pull_request, push ] on:
pull_request: {}
push: {}
workflow_dispatch: {}
jobs: jobs:
build: build:
env:
RUN_NUMBER: ${{ gitea.run_number }}
strategy: strategy:
matrix: matrix:
java: [ 17 ] java: [ '17' ]
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: checkout repository - name: Checkout Code
uses: actions/checkout@v2 uses: actions/checkout@v4
- name: setup jdk ${{ matrix.java }} - name: Setup JDK ${{ matrix.java }}
uses: actions/setup-java@v1 uses: actions/setup-java@v4
with: with:
distribution: 'oracle'
java-version: ${{ matrix.java }} java-version: ${{ matrix.java }}
- uses: actions/cache@v2 - name: Cache Gradle packages
uses: actions/cache@v4
with: with:
path: | path: |
~/.gradle/caches ~/.gradle/caches
~/.gradle/loom-cache
~/.gradle/wrapper ~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/gradle-wrapper.properties') }} key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: ${{ runner.os }}-gradle restore-keys: |
${{ runner.os }}-gradle-
- name: make gradle wrapper executable - name: Build with Gradle
run: chmod +x ./gradlew
- name: build
run: ./gradlew build run: ./gradlew build
- name: capture build artifacts - name: Upload Mod JAR
uses: actions/upload-artifact@v2 uses: actions/upload-artifact@v3
with: with:
name: Artifacts name: create-air-fabric
path: build/libs/ path: build/libs/*.jar
upload-release:
runs-on: ubuntu-latest
needs: build
steps:
- name: Download build artifact
uses: actions/download-artifact@v3
with:
name: create-air-fabric
- name: Make release
uses: akkuman/gitea-release-action@v1
with:
name: Create Air Fabric 1.0-${{ gitea.run_number }} for 1.20.1
tag_name: createairfabric-1.0+1.20.1-${{ gitea.run_number }}
md5sum: true
sha256sum: true
files: |-
*.jar
# build/libs/**

View File

@ -1,17 +1,13 @@
plugins { plugins {
id 'fabric-loom' version '1.2-SNAPSHOT' id "fabric-loom" version "1.8+"
id "io.github.p03w.machete" version "1.+" // automatic jar compressing on build id "io.github.p03w.machete" version "1.+" // automatic jar compressing on build
id 'maven-publish' id 'maven-publish'
} }
sourceCompatibility = JavaVersion.VERSION_17 base.archivesName = archives_base_name
targetCompatibility = JavaVersion.VERSION_17
archivesBaseName = project.archives_base_name
group = project.maven_group group = project.maven_group
//String buildNumber = System.getenv("GITHUB_RUN_NUMBER") String buildNumber = System.getenv("RUN_NUMBER")
String buildNumber = 4
version = "${mod_version}+${minecraft_version}" + (buildNumber != null ? "-${buildNumber}" : "") version = "${mod_version}+${minecraft_version}" + (buildNumber != null ? "-${buildNumber}" : "")
repositories { repositories {
@ -21,21 +17,34 @@ repositories {
// See https://docs.gradle.org/current/userguide/declaring_repositories.html // See https://docs.gradle.org/current/userguide/declaring_repositories.html
// for more information about repositories. // for more information about repositories.
maven { url = "https://maven.shedaniel.me/" } // Cloth Config, REI maven { url = "https://maven.shedaniel.me/" } // Cloth Config, REI
maven { url = "https://dvs1.progwml6.com/files/maven/" } // JEI maven { url = "https://maven.blamejared.com" } // JEI
maven { url = "https://maven.parchmentmc.org" } // Parchment mappings maven {
name = 'ParchmentMC'
url = 'https://maven.parchmentmc.org'
}
maven { url = "https://maven.quiltmc.org/repository/release" } // Quilt Mappings maven { url = "https://maven.quiltmc.org/repository/release" } // Quilt Mappings
maven { url = "https://api.modrinth.com/maven" } // LazyDFU maven { url = "https://api.modrinth.com/maven" } // LazyDFU
maven { url = "https://maven.terraformersmc.com/releases/" } // Mod Menu maven { url = "https://maven.terraformersmc.com/releases/" } // Mod Menu
maven { url = "https://mvn.devos.one/snapshots/" } // Create, Porting Lib, Forge Tags, Milk Lib, Registrate
maven { url = "https://cursemaven.com" } // Forge Config API Port maven { url = "https://cursemaven.com" } // Forge Config API Port
maven { url = "https://maven.jamieswhiteshirt.com/libs-release" } // Reach Entity Attributes maven { url = "https://maven.jamieswhiteshirt.com/libs-release" } // Reach Entity Attributes
maven { url = "https://jitpack.io/" } // Mixin Extras, Fabric ASM maven { // Fabric ASM for Porting Lib
url = "https://jitpack.io/"
content { includeGroupAndSubgroups("com.github") }
}
maven { url = "https://maven.tterrag.com/" } // Flywheel maven { url = "https://maven.tterrag.com/" } // Flywheel
maven { url = "https://mvn.devos.one/snapshots/" } // Create and several dependencies
maven { url = "https://mvn.devos.one/releases/" } // Porting Lib releases
maven { url = "https://raw.githubusercontent.com/Fuzss/modresources/main/maven" } // Forge Config API Port
maven { exclusiveContent {
url 'https://www.cursemaven.com' forRepository {
content { maven {
includeGroup "curse.maven" name = "Modrinth"
url = "https://api.modrinth.com/maven"
}
}
filter {
includeGroup "maven.modrinth"
} }
} }
} }
@ -57,33 +66,40 @@ dependencies {
modImplementation("com.simibubi.create:create-fabric-${minecraft_version}:${create_version}") modImplementation("com.simibubi.create:create-fabric-${minecraft_version}:${create_version}")
// Thin Air // Thin Air
modImplementation("curse.maven:new-thin-air-878379:4611944") modImplementation("maven.modrinth:thin-air:${thinair_version}")
// Ad Astra
modImplementation("maven.modrinth:ad-astra:${adastra_version}")
modImplementation("maven.modrinth:botarium:${botarium_version}")
// Development QOL // Development QOL
modLocalRuntime("maven.modrinth:lazydfu:${lazydfu_version}") modLocalRuntime("maven.modrinth:lazydfu:${lazydfu_version}")
modLocalRuntime("com.terraformersmc:modmenu:${modmenu_version}") modLocalRuntime("com.terraformersmc:modmenu:${modmenu_version}")
// Recipe Viewers - Create Fabric supports JEI, REI, and EMI. include(implementation(annotationProcessor("io.github.llamalad7:mixinextras-fabric:0.4.1")))
// Recipe Viewers - Create Fabric supports JEI, REI, and EMI.
// See root gradle.properties to choose which to use at runtime. // See root gradle.properties to choose which to use at runtime.
switch (recipe_viewer.toLowerCase(Locale.ROOT)) { switch (recipe_viewer.toLowerCase(Locale.ROOT)) {
case "jei": modLocalRuntime("mezz.jei:jei-${minecraft_version}-fabric:${jei_version}"); break case "jei": modLocalRuntime("mezz.jei:jei-$minecraft_version-fabric:$jei_version"); break
case "rei": modLocalRuntime("me.shedaniel:RoughlyEnoughItems-fabric:${rei_version}"); break case "rei": modLocalRuntime("me.shedaniel:RoughlyEnoughItems-fabric:$rei_version"); break
case "emi": modLocalRuntime("dev.emi:emi:${emi_version}"); break case "emi": modLocalRuntime("dev.emi:emi-fabric:$emi_version"); break
case "disabled": break case "disabled": break
default: println("Unknown recipe viewer specified: ${recipe_viewer}. Must be JEI, REI, EMI, or disabled.") default: println("Unknown recipe viewer specified: $recipe_viewer. Must be JEI, REI, EMI, or disabled.")
} }
} }
processResources { processResources {
// require dependencies to be the version compiled against or newer // require dependencies to be the version compiled against or newer
Map<String, String> properties = new HashMap<>() Map<String, Object> properties = [
properties.put("version", version) "version": version,
properties.put("fabric_loader_version", fabric_loader_version) "fabric_loader_version": fabric_loader_version,
properties.put("fabric_api_version", fabric_api_version) "fabric_api_version": fabric_api_version,
properties.put("create_version", create_version) "create_version": create_version,
properties.put("minecraft_version", minecraft_version) "minecraft_version": minecraft_version
]
properties.forEach((k, v) -> inputs.property(k, v)) inputs.properties(properties)
filesMatching("fabric.mod.json") { filesMatching("fabric.mod.json") {
expand properties expand properties
@ -92,7 +108,7 @@ processResources {
tasks.withType(JavaCompile).configureEach { tasks.withType(JavaCompile).configureEach {
it.options.encoding = "UTF-8" it.options.encoding = "UTF-8"
it.options.release = Integer.parseInt(sourceCompatibility) it.options.release = 17
} }
java { java {
@ -104,20 +120,3 @@ jar {
rename { "${it}_${project.archivesBaseName}"} rename { "${it}_${project.archivesBaseName}"}
} }
} }
// configure the maven publication
publishing {
publications {
mavenJava(MavenPublication) {
from components.java
}
}
// See https://docs.gradle.org/current/userguide/publishing_maven.html for information on how to set up publishing.
repositories {
// Add repositories to publish to here.
// Notice: This block does NOT have the same function as the block in the top level.
// The repositories here will be used for publishing your artifact, not for
// retrieving dependencies.
}
}

View File

@ -2,30 +2,35 @@
org.gradle.jvmargs=-Xmx1G org.gradle.jvmargs=-Xmx1G
# Fabric Properties # Fabric Properties
# check these on https://modmuss50.me/fabric.html # check these on https://modmuss50.me/fabric.html
minecraft_version=1.20.1 minecraft_version=1.20.1
yarn_mappings=1.20.1+build.10 yarn_mappings=1.20.1+build.10
fabric_loader_version=0.14.24 fabric_loader_version=0.16.9
# check this on https://modmuss50.me/fabric.html # check this on https://modmuss50.me/fabric.html
fabric_api_version=0.90.0+1.20.1 fabric_api_version=0.92.2+1.20.1
# Mappings # Mappings
# https://lambdaurora.dev/tools/import_quilt.html # https://lambdaurora.dev/tools/import_quilt.html
qm_version = 23 qm_version = 23
# https://parchmentmc.org/docs/getting-started # https://parchmentmc.org/docs/getting-started
parchment_version = 2023.06.26 parchment_version = 2023.09.03
# Mod Properties # Mod Properties
mod_version = 1.0 mod_version = 1.0
maven_group = ru.bitheaven maven_group = ru.bitheaven
archives_base_name = createairfabric archives_base_name = createairfabric
# Dependencies # Dependencies
# https://modrinth.com/mod/create-fabric/versions # https://modrinth.com/mod/create-fabric/versions
create_version = 0.5.1-d-build.1161+mc1.20.1 create_version = 0.5.1-j-build.1631+mc1.20.1
# set to disabled to have none of them. # https://modrinth.com/mod/thin-air/versions
recipe_viewer = disabled thinair_version = v8.1.5-1.20.1-Fabric
# Mod Menu - https://modrinth.com/mod/modmenu/versions # https://modrinth.com/mod/ad-astra/versions
modmenu_version = 4.1.2 adastra_version = Xtm1uo8F
# LazyDFU - https://modrinth.com/mod/lazydfu/versions botarium_version = f3ATcSfq
lazydfu_version = 0.1.3 # set to disabled to have none of them.
recipe_viewer = disabled
# Mod Menu - https://modrinth.com/mod/modmenu/versions
modmenu_version = 7.2.2
# LazyDFU - https://modrinth.com/mod/lazydfu/versions
lazydfu_version = 0.1.3

View File

@ -1,6 +1,5 @@
distributionBase=GRADLE_USER_HOME distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.1.1-bin.zip distributionUrl=https\://services.gradle.org/distributions/gradle-8.11.1-bin.zip
networkTimeout=10000
zipStoreBase=GRADLE_USER_HOME zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists zipStorePath=wrapper/dists

View File

@ -1,11 +1,10 @@
package ru.bitheaven.createairfabric; package ru.bitheaven.createairfabric;
import com.simibubi.create.Create; import com.simibubi.create.Create;
import fuzs.thinair.helper.AirHelper; import earth.terrarium.adastra.api.systems.OxygenApi;
import fuzs.thinair.helper.AirQualityLevel; import fuzs.thinair.helper.AirQualityHelperImpl;
import io.github.fabricators_of_create.porting_lib.util.EnvExecutor;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.minecraft.resources.ResourceLocation; import net.fabricmc.loader.api.FabricLoader;
import net.minecraft.world.entity.LivingEntity; import net.minecraft.world.entity.LivingEntity;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -18,18 +17,17 @@ public class CreateAirFabric implements ModInitializer {
@Override @Override
public void onInitialize() { public void onInitialize() {
LOGGER.info("Create addon mod [{}] is loading alongside Create [{}]!", NAME, Create.VERSION); LOGGER.info("Create addon mod [{}] is loading alongside Create [{}]!", NAME, Create.VERSION);
LOGGER.info(EnvExecutor.unsafeRunForDist(
() -> () -> "{} is accessing Porting Lib from the client!",
() -> () -> "{} is accessing Porting Lib from the server!"
), NAME);
} }
public static boolean airQualityActivatesHelmet(LivingEntity entity) { public static boolean isOxygen(LivingEntity entity) {
final var air = AirHelper.getO2LevelFromLocation(entity.getEyePosition(), entity.level()).getFirst(); boolean oxygen = true;
return air == AirQualityLevel.RED || air == AirQualityLevel.YELLOW; if (FabricLoader.getInstance().isModLoaded("thinair")) {
} oxygen &= new AirQualityHelperImpl()
.getAirQualityAtLocation(entity.level(), entity.getEyePosition()).canBreathe;
public static ResourceLocation id(String path) { }
return new ResourceLocation(ID, path); if (FabricLoader.getInstance().isModLoaded("ad_astra")) {
oxygen &= OxygenApi.API.hasOxygen(entity.level());
}
return oxygen;
} }
} }

View File

@ -0,0 +1,69 @@
package ru.bitheaven.createairfabric;
import com.google.common.collect.ImmutableMap;
import net.fabricmc.loader.api.FabricLoader;
import org.objectweb.asm.tree.ClassNode;
import org.spongepowered.asm.mixin.extensibility.IMixinConfigPlugin;
import org.spongepowered.asm.mixin.extensibility.IMixinInfo;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.function.Supplier;
public class CreateAirFabricMixinPlugin implements IMixinConfigPlugin {
private static final Supplier<Boolean> TRUE = () -> true;
private static final Map<String, Supplier<Boolean>> CONDITIONS = ImmutableMap.of(
"ru.bitheaven.createairfabric.mixin.DivingHelmetItemMixin",
() -> FabricLoader.getInstance().isModLoaded("thinair")
|| FabricLoader.getInstance().isModLoaded("ad_astra"),
"ru.bitheaven.createairfabric.mixin.RemainingAirOverlayMixin",
() -> FabricLoader.getInstance().isModLoaded("thinair")
|| FabricLoader.getInstance().isModLoaded("ad_astra"),
"ru.bitheaven.createairfabric.mixin.EntityOxygenSystemMixin",
() -> FabricLoader.getInstance().isModLoaded("ad_astra"),
"ru.bitheaven.createairfabric.mixin.EntityTemperatureSystemMixin",
() -> FabricLoader.getInstance().isModLoaded("ad_astra")
);
@Override
public boolean shouldApplyMixin(String targetClassName, String mixinClassName) {
return CONDITIONS.getOrDefault(mixinClassName, TRUE).get();
}
// Boilerplate
@Override
public void onLoad(String mixinPackage) {
}
@Override
public String getRefMapperConfig() {
return null;
}
@Override
public void acceptTargets(Set<String> myTargets, Set<String> otherTargets) {
}
@Override
public List<String> getMixins() {
return null;
}
@Override
public void preApply(String targetClassName, ClassNode targetClass, String mixinClassName, IMixinInfo mixinInfo) {
}
@Override
public void postApply(String targetClassName, ClassNode targetClass, String mixinClassName, IMixinInfo mixinInfo) {
}
}

View File

@ -1,26 +1,25 @@
package ru.bitheaven.createairfabric.mixin; package ru.bitheaven.createairfabric.mixin;
import fuzs.thinair.helper.AirHelper; import net.minecraft.world.entity.LivingEntity;
import fuzs.thinair.helper.AirQualityLevel;
import net.minecraft.tags.TagKey;
import net.minecraft.world.level.material.Fluid;
import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Redirect; import com.llamalad7.mixinextras.injector.ModifyExpressionValue;
import ru.bitheaven.createairfabric.CreateAirFabric;
import com.simibubi.create.content.equipment.armor.DivingHelmetItem; import com.simibubi.create.content.equipment.armor.DivingHelmetItem;
import ru.bitheaven.createairfabric.CreateAirFabric;
import net.minecraft.world.entity.LivingEntity;
@Mixin(DivingHelmetItem.class) @Mixin(DivingHelmetItem.class)
public abstract class DivingHelmetItemMixin { public abstract class DivingHelmetItemMixin {
/** /**
* Activate helmet "if in water or lava" -> "if in water or bad air or lava" * Activate helmet "if in water or lava" -> "if in water or bad air or lava"
*/ */
@Redirect(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/entity/LivingEntity;isEyeInFluid(Lnet/minecraft/tags/TagKey;)Z"), @ModifyExpressionValue(at = @At(value = "INVOKE", target = "Lnet/minecraft/world/entity/LivingEntity;isEyeInFluid(Lnet/minecraft/tags/TagKey;)Z"),
method = "breatheUnderwater(Lnet/minecraft/world/entity/LivingEntity;)V") method = "breatheUnderwater(Lnet/minecraft/world/entity/LivingEntity;)V")
private static boolean redirectBreatheUnderwater(LivingEntity entity, TagKey<Fluid> fluidTagKey) { private static boolean redirectBreatheUnderwater(boolean original, LivingEntity entity) {
return entity.isEyeInFluid(fluidTagKey) || CreateAirFabric.airQualityActivatesHelmet(entity); boolean oxygen = true;
oxygen &= !original;
oxygen &= !entity.isUnderWater();
oxygen &= CreateAirFabric.isOxygen(entity);
return !oxygen;
} }
} }

View File

@ -0,0 +1,41 @@
package ru.bitheaven.createairfabric.mixin;
import com.llamalad7.mixinextras.injector.ModifyExpressionValue;
import com.simibubi.create.content.equipment.armor.BacktankItem;
import com.simibubi.create.content.equipment.armor.BacktankUtil;
import com.simibubi.create.content.equipment.armor.DivingHelmetItem;
import earth.terrarium.adastra.common.systems.OxygenApiImpl;
import earth.terrarium.adastra.common.tags.ModItemTags;
import net.minecraft.server.level.ServerLevel;
import net.minecraft.world.entity.EquipmentSlot;
import net.minecraft.world.entity.LivingEntity;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
@Mixin(OxygenApiImpl.class)
public abstract class EntityOxygenSystemMixin {
/**
* Make air exists if Create Air
*/
@ModifyExpressionValue(at = @At(value = "INVOKE", target = "Learth/terrarium/adastra/common/items/armor/SpaceSuitItem;hasOxygen(Lnet/minecraft/world/entity/Entity;)Z"),
method = "entityTick(Lnet/minecraft/server/level/ServerLevel;Lnet/minecraft/world/entity/LivingEntity;)V")
private boolean redirectHasOxygen(boolean original, ServerLevel level, LivingEntity entity) {
boolean createOxygen = true;
createOxygen &= !DivingHelmetItem.getWornItem(entity).isEmpty();
createOxygen &= !BacktankUtil.getAllWithAir(entity).isEmpty();
return original || createOxygen;
}
@ModifyExpressionValue(at = @At(value = "INVOKE", target = "Learth/terrarium/adastra/common/items/armor/SpaceSuitItem;hasFullSet(Lnet/minecraft/world/entity/LivingEntity;)Z"),
method = "entityTick(Lnet/minecraft/server/level/ServerLevel;Lnet/minecraft/world/entity/LivingEntity;)V")
private boolean redirectHasFullSet(boolean original, ServerLevel level, LivingEntity entity) {
boolean createArmor = true;
createArmor &= entity.getItemBySlot(EquipmentSlot.HEAD).getItem() instanceof DivingHelmetItem;
createArmor &= entity.getItemBySlot(EquipmentSlot.CHEST).getItem() instanceof BacktankItem;
createArmor &= entity.getItemBySlot(EquipmentSlot.LEGS).is(ModItemTags.SPACE_SUITS);
createArmor &= entity.getItemBySlot(EquipmentSlot.FEET).is(ModItemTags.SPACE_SUITS);
return original || createArmor;
}
}

View File

@ -0,0 +1,30 @@
package ru.bitheaven.createairfabric.mixin;
import com.llamalad7.mixinextras.injector.ModifyExpressionValue;
import earth.terrarium.adastra.common.items.armor.NetheriteSpaceSuitItem;
import earth.terrarium.adastra.common.tags.ModItemTags;
import earth.terrarium.adastra.common.systems.TemperatureApiImpl;
import net.minecraft.server.level.ServerLevel;
import net.minecraft.world.entity.EquipmentSlot;
import net.minecraft.world.entity.LivingEntity;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
@Mixin(TemperatureApiImpl.class)
public abstract class EntityTemperatureSystemMixin {
@ModifyExpressionValue(at = @At(value = "INVOKE", target = "Learth/terrarium/adastra/api/events/AdAstraEvents$HotTemperatureTickEvent;fire(Lnet/minecraft/server/level/ServerLevel;Lnet/minecraft/world/entity/LivingEntity;)Z"),
method = "entityTick(Lnet/minecraft/server/level/ServerLevel;Lnet/minecraft/world/entity/LivingEntity;)V")
private boolean redirectTemperatureTick(boolean original, ServerLevel level, LivingEntity entity) {
boolean createNetherite = true;
createNetherite &= entity.getItemBySlot(EquipmentSlot.HEAD).getItem().isFireResistant();
createNetherite &= entity.getItemBySlot(EquipmentSlot.CHEST).getItem().isFireResistant();
createNetherite &= entity.getItemBySlot(EquipmentSlot.LEGS).is(ModItemTags.HEAT_RESISTANT_ARMOR)
|| entity.getItemBySlot(EquipmentSlot.LEGS).getItem() instanceof NetheriteSpaceSuitItem
|| entity.getItemBySlot(EquipmentSlot.LEGS).getItem().isFireResistant();
createNetherite &= entity.getItemBySlot(EquipmentSlot.FEET).is(ModItemTags.HEAT_RESISTANT_ARMOR)
|| entity.getItemBySlot(EquipmentSlot.FEET).getItem() instanceof NetheriteSpaceSuitItem
|| entity.getItemBySlot(EquipmentSlot.FEET).getItem().isFireResistant();
return original && !createNetherite;
}
}

View File

@ -1,11 +1,8 @@
package ru.bitheaven.createairfabric.mixin; package ru.bitheaven.createairfabric.mixin;
import ru.bitheaven.createairfabric.CreateAirFabric; import ru.bitheaven.createairfabric.CreateAirFabric;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.main.GameConfig; import net.minecraft.client.main.GameConfig;
import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject; import org.spongepowered.asm.mixin.injection.Inject;

View File

@ -0,0 +1,23 @@
package ru.bitheaven.createairfabric.mixin;
import com.llamalad7.mixinextras.injector.ModifyExpressionValue;
import com.simibubi.create.content.equipment.armor.RemainingAirOverlay;
import net.minecraft.client.Minecraft;
import net.minecraft.client.player.LocalPlayer;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
import ru.bitheaven.createairfabric.CreateAirFabric;
@Mixin(RemainingAirOverlay.class)
public class RemainingAirOverlayMixin {
/**
* Activate UI "if in water or lava" -> "if in water or bad air or lava"
*/
@ModifyExpressionValue(at = @At(value = "INVOKE", target = "Lnet/minecraft/client/player/LocalPlayer;isEyeInFluid(Lnet/minecraft/tags/TagKey;)Z"),
method = "render(Lnet/minecraft/client/gui/GuiGraphics;II)V")
private static boolean redirectRender(boolean original) {
Minecraft mc = Minecraft.getInstance();
LocalPlayer player = mc.player;
return original || !CreateAirFabric.isOxygen(player);
}
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 52 KiB

After

Width:  |  Height:  |  Size: 60 KiB

View File

@ -3,11 +3,15 @@
"minVersion": "0.8", "minVersion": "0.8",
"package": "ru.bitheaven.createairfabric.mixin", "package": "ru.bitheaven.createairfabric.mixin",
"compatibilityLevel": "JAVA_17", "compatibilityLevel": "JAVA_17",
"plugin": "ru.bitheaven.createairfabric.CreateAirFabricMixinPlugin",
"mixins": [ "mixins": [
"DivingHelmetItemMixin" "DivingHelmetItemMixin",
"EntityOxygenSystemMixin",
"EntityTemperatureSystemMixin"
], ],
"client": [ "client": [
"MinecraftMixin" "MinecraftMixin",
"RemainingAirOverlayMixin"
], ],
"injectors": { "injectors": {
"defaultRequire": 1 "defaultRequire": 1

View File

@ -3,7 +3,7 @@
"id": "createairfabric", "id": "createairfabric",
"version": "${version}", "version": "${version}",
"name": "Create Air Fabric", "name": "Create Air Fabric",
"description": "Addon for compatibility Create and Thin Air", "description": "Addon for Create that add compatibility with Thin Air, Ad Astra",
"authors": [ "authors": [
"BitHeaven" "BitHeaven"
], ],