aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/gregtech/common/bees/GT_Bee_Mutation.java
diff options
context:
space:
mode:
authorNotAPenguin <michiel.vandeginste@gmail.com>2024-09-02 23:17:17 +0200
committerGitHub <noreply@github.com>2024-09-02 23:17:17 +0200
commit1b820de08a05070909a267e17f033fcf58ac8710 (patch)
tree02831a025986a06b20f87e5bcc69d1e0c639a342 /src/main/java/gregtech/common/bees/GT_Bee_Mutation.java
parentafd3fd92b6a6ab9ab0d0dc3214e6bc8ff7a86c9b (diff)
downloadGT5-Unofficial-1b820de08a05070909a267e17f033fcf58ac8710.tar.gz
GT5-Unofficial-1b820de08a05070909a267e17f033fcf58ac8710.tar.bz2
GT5-Unofficial-1b820de08a05070909a267e17f033fcf58ac8710.zip
The Great Renaming (#3014)
* move kekztech to a single root dir * move detrav to a single root dir * move gtnh-lanthanides to a single root dir * move tectech and delete some gross reflection in gt++ * remove more reflection inside gt5u * delete more reflection in gt++ * fix imports * move bartworks and bwcrossmod * fix proxies * move galactigreg and ggfab * move gtneioreplugin * try to fix gt++ bee loader * apply the rename rules to BW * apply rename rules to bwcrossmod * apply rename rules to detrav scanner mod * apply rename rules to galacticgreg * apply rename rules to ggfab * apply rename rules to goodgenerator * apply rename rules to gtnh-lanthanides * apply rename rules to gt++ * apply rename rules to kekztech * apply rename rules to kubatech * apply rename rules to tectech * apply rename rules to gt apply the rename rules to gt * fix tt import * fix mui hopefully * fix coremod except intergalactic * rename assline recipe class * fix a class name i stumbled on * rename StructureUtility to GTStructureUtility to prevent conflict with structurelib * temporary rename of GTTooltipDataCache to old name * fix gt client/server proxy names
Diffstat (limited to 'src/main/java/gregtech/common/bees/GT_Bee_Mutation.java')
-rw-r--r--src/main/java/gregtech/common/bees/GT_Bee_Mutation.java85
1 files changed, 0 insertions, 85 deletions
diff --git a/src/main/java/gregtech/common/bees/GT_Bee_Mutation.java b/src/main/java/gregtech/common/bees/GT_Bee_Mutation.java
deleted file mode 100644
index e8b2d5b8c6..0000000000
--- a/src/main/java/gregtech/common/bees/GT_Bee_Mutation.java
+++ /dev/null
@@ -1,85 +0,0 @@
-package gregtech.common.bees;
-
-import java.lang.reflect.Field;
-import java.util.List;
-
-import net.minecraft.util.ChunkCoordinates;
-import net.minecraft.world.World;
-
-import org.apache.commons.lang3.reflect.FieldUtils;
-
-import forestry.api.apiculture.BeeManager;
-import forestry.api.apiculture.IAlleleBeeSpecies;
-import forestry.api.apiculture.IBeeGenome;
-import forestry.api.apiculture.IBeeHousing;
-import forestry.api.apiculture.IBeeModifier;
-import forestry.api.core.IClimateProvider;
-import forestry.api.genetics.IAllele;
-import forestry.api.genetics.IGenome;
-import forestry.api.genetics.IMutationCondition;
-import forestry.apiculture.genetics.BeeMutation;
-import forestry.core.genetics.mutations.Mutation;
-
-public class GT_Bee_Mutation extends BeeMutation {
-
- private final float split;
-
- public GT_Bee_Mutation(IAlleleBeeSpecies bee0, IAlleleBeeSpecies bee1, IAllele[] result, int chance, float split) {
- super(bee0, bee1, result, chance);
- this.split = split;
- BeeManager.beeRoot.registerMutation(this);
- }
-
- @Override
- public float getBaseChance() {
- return super.getBaseChance() / split;
- }
-
- @Override
- public float getChance(IBeeHousing housing, IAlleleBeeSpecies allele0, IAlleleBeeSpecies allele1,
- IBeeGenome genome0, IBeeGenome genome1) {
- World world = housing != null ? housing.getWorld() : null;
- ChunkCoordinates housingCoordinates = housing != null ? housing.getCoordinates() : null;
- int x = housingCoordinates != null ? housingCoordinates.posX : 0;
- int y = housingCoordinates != null ? housingCoordinates.posY : 0;
- int z = housingCoordinates != null ? housingCoordinates.posZ : 0;
-
- float processedChance = getBasicChance(world, x, y, z, allele0, allele1, genome0, genome1, housing);
-
- if (processedChance <= 0f) {
- return 0f;
- }
-
- IBeeModifier beeHousingModifier = BeeManager.beeRoot.createBeeHousingModifier(housing);
- IBeeModifier beeModeModifier = BeeManager.beeRoot.getBeekeepingMode(world)
- .getBeeModifier();
-
- processedChance *= beeHousingModifier.getMutationModifier(genome0, genome1, processedChance);
- processedChance *= beeModeModifier.getMutationModifier(genome0, genome1, processedChance);
-
- return processedChance;
- }
-
- @SuppressWarnings("unchecked")
- private float getBasicChance(World world, int x, int y, int z, IAllele allele0, IAllele allele1, IGenome genome0,
- IGenome genome1, IClimateProvider climate) {
- float mutationChance = this.getBaseChance();
- List<IMutationCondition> mutationConditions = null;
- Field f = FieldUtils.getDeclaredField(Mutation.class, "mutationConditions", true);
- if (f == null) f = FieldUtils.getField(Mutation.class, "mutationConditions", true);
- if (f == null) return mutationChance;
- try {
- mutationConditions = f.get(this) instanceof List ? (List<IMutationCondition>) f.get(this) : null;
- } catch (IllegalAccessException e) {
- e.printStackTrace();
- }
-
- if (mutationConditions != null) for (IMutationCondition mutationCondition : mutationConditions) {
- mutationChance *= mutationCondition.getChance(world, x, y, z, allele0, allele1, genome0, genome1, climate);
- if (mutationChance == 0) {
- return 0;
- }
- }
- return mutationChance;
- }
-}