More compile cleanups. (#5139)
This commit is contained in:
parent
dbf649225a
commit
3f743887e7
71 changed files with 901 additions and 411 deletions
|
@ -6,7 +6,7 @@ buildscript {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'net.minecraftforge.gradle:ForgeGradle:3.+'
|
classpath 'net.minecraftforge.gradle:ForgeGradle:3.0.4'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
22
patches/minecraft/net/minecraft/entity/EntityType.java.patch
Normal file
22
patches/minecraft/net/minecraft/entity/EntityType.java.patch
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
--- a/net/minecraft/entity/EntityType.java
|
||||||
|
+++ b/net/minecraft/entity/EntityType.java
|
||||||
|
@@ -98,6 +98,7 @@
|
||||||
|
import net.minecraft.entity.projectile.EntityTippedArrow;
|
||||||
|
import net.minecraft.entity.projectile.EntityTrident;
|
||||||
|
import net.minecraft.entity.projectile.EntityWitherSkull;
|
||||||
|
+import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.server.MinecraftServer;
|
||||||
|
@@ -121,9 +122,9 @@
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
|
-public class EntityType<T extends Entity> {
|
||||||
|
+public class EntityType<T extends Entity> extends net.minecraftforge.registries.ForgeRegistryEntry<EntityType<T>> {
|
||||||
|
private static final Logger field_200731_aJ = LogManager.getLogger();
|
||||||
|
- public static final RegistryNamespaced<ResourceLocation, EntityType<?>> field_200787_a = new RegistryNamespaced<ResourceLocation, EntityType<?>>();
|
||||||
|
+ public static final RegistryNamespaced<ResourceLocation, EntityType<?>> field_200787_a = net.minecraftforge.registries.GameData.getWrapper(EntityType.class);
|
||||||
|
public static final EntityType<EntityAreaEffectCloud> field_200788_b = func_200712_a("area_effect_cloud", EntityType.Builder.func_201757_a(EntityAreaEffectCloud.class, EntityAreaEffectCloud::new));
|
||||||
|
public static final EntityType<EntityArmorStand> field_200789_c = func_200712_a("armor_stand", EntityType.Builder.func_201757_a(EntityArmorStand.class, EntityArmorStand::new));
|
||||||
|
public static final EntityType<EntityTippedArrow> field_200790_d = func_200712_a("arrow", EntityType.Builder.func_201757_a(EntityTippedArrow.class, EntityTippedArrow::new));
|
|
@ -0,0 +1,81 @@
|
||||||
|
--- a/net/minecraft/entity/monster/EntityZombieVillager.java
|
||||||
|
+++ b/net/minecraft/entity/monster/EntityZombieVillager.java
|
||||||
|
@@ -49,15 +49,18 @@
|
||||||
|
|
||||||
|
public void setProfession(int profession) {
|
||||||
|
this.dataManager.set(PROFESSION, profession);
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.onSetProfession(this, profession);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @Deprecated // Use Forge Variant below
|
||||||
|
public int getProfession() {
|
||||||
|
- return Math.max(this.dataManager.get(PROFESSION) % 6, 0);
|
||||||
|
+ return Math.max(this.dataManager.get(PROFESSION), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void writeEntityToNBT(NBTTagCompound compound) {
|
||||||
|
super.writeEntityToNBT(compound);
|
||||||
|
compound.setInteger("Profession", this.getProfession());
|
||||||
|
+ compound.setString("ProfessionName", this.getForgeProfession().getRegistryName().toString());
|
||||||
|
compound.setInteger("ConversionTime", this.isConverting() ? this.conversionTime : -1);
|
||||||
|
if (this.converstionStarter != null) {
|
||||||
|
compound.setUniqueId("ConversionPlayer", this.converstionStarter);
|
||||||
|
@@ -68,6 +71,11 @@
|
||||||
|
public void readEntityFromNBT(NBTTagCompound compound) {
|
||||||
|
super.readEntityFromNBT(compound);
|
||||||
|
this.setProfession(compound.getInteger("Profession"));
|
||||||
|
+ if (compound.hasKey("ProfessionName")) {
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession p = net.minecraftforge.registries.ForgeRegistries.VILLAGER_PROFESSIONS.getValue(new net.minecraft.util.ResourceLocation(compound.getString("ProfessionName")));
|
||||||
|
+ if (p == null) p = net.minecraftforge.fml.common.registry.VillagerRegistry.FARMER.orElseThrow(() -> new IllegalStateException("Farmer profession not initialized?"));
|
||||||
|
+ this.setForgeProfession(p);
|
||||||
|
+ }
|
||||||
|
if (compound.hasKey("ConversionTime", 99) && compound.getInteger("ConversionTime") > -1) {
|
||||||
|
this.startConverting(compound.hasUniqueId("ConversionPlayer") ? compound.getUniqueId("ConversionPlayer") : null, compound.getInteger("ConversionTime"));
|
||||||
|
}
|
||||||
|
@@ -145,7 +153,7 @@
|
||||||
|
protected void finishConversion() {
|
||||||
|
EntityVillager entityvillager = new EntityVillager(this.world);
|
||||||
|
entityvillager.copyLocationAndAnglesFrom(this);
|
||||||
|
- entityvillager.setProfession(this.getProfession());
|
||||||
|
+ entityvillager.setProfession(this.getForgeProfession());
|
||||||
|
entityvillager.finalizeMobSpawn(this.world.getDifficultyForLocation(new BlockPos(entityvillager)), (IEntityLivingData)null, (NBTTagCompound)null, false);
|
||||||
|
entityvillager.setLookingForHome();
|
||||||
|
if (this.isChild()) {
|
||||||
|
@@ -224,4 +232,37 @@
|
||||||
|
protected ItemStack getSkullDrop() {
|
||||||
|
return ItemStack.EMPTY;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ /* ======================================== FORGE START =====================================*/
|
||||||
|
+
|
||||||
|
+ @Nullable
|
||||||
|
+ private net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession prof;
|
||||||
|
+ public void setForgeProfession(net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession prof)
|
||||||
|
+ {
|
||||||
|
+ this.prof = prof;
|
||||||
|
+ this.setProfession(net.minecraftforge.fml.common.registry.VillagerRegistry.getId(prof));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession getForgeProfession()
|
||||||
|
+ {
|
||||||
|
+ if (this.prof == null)
|
||||||
|
+ {
|
||||||
|
+ this.prof = net.minecraftforge.fml.common.registry.VillagerRegistry.getById(this.getProfession());
|
||||||
|
+ if (this.prof == null)
|
||||||
|
+ return net.minecraftforge.fml.common.registry.VillagerRegistry.FARMER.orElseThrow(() -> new IllegalStateException("Farmer profession not initialized?"));
|
||||||
|
+ }
|
||||||
|
+ return this.prof;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void notifyDataManagerChange(DataParameter<?> key)
|
||||||
|
+ {
|
||||||
|
+ super.notifyDataManagerChange(key);
|
||||||
|
+ if (key.equals(PROFESSION))
|
||||||
|
+ {
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.onSetProfession(this, this.dataManager.get(PROFESSION));
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* ======================================== FORGE END =====================================*/
|
||||||
|
}
|
|
@ -0,0 +1,169 @@
|
||||||
|
--- a/net/minecraft/entity/passive/EntityVillager.java
|
||||||
|
+++ b/net/minecraft/entity/passive/EntityVillager.java
|
||||||
|
@@ -105,7 +105,7 @@
|
||||||
|
private boolean needsInitilization;
|
||||||
|
private boolean isWillingToMate;
|
||||||
|
private int wealth;
|
||||||
|
- private String lastBuyingPlayer;
|
||||||
|
+ private java.util.UUID lastBuyingPlayer;
|
||||||
|
private int careerId;
|
||||||
|
private int careerLevel;
|
||||||
|
private boolean isLookingForHome;
|
||||||
|
@@ -220,7 +220,7 @@
|
||||||
|
if (flag) {
|
||||||
|
itemstack.interactWithEntity(player, this, hand);
|
||||||
|
return true;
|
||||||
|
- } else if (itemstack.getItem() != Items.field_196172_da && this.isEntityAlive() && !this.isTrading() && !this.isChild()) {
|
||||||
|
+ } else if (itemstack.getItem() != Items.field_196172_da && this.isEntityAlive() && !this.isTrading() && !this.isChild() && !player.isSneaking()) {
|
||||||
|
if (this.buyingList == null) {
|
||||||
|
this.populateBuyingList();
|
||||||
|
}
|
||||||
|
@@ -250,6 +250,7 @@
|
||||||
|
public void writeEntityToNBT(NBTTagCompound compound) {
|
||||||
|
super.writeEntityToNBT(compound);
|
||||||
|
compound.setInteger("Profession", this.getProfession());
|
||||||
|
+ compound.setString("ProfessionName", this.getProfessionForge().getRegistryName().toString());
|
||||||
|
compound.setInteger("Riches", this.wealth);
|
||||||
|
compound.setInteger("Career", this.careerId);
|
||||||
|
compound.setInteger("CareerLevel", this.careerLevel);
|
||||||
|
@@ -273,6 +274,14 @@
|
||||||
|
public void readEntityFromNBT(NBTTagCompound compound) {
|
||||||
|
super.readEntityFromNBT(compound);
|
||||||
|
this.setProfession(compound.getInteger("Profession"));
|
||||||
|
+ if (compound.hasKey("ProfessionName"))
|
||||||
|
+ {
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession p =
|
||||||
|
+ net.minecraftforge.registries.ForgeRegistries.VILLAGER_PROFESSIONS.getValue(new net.minecraft.util.ResourceLocation(compound.getString("ProfessionName")));
|
||||||
|
+ if (p == null)
|
||||||
|
+ p = net.minecraftforge.registries.ForgeRegistries.VILLAGER_PROFESSIONS.getValue(new net.minecraft.util.ResourceLocation("minecraft:farmer"));
|
||||||
|
+ this.setProfession(p);
|
||||||
|
+ }
|
||||||
|
this.wealth = compound.getInteger("Riches");
|
||||||
|
this.careerId = compound.getInteger("Career");
|
||||||
|
this.careerLevel = compound.getInteger("CareerLevel");
|
||||||
|
@@ -318,12 +327,42 @@
|
||||||
|
|
||||||
|
public void setProfession(int professionId) {
|
||||||
|
this.dataManager.set(PROFESSION, professionId);
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.onSetProfession(this, professionId);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @Deprecated // Use Forge Variant below
|
||||||
|
public int getProfession() {
|
||||||
|
- return Math.max(this.dataManager.get(PROFESSION) % 6, 0);
|
||||||
|
+ return Math.max(this.dataManager.get(PROFESSION), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ private net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession prof;
|
||||||
|
+ public void setProfession(net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession prof)
|
||||||
|
+ {
|
||||||
|
+ this.prof = prof;
|
||||||
|
+ this.setProfession(net.minecraftforge.fml.common.registry.VillagerRegistry.getId(prof));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession getProfessionForge()
|
||||||
|
+ {
|
||||||
|
+ if (this.prof == null)
|
||||||
|
+ {
|
||||||
|
+ this.prof = net.minecraftforge.fml.common.registry.VillagerRegistry.getById(this.getProfession());
|
||||||
|
+ if (this.prof == null)
|
||||||
|
+ return net.minecraftforge.fml.common.registry.VillagerRegistry.getById(0); //Farmer
|
||||||
|
+ }
|
||||||
|
+ return this.prof;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void notifyDataManagerChange(DataParameter<?> key)
|
||||||
|
+ {
|
||||||
|
+ super.notifyDataManagerChange(key);
|
||||||
|
+ if (key.equals(PROFESSION))
|
||||||
|
+ {
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.onSetProfession(this, this.dataManager.get(PROFESSION));
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
public boolean isMating() {
|
||||||
|
return this.isMating;
|
||||||
|
}
|
||||||
|
@@ -433,7 +472,7 @@
|
||||||
|
this.needsInitilization = true;
|
||||||
|
this.isWillingToMate = true;
|
||||||
|
if (this.buyingPlayer != null) {
|
||||||
|
- this.lastBuyingPlayer = this.buyingPlayer.getGameProfile().getName();
|
||||||
|
+ this.lastBuyingPlayer = this.buyingPlayer.getUniqueID();
|
||||||
|
} else {
|
||||||
|
this.lastBuyingPlayer = null;
|
||||||
|
}
|
||||||
|
@@ -473,11 +512,10 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
private void populateBuyingList() {
|
||||||
|
- EntityVillager.ITradeList[][][] aentityvillager$itradelist = DEFAULT_TRADE_LIST_MAP[this.getProfession()];
|
||||||
|
if (this.careerId != 0 && this.careerLevel != 0) {
|
||||||
|
++this.careerLevel;
|
||||||
|
} else {
|
||||||
|
- this.careerId = this.rand.nextInt(aentityvillager$itradelist.length) + 1;
|
||||||
|
+ this.careerId = this.getProfessionForge().getRandomCareer(this.rand) + 1;
|
||||||
|
this.careerLevel = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -487,16 +525,11 @@
|
||||||
|
|
||||||
|
int i = this.careerId - 1;
|
||||||
|
int j = this.careerLevel - 1;
|
||||||
|
- if (i >= 0 && i < aentityvillager$itradelist.length) {
|
||||||
|
- EntityVillager.ITradeList[][] aentityvillager$itradelist1 = aentityvillager$itradelist[i];
|
||||||
|
- if (j >= 0 && j < aentityvillager$itradelist1.length) {
|
||||||
|
- EntityVillager.ITradeList[] aentityvillager$itradelist2 = aentityvillager$itradelist1[j];
|
||||||
|
-
|
||||||
|
- for(EntityVillager.ITradeList entityvillager$itradelist : aentityvillager$itradelist2) {
|
||||||
|
- entityvillager$itradelist.addMerchantRecipe(this, this.buyingList, this.rand);
|
||||||
|
- }
|
||||||
|
+ java.util.List<EntityVillager.ITradeList> trades = this.getProfessionForge().getCareer(i).getTrades(j);
|
||||||
|
+ if (i >= 0 && trades != null) {
|
||||||
|
+ for (EntityVillager.ITradeList entityvillager$itradelist : trades) {
|
||||||
|
+ entityvillager$itradelist.addMerchantRecipe(this, this.buyingList, this.rand);
|
||||||
|
}
|
||||||
|
-
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -567,7 +600,7 @@
|
||||||
|
s = "nitwit";
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (s != null) {
|
||||||
|
+ s = this.getProfessionForge().getCareer(this.careerId-1).getName();
|
||||||
|
ITextComponent itextcomponent1 = (new TextComponentTranslation(this.func_200600_R().func_210760_d() + '.' + s, new Object[0])).func_211710_a((p_211520_1_) -> {
|
||||||
|
p_211520_1_.setHoverEvent(this.getHoverEvent()).setInsertion(this.getCachedUniqueIdString());
|
||||||
|
});
|
||||||
|
@@ -576,9 +609,6 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
return itextcomponent1;
|
||||||
|
- } else {
|
||||||
|
- return super.getDisplayName();
|
||||||
|
- }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -619,7 +649,7 @@
|
||||||
|
public IEntityLivingData finalizeMobSpawn(DifficultyInstance p_190672_1_, @Nullable IEntityLivingData p_190672_2_, @Nullable NBTTagCompound p_190672_3_, boolean p_190672_4_) {
|
||||||
|
p_190672_2_ = super.func_204210_a(p_190672_1_, p_190672_2_, p_190672_3_);
|
||||||
|
if (p_190672_4_) {
|
||||||
|
- this.setProfession(this.world.rand.nextInt(6));
|
||||||
|
+ net.minecraftforge.fml.common.registry.VillagerRegistry.setRandomProfession(this, this.world.rand);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setAdditionalAItasks();
|
||||||
|
@@ -817,6 +847,10 @@
|
||||||
|
recipeList.add(new MerchantRecipe(itemstack, itemstack1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ //MODDERS DO NOT USE OR EDIT THIS IN ANY WAY IT WILL HAVE NO EFFECT, THIS IS JUST IN HERE TO ALLOW FORGE TO ACCESS IT
|
||||||
|
+ @Deprecated
|
||||||
|
+ public static ITradeList[][][][] GET_TRADES_DONT_USE(){ return DEFAULT_TRADE_LIST_MAP; }
|
||||||
|
|
||||||
|
public static class ListItemForEmeralds implements EntityVillager.ITradeList {
|
||||||
|
public ItemStack itemToBuy;
|
19
patches/minecraft/net/minecraft/init/Bootstrap.java.patch
Normal file
19
patches/minecraft/net/minecraft/init/Bootstrap.java.patch
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
--- a/net/minecraft/init/Bootstrap.java
|
||||||
|
+++ b/net/minecraft/init/Bootstrap.java
|
||||||
|
@@ -75,6 +75,8 @@
|
||||||
|
import net.minecraft.world.biome.Biome;
|
||||||
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
+import net.minecraftforge.registries.ForgeRegistries;
|
||||||
|
+
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
|
@@ -421,6 +423,7 @@
|
||||||
|
|
||||||
|
redirectOutputToLog();
|
||||||
|
}
|
||||||
|
+ ForgeRegistries.ITEMS.getClass(); // TODO figure out a better way to ensure this is initialized
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -9,7 +9,13 @@
|
||||||
private World world;
|
private World world;
|
||||||
private final List<VillageDoorInfo> villageDoorInfoList = Lists.<VillageDoorInfo>newArrayList();
|
private final List<VillageDoorInfo> villageDoorInfoList = Lists.<VillageDoorInfo>newArrayList();
|
||||||
private BlockPos centerHelper = BlockPos.ORIGIN;
|
private BlockPos centerHelper = BlockPos.ORIGIN;
|
||||||
@@ -45,10 +45,12 @@
|
@@ -40,15 +40,17 @@
|
||||||
|
private int tickCounter;
|
||||||
|
private int numVillagers;
|
||||||
|
private int noBreedTicks;
|
||||||
|
- private final Map<String, Integer> playerReputation = Maps.<String, Integer>newHashMap();
|
||||||
|
+ private final Map<UUID, Integer> playerReputation = Maps.<UUID, Integer>newHashMap();
|
||||||
|
private final List<Village.VillageAggressor> villageAgressors = Lists.<Village.VillageAggressor>newArrayList();
|
||||||
private int numIronGolems;
|
private int numIronGolems;
|
||||||
|
|
||||||
public Village() {
|
public Village() {
|
||||||
|
@ -22,8 +28,83 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setWorld(World worldIn) {
|
public void setWorld(World worldIn) {
|
||||||
@@ -364,7 +366,7 @@
|
@@ -237,9 +239,9 @@
|
||||||
this.playerReputation.put(nbttagcompound1.getString("Name"), nbttagcompound1.getInteger("S"));
|
double d0 = Double.MAX_VALUE;
|
||||||
|
EntityPlayer entityplayer = null;
|
||||||
|
|
||||||
|
- for(String s : this.playerReputation.keySet()) {
|
||||||
|
+ for(UUID s : this.playerReputation.keySet()) {
|
||||||
|
if (this.isPlayerReputationTooLow(s)) {
|
||||||
|
- EntityPlayer entityplayer1 = this.world.getPlayerEntityByName(s);
|
||||||
|
+ EntityPlayer entityplayer1 = this.world.getPlayerEntityByUUID(s);
|
||||||
|
if (entityplayer1 != null) {
|
||||||
|
double d1 = entityplayer1.getDistanceSq(villageDefender);
|
||||||
|
if (!(d1 > d0)) {
|
||||||
|
@@ -317,12 +319,32 @@
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+ @Deprecated //Hasn't worked since 1.9, use UUID version below.
|
||||||
|
public int getPlayerReputation(String playerName) {
|
||||||
|
+ return this.getPlayerReputation(findUUID(playerName));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public int getPlayerReputation(UUID playerName)
|
||||||
|
+ {
|
||||||
|
Integer integer = this.playerReputation.get(playerName);
|
||||||
|
return integer == null ? 0 : integer;
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ private UUID findUUID(String name)
|
||||||
|
+ {
|
||||||
|
+ if (this.world == null || this.world.getMinecraftServer() == null)
|
||||||
|
+ return EntityPlayer.getOfflineUUID(name);
|
||||||
|
+ GameProfile profile = this.world.getMinecraftServer().getPlayerProfileCache().getGameProfileForUsername(name);
|
||||||
|
+ return profile == null ? EntityPlayer.getOfflineUUID(name) : profile.getId();
|
||||||
|
+ }
|
||||||
|
|
||||||
|
+ @Deprecated //Hasn't worked since 1.9, use UUID version below.
|
||||||
|
public int modifyPlayerReputation(String playerName, int reputation) {
|
||||||
|
+ return this.modifyPlayerReputation(findUUID(playerName), reputation);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public int modifyPlayerReputation(UUID playerName, int reputation)
|
||||||
|
+ {
|
||||||
|
int i = this.getPlayerReputation(playerName);
|
||||||
|
int j = MathHelper.clamp(i + reputation, -30, 10);
|
||||||
|
this.playerReputation.put(playerName, j);
|
||||||
|
@@ -330,9 +352,14 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isPlayerReputationTooLow(String playerName) {
|
||||||
|
- return this.getPlayerReputation(playerName) <= -15;
|
||||||
|
+ return this.isPlayerReputationTooLow(findUUID(playerName));
|
||||||
|
}
|
||||||
|
|
||||||
|
+ public boolean isPlayerReputationTooLow(UUID uuid)
|
||||||
|
+ {
|
||||||
|
+ return this.getPlayerReputation(uuid) <= -15;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
public void readVillageDataFromNBT(NBTTagCompound compound) {
|
||||||
|
this.numVillagers = compound.getInteger("PopSize");
|
||||||
|
this.villageRadius = compound.getInteger("Radius");
|
||||||
|
@@ -354,17 +381,14 @@
|
||||||
|
|
||||||
|
for(int j = 0; j < nbttaglist1.size(); ++j) {
|
||||||
|
NBTTagCompound nbttagcompound1 = nbttaglist1.getCompoundTagAt(j);
|
||||||
|
- if (nbttagcompound1.hasKey("UUID") && this.world != null && this.world.getMinecraftServer() != null) {
|
||||||
|
- PlayerProfileCache playerprofilecache = this.world.getMinecraftServer().getPlayerProfileCache();
|
||||||
|
- GameProfile gameprofile = playerprofilecache.getProfileByUUID(UUID.fromString(nbttagcompound1.getString("UUID")));
|
||||||
|
- if (gameprofile != null) {
|
||||||
|
- this.playerReputation.put(gameprofile.getName(), nbttagcompound1.getInteger("S"));
|
||||||
|
- }
|
||||||
|
+ if (nbttagcompound1.hasKey("UUID")) {
|
||||||
|
+ this.playerReputation.put(UUID.fromString(nbttagcompound1.getString("UUID")), Integer.valueOf(nbttagcompound1.getInteger("S")));
|
||||||
|
} else {
|
||||||
|
- this.playerReputation.put(nbttagcompound1.getString("Name"), nbttagcompound1.getInteger("S"));
|
||||||
|
+ //World is never set here, so this will always be offline UUIDs, sadly there is no way to convert this.
|
||||||
|
+ this.playerReputation.put(findUUID(nbttagcompound1.getString("Name")), Integer.valueOf(nbttagcompound1.getInteger("S")));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
-
|
-
|
||||||
|
@ -31,7 +112,25 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeVillageDataToNBT(NBTTagCompound compound) {
|
public void writeVillageDataToNBT(NBTTagCompound compound) {
|
||||||
@@ -413,6 +415,8 @@
|
@@ -396,14 +420,12 @@
|
||||||
|
compound.setTag("Doors", nbttaglist);
|
||||||
|
NBTTagList nbttaglist1 = new NBTTagList();
|
||||||
|
|
||||||
|
- for(String s : this.playerReputation.keySet()) {
|
||||||
|
+ for(UUID s : this.playerReputation.keySet()) {
|
||||||
|
NBTTagCompound nbttagcompound1 = new NBTTagCompound();
|
||||||
|
- PlayerProfileCache playerprofilecache = this.world.getMinecraftServer().getPlayerProfileCache();
|
||||||
|
|
||||||
|
try {
|
||||||
|
- GameProfile gameprofile = playerprofilecache.getGameProfileForUsername(s);
|
||||||
|
- if (gameprofile != null) {
|
||||||
|
- nbttagcompound1.setString("UUID", gameprofile.getId().toString());
|
||||||
|
+ {
|
||||||
|
+ nbttagcompound1.setString("UUID", s.toString());
|
||||||
|
nbttagcompound1.setInteger("S", this.playerReputation.get(s));
|
||||||
|
nbttaglist1.add((INBTBase)nbttagcompound1);
|
||||||
|
}
|
||||||
|
@@ -413,6 +435,8 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
compound.setTag("Players", nbttaglist1);
|
compound.setTag("Players", nbttaglist1);
|
||||||
|
@ -40,3 +139,12 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void endMatingSeason() {
|
public void endMatingSeason() {
|
||||||
|
@@ -424,7 +448,7 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDefaultPlayerReputation(int defaultReputation) {
|
||||||
|
- for(String s : this.playerReputation.keySet()) {
|
||||||
|
+ for(UUID s : this.playerReputation.keySet()) {
|
||||||
|
this.modifyPlayerReputation(s, defaultReputation);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
public static final float[] MOON_PHASE_FACTORS = new float[]{1.0F, 0.75F, 0.5F, 0.25F, 0.0F, 0.25F, 0.5F, 0.75F};
|
public static final float[] MOON_PHASE_FACTORS = new float[]{1.0F, 0.75F, 0.5F, 0.25F, 0.0F, 0.25F, 0.5F, 0.75F};
|
||||||
protected World world;
|
protected World world;
|
||||||
protected boolean doesWaterVaporize;
|
protected boolean doesWaterVaporize;
|
||||||
@@ -141,4 +141,54 @@
|
@@ -141,4 +141,67 @@
|
||||||
public abstract boolean doesXZShowFog(int x, int z);
|
public abstract boolean doesXZShowFog(int x, int z);
|
||||||
|
|
||||||
public abstract DimensionType getDimensionType();
|
public abstract DimensionType getDimensionType();
|
||||||
|
@ -18,6 +18,19 @@
|
||||||
+ private net.minecraftforge.client.IRenderHandler skyRenderer = null;
|
+ private net.minecraftforge.client.IRenderHandler skyRenderer = null;
|
||||||
+ private net.minecraftforge.client.IRenderHandler cloudRenderer = null;
|
+ private net.minecraftforge.client.IRenderHandler cloudRenderer = null;
|
||||||
+ private net.minecraftforge.client.IRenderHandler weatherRenderer = null;
|
+ private net.minecraftforge.client.IRenderHandler weatherRenderer = null;
|
||||||
|
+ private int dimensionId;
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public void setId(int id)
|
||||||
|
+ {
|
||||||
|
+ this.dimensionId = id;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ @Override
|
||||||
|
+ public int getId()
|
||||||
|
+ {
|
||||||
|
+ return this.dimensionId;
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ @Nullable
|
+ @Nullable
|
||||||
+ @OnlyIn(Dist.CLIENT)
|
+ @OnlyIn(Dist.CLIENT)
|
||||||
|
|
|
@ -48,13 +48,12 @@ import com.google.common.collect.Multiset;
|
||||||
|
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.server.MinecraftServer;
|
import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraft.world.DimensionType;
|
|
||||||
import net.minecraft.world.MinecraftException;
|
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraft.world.ServerWorldEventHandler;
|
import net.minecraft.world.ServerWorldEventHandler;
|
||||||
import net.minecraft.world.WorldProvider;
|
|
||||||
import net.minecraft.world.WorldServer;
|
import net.minecraft.world.WorldServer;
|
||||||
import net.minecraft.world.WorldServerMulti;
|
import net.minecraft.world.WorldServerMulti;
|
||||||
|
import net.minecraft.world.dimension.Dimension;
|
||||||
|
import net.minecraft.world.dimension.DimensionType;
|
||||||
import net.minecraft.world.storage.ISaveHandler;
|
import net.minecraft.world.storage.ISaveHandler;
|
||||||
import net.minecraftforge.event.world.WorldEvent;
|
import net.minecraftforge.event.world.WorldEvent;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
@ -68,11 +67,11 @@ public class DimensionManager
|
||||||
{
|
{
|
||||||
private static final Logger LOGGER = LogManager.getLogger();
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
private static final Marker DIMMGR = MarkerManager.getMarker("DIMS");
|
private static final Marker DIMMGR = MarkerManager.getMarker("DIMS");
|
||||||
private static class Dimension
|
private static class DimensionData
|
||||||
{
|
{
|
||||||
private final DimensionType type;
|
private final DimensionType type;
|
||||||
private int ticksWaited;
|
private int ticksWaited;
|
||||||
private Dimension(DimensionType type)
|
private DimensionData(DimensionType type)
|
||||||
{
|
{
|
||||||
this.type = type;
|
this.type = type;
|
||||||
this.ticksWaited = 0;
|
this.ticksWaited = 0;
|
||||||
|
@ -82,7 +81,7 @@ public class DimensionManager
|
||||||
private static boolean hasInit = false;
|
private static boolean hasInit = false;
|
||||||
|
|
||||||
private static final Int2ObjectMap<WorldServer> worlds = Int2ObjectMaps.synchronize(new Int2ObjectLinkedOpenHashMap<>());
|
private static final Int2ObjectMap<WorldServer> worlds = Int2ObjectMaps.synchronize(new Int2ObjectLinkedOpenHashMap<>());
|
||||||
private static final Int2ObjectMap<Dimension> dimensions = Int2ObjectMaps.synchronize(new Int2ObjectLinkedOpenHashMap<>());
|
private static final Int2ObjectMap<DimensionData> dimensions = Int2ObjectMaps.synchronize(new Int2ObjectLinkedOpenHashMap<>());
|
||||||
private static final IntSet keepLoaded = IntSets.synchronize(new IntOpenHashSet());
|
private static final IntSet keepLoaded = IntSets.synchronize(new IntOpenHashSet());
|
||||||
private static final IntSet unloadQueue = IntSets.synchronize(new IntLinkedOpenHashSet());
|
private static final IntSet unloadQueue = IntSets.synchronize(new IntLinkedOpenHashSet());
|
||||||
private static final BitSet dimensionMap = new BitSet(Long.SIZE << 4);
|
private static final BitSet dimensionMap = new BitSet(Long.SIZE << 4);
|
||||||
|
@ -96,7 +95,7 @@ public class DimensionManager
|
||||||
{
|
{
|
||||||
int[] ret = new int[dimensions.size()];
|
int[] ret = new int[dimensions.size()];
|
||||||
int x = 0;
|
int x = 0;
|
||||||
for (Int2ObjectMap.Entry<Dimension> ent : dimensions.int2ObjectEntrySet())
|
for (Int2ObjectMap.Entry<DimensionData> ent : dimensions.int2ObjectEntrySet())
|
||||||
{
|
{
|
||||||
if (ent.getValue().type == type)
|
if (ent.getValue().type == type)
|
||||||
{
|
{
|
||||||
|
@ -110,7 +109,7 @@ public class DimensionManager
|
||||||
public static Map<DimensionType, IntSortedSet> getRegisteredDimensions()
|
public static Map<DimensionType, IntSortedSet> getRegisteredDimensions()
|
||||||
{
|
{
|
||||||
Map<DimensionType, IntSortedSet> map = new IdentityHashMap<>();
|
Map<DimensionType, IntSortedSet> map = new IdentityHashMap<>();
|
||||||
for (Int2ObjectMap.Entry<Dimension> entry : dimensions.int2ObjectEntrySet())
|
for (Int2ObjectMap.Entry<DimensionData> entry : dimensions.int2ObjectEntrySet())
|
||||||
{
|
{
|
||||||
map.computeIfAbsent(entry.getValue().type, k -> new IntRBTreeSet()).add(entry.getIntKey());
|
map.computeIfAbsent(entry.getValue().type, k -> new IntRBTreeSet()).add(entry.getIntKey());
|
||||||
}
|
}
|
||||||
|
@ -138,7 +137,7 @@ public class DimensionManager
|
||||||
{
|
{
|
||||||
throw new IllegalArgumentException(String.format("Failed to register dimension for id %d, One is already registered", id));
|
throw new IllegalArgumentException(String.format("Failed to register dimension for id %d, One is already registered", id));
|
||||||
}
|
}
|
||||||
dimensions.put(id, new Dimension(type));
|
dimensions.put(id, new DimensionData(type));
|
||||||
if (id >= 0)
|
if (id >= 0)
|
||||||
{
|
{
|
||||||
dimensionMap.set(id);
|
dimensionMap.set(id);
|
||||||
|
@ -171,7 +170,7 @@ public class DimensionManager
|
||||||
return dimensions.get(dim).type;
|
return dimensions.get(dim).type;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static WorldProvider getProvider(int dim)
|
public static Dimension getProvider(int dim)
|
||||||
{
|
{
|
||||||
return getWorld(dim).provider;
|
return getWorld(dim).provider;
|
||||||
}
|
}
|
||||||
|
@ -309,14 +308,14 @@ public class DimensionManager
|
||||||
return dimensions.keySet().toArray(new Integer[0]);
|
return dimensions.keySet().toArray(new Integer[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static WorldProvider createProviderFor(int dim)
|
public static Dimension createProviderFor(int dim)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (dimensions.containsKey(dim))
|
if (dimensions.containsKey(dim))
|
||||||
{
|
{
|
||||||
WorldProvider ret = getProviderType(dim).createDimension();
|
Dimension ret = getProviderType(dim).createDimension();
|
||||||
ret.setDimension(dim);
|
ret.setId(dim);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -348,7 +347,7 @@ public class DimensionManager
|
||||||
return ForgeChunkManager.getPersistentChunksFor(world).isEmpty()
|
return ForgeChunkManager.getPersistentChunksFor(world).isEmpty()
|
||||||
&& world.playerEntities.isEmpty()
|
&& world.playerEntities.isEmpty()
|
||||||
&& !world.provider.getDimensionType().shouldLoadSpawn()
|
&& !world.provider.getDimensionType().shouldLoadSpawn()
|
||||||
&& !keepLoaded.contains(world.provider.getDimension());
|
&& !keepLoaded.contains(world.provider.getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -380,7 +379,7 @@ public class DimensionManager
|
||||||
while (queueIterator.hasNext())
|
while (queueIterator.hasNext())
|
||||||
{
|
{
|
||||||
int id = queueIterator.nextInt();
|
int id = queueIterator.nextInt();
|
||||||
Dimension dimension = dimensions.get(id);
|
DimensionData dimension = dimensions.get(id);
|
||||||
if (dimension.ticksWaited < ForgeMod.dimensionUnloadQueueDelay)
|
if (dimension.ticksWaited < ForgeMod.dimensionUnloadQueueDelay)
|
||||||
{
|
{
|
||||||
dimension.ticksWaited++;
|
dimension.ticksWaited++;
|
||||||
|
|
|
@ -110,7 +110,7 @@ import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraft.util.text.TextComponentString;
|
import net.minecraft.util.text.TextComponentString;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraft.util.text.event.ClickEvent;
|
import net.minecraft.util.text.event.ClickEvent;
|
||||||
import net.minecraft.world.IBlockAccess;
|
import net.minecraft.world.IWorldReader;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraft.world.EnumDifficulty;
|
import net.minecraft.world.EnumDifficulty;
|
||||||
import net.minecraft.world.GameType;
|
import net.minecraft.world.GameType;
|
||||||
|
@ -209,7 +209,7 @@ public class ForgeHooks
|
||||||
private static boolean toolInit = false;
|
private static boolean toolInit = false;
|
||||||
//static HashSet<List> toolEffectiveness = new HashSet<List>();
|
//static HashSet<List> toolEffectiveness = new HashSet<List>();
|
||||||
|
|
||||||
public static boolean canHarvestBlock(@Nonnull Block block, @Nonnull EntityPlayer player, @Nonnull IBlockAccess world, @Nonnull BlockPos pos)
|
public static boolean canHarvestBlock(@Nonnull Block block, @Nonnull EntityPlayer player, @Nonnull IWorldReader world, @Nonnull BlockPos pos)
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState(pos);
|
IBlockState state = world.getBlockState(pos);
|
||||||
state = state.getBlock().getActualState(state, world, pos);
|
state = state.getBlock().getActualState(state, world, pos);
|
||||||
|
@ -234,7 +234,7 @@ public class ForgeHooks
|
||||||
return toolLevel >= block.getHarvestLevel(state);
|
return toolLevel >= block.getHarvestLevel(state);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean canToolHarvestBlock(IBlockAccess world, BlockPos pos, @Nonnull ItemStack stack)
|
public static boolean canToolHarvestBlock(IWorldReader world, BlockPos pos, @Nonnull ItemStack stack)
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState(pos);
|
IBlockState state = world.getBlockState(pos);
|
||||||
state = state.getBlock().getActualState(state, world, pos);
|
state = state.getBlock().getActualState(state, world, pos);
|
||||||
|
@ -261,7 +261,7 @@ public class ForgeHooks
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isToolEffective(IBlockAccess world, BlockPos pos, @Nonnull ItemStack stack)
|
public static boolean isToolEffective(IWorldReader world, BlockPos pos, @Nonnull ItemStack stack)
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState(pos);
|
IBlockState state = world.getBlockState(pos);
|
||||||
state = state.getBlock().getActualState(state, world, pos);
|
state = state.getBlock().getActualState(state, world, pos);
|
||||||
|
|
|
@ -105,7 +105,7 @@ public class ForgeModContainer extends FMLModContainer
|
||||||
ConfigCategory GENERAL = config.getCategory(CATEGORY_GENERAL);
|
ConfigCategory GENERAL = config.getCategory(CATEGORY_GENERAL);
|
||||||
if (GENERAL.containsKey(key))
|
if (GENERAL.containsKey(key))
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Remapping property {} from category general to client", key);
|
LOGGER.debug("Remapping property {} from category general to client", key);
|
||||||
Property property = GENERAL.get(key);
|
Property property = GENERAL.get(key);
|
||||||
GENERAL.remove(key);
|
GENERAL.remove(key);
|
||||||
config.getCategory(CATEGORY_CLIENT).put(key, property);
|
config.getCategory(CATEGORY_CLIENT).put(key, property);
|
||||||
|
@ -182,7 +182,7 @@ public class ForgeModContainer extends FMLModContainer
|
||||||
|
|
||||||
if (removeErroringEntities)
|
if (removeErroringEntities)
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("Enabling removal of erroring Entities - USE AT YOUR OWN RISK");
|
LOGGER.warn("Enabling removal of erroring Entities - USE AT YOUR OWN RISK");
|
||||||
}
|
}
|
||||||
|
|
||||||
prop = config.get(Configuration.CATEGORY_GENERAL, "removeErroringTileEntities", false);
|
prop = config.get(Configuration.CATEGORY_GENERAL, "removeErroringTileEntities", false);
|
||||||
|
@ -193,7 +193,7 @@ public class ForgeModContainer extends FMLModContainer
|
||||||
|
|
||||||
if (removeErroringTileEntities)
|
if (removeErroringTileEntities)
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("Enabling removal of erroring Tile Entities - USE AT YOUR OWN RISK");
|
LOGGER.warn("Enabling removal of erroring Tile Entities - USE AT YOUR OWN RISK");
|
||||||
}
|
}
|
||||||
|
|
||||||
prop = config.get(Configuration.CATEGORY_GENERAL, "fullBoundingBoxLadders", false);
|
prop = config.get(Configuration.CATEGORY_GENERAL, "fullBoundingBoxLadders", false);
|
||||||
|
|
|
@ -21,10 +21,10 @@ package net.minecraftforge.common;
|
||||||
|
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.IBlockAccess;
|
import net.minecraft.world.IWorldReader;
|
||||||
|
|
||||||
public interface IPlantable
|
public interface IPlantable
|
||||||
{
|
{
|
||||||
EnumPlantType getPlantType(IBlockAccess world, BlockPos pos);
|
EnumPlantType getPlantType(IWorldReader world, BlockPos pos);
|
||||||
IBlockState getPlant(IBlockAccess world, BlockPos pos);
|
IBlockState getPlant(IWorldReader world, BlockPos pos);
|
||||||
}
|
}
|
|
@ -23,7 +23,7 @@ import java.util.List;
|
||||||
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.IBlockAccess;
|
import net.minecraft.world.IWorldReader;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ import javax.annotation.Nonnull;
|
||||||
* to support mod-shears as well.
|
* to support mod-shears as well.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
//TODO Change to World, not IBlockAccess and make Implementor responsible for removing itself from the world.
|
//TODO Change to World, not IWorldReader and make Implementor responsible for removing itself from the world.
|
||||||
//Better mimics vanilla behavior and allows more control for the user.
|
//Better mimics vanilla behavior and allows more control for the user.
|
||||||
public interface IShearable
|
public interface IShearable
|
||||||
{
|
{
|
||||||
|
@ -48,7 +48,7 @@ public interface IShearable
|
||||||
* @param pos Block's position in world.
|
* @param pos Block's position in world.
|
||||||
* @return If this is shearable, and onSheared should be called.
|
* @return If this is shearable, and onSheared should be called.
|
||||||
*/
|
*/
|
||||||
boolean isShearable(@Nonnull ItemStack item, IBlockAccess world, BlockPos pos);
|
boolean isShearable(@Nonnull ItemStack item, IWorldReader world, BlockPos pos);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Performs the shear function on this object.
|
* Performs the shear function on this object.
|
||||||
|
@ -69,5 +69,5 @@ public interface IShearable
|
||||||
* @return A List containing all items from this shearing. May be empty.
|
* @return A List containing all items from this shearing. May be empty.
|
||||||
*/
|
*/
|
||||||
@Nonnull
|
@Nonnull
|
||||||
List<ItemStack> onSheared(@Nonnull ItemStack item, IBlockAccess world, BlockPos pos, int fortune);
|
List<ItemStack> onSheared(@Nonnull ItemStack item, IWorldReader world, BlockPos pos, int fortune);
|
||||||
}
|
}
|
||||||
|
|
|
@ -121,7 +121,7 @@ public class MinecraftForge
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Could not find class for name '{}'.", name, e);
|
LOGGER.error("Could not find class for name '{}'.", name, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,8 @@ import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.apache.logging.log4j.Level;
|
import org.apache.logging.log4j.Level;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import com.google.common.io.Files;
|
import com.google.common.io.Files;
|
||||||
import com.mojang.datafixers.DataFixer;
|
import com.mojang.datafixers.DataFixer;
|
||||||
|
@ -40,6 +42,8 @@ import net.minecraft.world.WorldServer;
|
||||||
|
|
||||||
public class WorldSpecificSaveHandler implements ISaveHandler
|
public class WorldSpecificSaveHandler implements ISaveHandler
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private WorldServer world;
|
private WorldServer world;
|
||||||
private ISaveHandler parent;
|
private ISaveHandler parent;
|
||||||
private File dataDir;
|
private File dataDir;
|
||||||
|
@ -95,7 +99,7 @@ public class WorldSpecificSaveHandler implements ISaveHandler
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("A critical error occurred copying {} to world specific dat folder - new file will be created.", parentFile.getName(), e);
|
LOGGER.error("A critical error occurred copying {} to world specific dat folder - new file will be created.", parentFile.getName(), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,6 +67,11 @@ public class OptionalCapabilityInstance<T>
|
||||||
return instanceSupplier == null ? EMPTY.cast() : new OptionalCapabilityInstance<>(instanceSupplier);
|
return instanceSupplier == null ? EMPTY.cast() : new OptionalCapabilityInstance<>(instanceSupplier);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static <T, R> OptionalCapabilityInstance<R> orEmpty(Capability<R> cap, Capability<T> toCheck, OptionalCapabilityInstance<T> inst)
|
||||||
|
{
|
||||||
|
return cap == toCheck ? inst.cast() : EMPTY.cast();
|
||||||
|
}
|
||||||
|
|
||||||
private @Nullable T getValue()
|
private @Nullable T getValue()
|
||||||
{
|
{
|
||||||
if (!isValid)
|
if (!isValid)
|
||||||
|
|
|
@ -27,16 +27,20 @@ import java.util.concurrent.ThreadPoolExecutor;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
import com.google.common.collect.Maps;
|
||||||
|
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraft.world.chunk.Chunk;
|
import net.minecraft.world.chunk.Chunk;
|
||||||
import net.minecraft.world.chunk.storage.AnvilChunkLoader;
|
import net.minecraft.world.chunk.storage.AnvilChunkLoader;
|
||||||
import net.minecraft.world.gen.ChunkProviderServer;
|
import net.minecraft.world.gen.ChunkProviderServer;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
public class ChunkIOExecutor
|
public class ChunkIOExecutor
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private static final int BASE_THREADS = 1;
|
private static final int BASE_THREADS = 1;
|
||||||
private static final int PLAYERS_PER_THREAD = 50;
|
private static final int PLAYERS_PER_THREAD = 50;
|
||||||
|
|
||||||
|
@ -120,7 +124,7 @@ public class ChunkIOExecutor
|
||||||
ChunkIOProvider task = tasks.get(key);
|
ChunkIOProvider task = tasks.get(key);
|
||||||
if (task == null)
|
if (task == null)
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("Attempted to dequeue chunk that wasn't queued? {} @ ({}, {})", world.provider.getDimension(), x, z);
|
LOGGER.warn("Attempted to dequeue chunk that wasn't queued? {} @ ({}, {})", world.provider.getId(), x, z);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -65,14 +65,14 @@ class ChunkIOProvider implements Runnable
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Object[] data = null;
|
Object[] data = null;
|
||||||
try
|
/*try
|
||||||
{
|
{ TODO Chunk loading
|
||||||
data = this.loader.loadChunk__Async(chunkInfo.world, chunkInfo.x, chunkInfo.z);
|
data = this.loader.loadChunk__Async(chunkInfo.world, chunkInfo.x, chunkInfo.z);
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
throw new RuntimeException(e); // Allow exception to bubble up to afterExecute
|
throw new RuntimeException(e); // Allow exception to bubble up to afterExecute
|
||||||
}
|
}*/
|
||||||
|
|
||||||
if (data != null)
|
if (data != null)
|
||||||
{
|
{
|
||||||
|
@ -97,7 +97,7 @@ class ChunkIOProvider implements Runnable
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load Entities
|
/*/ Load Entities TODO Chunk loading
|
||||||
this.loader.loadEntities(this.chunkInfo.world, this.nbt.getCompoundTag("Level"), this.chunk);
|
this.loader.loadEntities(this.chunkInfo.world, this.nbt.getCompoundTag("Level"), this.chunk);
|
||||||
|
|
||||||
MinecraftForge.EVENT_BUS.post(new ChunkDataEvent.Load(this.chunk, this.nbt)); // Don't call ChunkDataEvent.Load async
|
MinecraftForge.EVENT_BUS.post(new ChunkDataEvent.Load(this.chunk, this.nbt)); // Don't call ChunkDataEvent.Load async
|
||||||
|
@ -108,7 +108,7 @@ class ChunkIOProvider implements Runnable
|
||||||
provider.id2ChunkMap.put(ChunkPos.asLong(this.chunkInfo.x, this.chunkInfo.z), this.chunk);
|
provider.id2ChunkMap.put(ChunkPos.asLong(this.chunkInfo.x, this.chunkInfo.z), this.chunk);
|
||||||
this.chunk.onLoad();
|
this.chunk.onLoad();
|
||||||
this.chunk.populate(provider, provider.chunkGenerator);
|
this.chunk.populate(provider, provider.chunkGenerator);
|
||||||
|
*/
|
||||||
this.runCallbacks();
|
this.runCallbacks();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,10 +24,13 @@ import java.util.concurrent.ThreadFactory;
|
||||||
import java.util.concurrent.ThreadPoolExecutor;
|
import java.util.concurrent.ThreadPoolExecutor;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import net.minecraft.crash.CrashReportCategory;
|
import net.minecraft.crash.CrashReportCategory;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
class ChunkIOThreadPoolExecutor extends ThreadPoolExecutor {
|
class ChunkIOThreadPoolExecutor extends ThreadPoolExecutor {
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
public ChunkIOThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory)
|
public ChunkIOThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory)
|
||||||
{
|
{
|
||||||
|
@ -41,14 +44,14 @@ class ChunkIOThreadPoolExecutor extends ThreadPoolExecutor {
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unhandled exception loading chunk:", t);
|
LOGGER.error("Unhandled exception loading chunk:", t);
|
||||||
QueuedChunk queuedChunk = ((ChunkIOProvider) r).getChunkInfo();
|
QueuedChunk queuedChunk = ((ChunkIOProvider) r).getChunkInfo();
|
||||||
FMLLog.log.error(queuedChunk);
|
LOGGER.error(queuedChunk);
|
||||||
FMLLog.log.error(CrashReportCategory.getCoordinateInfo(queuedChunk.x << 4, 64, queuedChunk.z << 4));
|
LOGGER.error(CrashReportCategory.getCoordinateInfo(queuedChunk.x << 4, 64, queuedChunk.z << 4));
|
||||||
}
|
}
|
||||||
catch (Throwable t2)
|
catch (Throwable t2)
|
||||||
{
|
{
|
||||||
FMLLog.log.error(t2);
|
LOGGER.error(t2);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
|
|
@ -57,7 +57,7 @@ class QueuedChunk {
|
||||||
result.append(" x: " + x + NEW_LINE);
|
result.append(" x: " + x + NEW_LINE);
|
||||||
result.append(" z: " + z + NEW_LINE);
|
result.append(" z: " + z + NEW_LINE);
|
||||||
result.append(" world: " + world.getWorldInfo().getWorldName() + NEW_LINE);
|
result.append(" world: " + world.getWorldInfo().getWorldName() + NEW_LINE);
|
||||||
result.append(" dimension: " + world.provider.getDimension() + NEW_LINE);
|
result.append(" dimension: " + world.provider.getId() + NEW_LINE);
|
||||||
result.append(" provider: " + world.provider.getClass().getName() + NEW_LINE);
|
result.append(" provider: " + world.provider.getClass().getName() + NEW_LINE);
|
||||||
result.append("}");
|
result.append("}");
|
||||||
|
|
||||||
|
|
|
@ -36,16 +36,19 @@ import com.google.common.collect.Sets;
|
||||||
import net.minecraftforge.common.config.Config.Comment;
|
import net.minecraftforge.common.config.Config.Comment;
|
||||||
import net.minecraftforge.common.config.Config.LangKey;
|
import net.minecraftforge.common.config.Config.LangKey;
|
||||||
import net.minecraftforge.common.config.Config.Name;
|
import net.minecraftforge.common.config.Config.Name;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.fml.common.FMLPaths;
|
import net.minecraftforge.fml.common.FMLPaths;
|
||||||
import net.minecraftforge.fml.common.Loader;
|
import net.minecraftforge.fml.common.Loader;
|
||||||
import net.minecraftforge.fml.common.LoaderException;
|
import net.minecraftforge.fml.common.LoaderException;
|
||||||
import net.minecraftforge.fml.loading.moddiscovery.ModAnnotation.EnumHolder;
|
import net.minecraftforge.fml.loading.moddiscovery.ModAnnotation.EnumHolder;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
public class ConfigManager
|
public class ConfigManager
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private static Map<String, Multimap<Config.Type, ASMData>> asm_data = Maps.newHashMap();
|
private static Map<String, Multimap<Config.Type, ASMData>> asm_data = Maps.newHashMap();
|
||||||
static Map<Class<?>, ITypeAdapter> ADAPTERS = Maps.newHashMap();
|
static Map<Class<?>, ITypeAdapter> ADAPTERS = Maps.newHashMap();
|
||||||
static Map<Class<?>, Class<?>> ARRAY_REMAP = Maps.newHashMap();
|
static Map<Class<?>, Class<?>> ARRAY_REMAP = Maps.newHashMap();
|
||||||
|
@ -102,7 +105,7 @@ public class ConfigManager
|
||||||
|
|
||||||
public static void loadData(ASMDataTable data)
|
public static void loadData(ASMDataTable data)
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Loading @Config anotation data");
|
LOGGER.debug("Loading @Config anotation data");
|
||||||
for (ASMData target : data.getAll(Config.class.getName()))
|
for (ASMData target : data.getAll(Config.class.getName()))
|
||||||
{
|
{
|
||||||
String modid = (String)target.getAnnotationInfo().get("modid");
|
String modid = (String)target.getAnnotationInfo().get("modid");
|
||||||
|
@ -143,7 +146,7 @@ public class ConfigManager
|
||||||
*/
|
*/
|
||||||
public static void sync(String modid, Config.Type type)
|
public static void sync(String modid, Config.Type type)
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Attempting to inject @Config classes into {} for type {}", modid, type);
|
LOGGER.debug("Attempting to inject @Config classes into {} for type {}", modid, type);
|
||||||
ClassLoader mcl = Loader.instance().getModClassLoader();
|
ClassLoader mcl = Loader.instance().getModClassLoader();
|
||||||
File configDir = FMLPaths.FMLCONFIG.get().toFile();
|
File configDir = FMLPaths.FMLCONFIG.get().toFile();
|
||||||
Multimap<Config.Type, ASMData> map = asm_data.get(modid);
|
Multimap<Config.Type, ASMData> map = asm_data.get(modid);
|
||||||
|
@ -186,7 +189,7 @@ public class ConfigManager
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("An error occurred trying to load a config for {} into {}", targ.getClassName(), e);
|
LOGGER.error("An error occurred trying to load a config for {} into {}", targ.getClassName(), e);
|
||||||
throw new LoaderException(e);
|
throw new LoaderException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,10 +55,11 @@ import net.minecraftforge.fml.client.config.GuiConfig;
|
||||||
import net.minecraftforge.fml.client.config.GuiConfigEntries;
|
import net.minecraftforge.fml.client.config.GuiConfigEntries;
|
||||||
import net.minecraftforge.fml.client.config.GuiConfigEntries.IConfigEntry;
|
import net.minecraftforge.fml.client.config.GuiConfigEntries.IConfigEntry;
|
||||||
import net.minecraftforge.fml.client.config.IConfigElement;
|
import net.minecraftforge.fml.client.config.IConfigElement;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.fml.common.FMLPaths;
|
import net.minecraftforge.fml.common.FMLPaths;
|
||||||
import net.minecraftforge.fml.common.Loader;
|
import net.minecraftforge.fml.common.Loader;
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class offers advanced configurations capabilities, allowing to provide
|
* This class offers advanced configurations capabilities, allowing to provide
|
||||||
|
@ -66,6 +67,8 @@ import org.apache.commons.io.IOUtils;
|
||||||
*/
|
*/
|
||||||
public class Configuration
|
public class Configuration
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
public static final String CATEGORY_GENERAL = "general";
|
public static final String CATEGORY_GENERAL = "general";
|
||||||
public static final String CATEGORY_CLIENT = "client";
|
public static final String CATEGORY_CLIENT = "client";
|
||||||
public static final String ALLOWED_CHARS = "._-";
|
public static final String ALLOWED_CHARS = "._-";
|
||||||
|
@ -132,7 +135,7 @@ public class Configuration
|
||||||
{
|
{
|
||||||
File fileBak = new File(file.getAbsolutePath() + "_" +
|
File fileBak = new File(file.getAbsolutePath() + "_" +
|
||||||
new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date()) + ".errored");
|
new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date()) + ".errored");
|
||||||
FMLLog.log.fatal("An exception occurred while loading config file {}. This file will be renamed to {} " +
|
LOGGER.fatal("An exception occurred while loading config file {}. This file will be renamed to {} " +
|
||||||
"and a new config file will be generated.", file.getName(), fileBak.getName(), e);
|
"and a new config file will be generated.", file.getName(), fileBak.getName(), e);
|
||||||
|
|
||||||
file.renameTo(fileBak);
|
file.renameTo(fileBak);
|
||||||
|
@ -1047,7 +1050,7 @@ public class Configuration
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error while loading config {}.", fileName, e);
|
LOGGER.error("Error while loading config {}.", fileName, e);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
@ -1108,7 +1111,7 @@ public class Configuration
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error while saving config {}.", fileName, e);
|
LOGGER.error("Error while saving config {}.", fileName, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1719,7 +1722,7 @@ public class Configuration
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Failed to get float for {}/{}", name, category, e);
|
LOGGER.error("Failed to get float for {}/{}", name, category, e);
|
||||||
}
|
}
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,17 @@ public interface IForgeDimension
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the providers current dimension ID, used in default getSaveFolder()
|
||||||
|
* Added to allow default providers to be registered for multiple dimensions.
|
||||||
|
* This is to denote the exact dimension ID opposed to the 'type' in WorldType
|
||||||
|
*
|
||||||
|
* @param id Dimension ID
|
||||||
|
*/
|
||||||
|
void setId(int id);
|
||||||
|
|
||||||
|
int getId();
|
||||||
|
|
||||||
@OnlyIn(Dist.CLIENT)
|
@OnlyIn(Dist.CLIENT)
|
||||||
@Nullable
|
@Nullable
|
||||||
IRenderHandler getSkyRenderer();
|
IRenderHandler getSkyRenderer();
|
||||||
|
|
|
@ -52,9 +52,10 @@ public class CapabilityAnimation
|
||||||
|
|
||||||
public static class DefaultItemAnimationCapabilityProvider implements ICapabilityProvider
|
public static class DefaultItemAnimationCapabilityProvider implements ICapabilityProvider
|
||||||
{
|
{
|
||||||
private final IAnimationStateMachine asm;
|
@Nonnull
|
||||||
|
private final OptionalCapabilityInstance<IAnimationStateMachine> asm;
|
||||||
|
|
||||||
public DefaultItemAnimationCapabilityProvider(IAnimationStateMachine asm)
|
public DefaultItemAnimationCapabilityProvider(@Nonnull OptionalCapabilityInstance<IAnimationStateMachine> asm)
|
||||||
{
|
{
|
||||||
this.asm = asm;
|
this.asm = asm;
|
||||||
}
|
}
|
||||||
|
@ -63,11 +64,7 @@ public class CapabilityAnimation
|
||||||
@Nonnull
|
@Nonnull
|
||||||
public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
||||||
{
|
{
|
||||||
if(capability == ANIMATION_CAPABILITY)
|
return OptionalCapabilityInstance.orEmpty(capability, ANIMATION_CAPABILITY, asm);
|
||||||
{
|
|
||||||
return OptionalCapabilityInstance.of(() -> asm).cast();
|
|
||||||
}
|
|
||||||
return OptionalCapabilityInstance.empty();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,13 +21,18 @@ package net.minecraftforge.common.network;
|
||||||
|
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
import io.netty.channel.SimpleChannelInboundHandler;
|
import io.netty.channel.SimpleChannelInboundHandler;
|
||||||
import net.minecraft.world.DimensionType;
|
import net.minecraft.world.dimension.DimensionType;
|
||||||
import net.minecraftforge.common.DimensionManager;
|
import net.minecraftforge.common.DimensionManager;
|
||||||
import net.minecraftforge.common.network.ForgeMessage.DimensionRegisterMessage;
|
import net.minecraftforge.common.network.ForgeMessage.DimensionRegisterMessage;
|
||||||
import org.apache.logging.log4j.Level;
|
import org.apache.logging.log4j.Level;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
public class DimensionMessageHandler extends SimpleChannelInboundHandler<ForgeMessage.DimensionRegisterMessage>{
|
public class DimensionMessageHandler extends SimpleChannelInboundHandler<ForgeMessage.DimensionRegisterMessage>{
|
||||||
|
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void channelRead0(ChannelHandlerContext ctx, DimensionRegisterMessage msg) throws Exception
|
protected void channelRead0(ChannelHandlerContext ctx, DimensionRegisterMessage msg) throws Exception
|
||||||
{
|
{
|
||||||
|
@ -39,7 +44,7 @@ public class DimensionMessageHandler extends SimpleChannelInboundHandler<ForgeMe
|
||||||
@Override
|
@Override
|
||||||
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception
|
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception
|
||||||
{
|
{
|
||||||
FMLLog.log.error("DimensionMessageHandler exception", cause);
|
LOGGER.error("DimensionMessageHandler exception", cause);
|
||||||
super.exceptionCaught(ctx, cause);
|
super.exceptionCaught(ctx, cause);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,12 +22,15 @@ package net.minecraftforge.common.network;
|
||||||
import net.minecraftforge.fluids.FluidRegistry;
|
import net.minecraftforge.fluids.FluidRegistry;
|
||||||
|
|
||||||
import org.apache.logging.log4j.Level;
|
import org.apache.logging.log4j.Level;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import io.netty.channel.ChannelHandlerContext;
|
import io.netty.channel.ChannelHandlerContext;
|
||||||
import io.netty.channel.SimpleChannelInboundHandler;
|
import io.netty.channel.SimpleChannelInboundHandler;
|
||||||
|
|
||||||
public class FluidIdRegistryMessageHandler extends SimpleChannelInboundHandler<ForgeMessage.FluidIdMapMessage> {
|
public class FluidIdRegistryMessageHandler extends SimpleChannelInboundHandler<ForgeMessage.FluidIdMapMessage> {
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void channelRead0(ChannelHandlerContext ctx, ForgeMessage.FluidIdMapMessage msg) throws Exception
|
protected void channelRead0(ChannelHandlerContext ctx, ForgeMessage.FluidIdMapMessage msg) throws Exception
|
||||||
{
|
{
|
||||||
|
@ -36,7 +39,7 @@ public class FluidIdRegistryMessageHandler extends SimpleChannelInboundHandler<F
|
||||||
@Override
|
@Override
|
||||||
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception
|
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception
|
||||||
{
|
{
|
||||||
FMLLog.log.error("FluidIdRegistryMessageHandler exception", cause);
|
LOGGER.error("FluidIdRegistryMessageHandler exception", cause);
|
||||||
super.exceptionCaught(ctx, cause);
|
super.exceptionCaught(ctx, cause);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,9 @@ import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import net.minecraftforge.fluids.Fluid;
|
import net.minecraftforge.fluids.Fluid;
|
||||||
import net.minecraftforge.fluids.FluidRegistry;
|
import net.minecraftforge.fluids.FluidRegistry;
|
||||||
|
|
||||||
|
@ -30,11 +33,12 @@ import com.google.common.collect.BiMap;
|
||||||
import com.google.common.collect.HashBiMap;
|
import com.google.common.collect.HashBiMap;
|
||||||
import com.google.common.collect.Sets;
|
import com.google.common.collect.Sets;
|
||||||
|
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.fml.common.network.ByteBufUtils;
|
import net.minecraftforge.fml.common.network.ByteBufUtils;
|
||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
|
|
||||||
public abstract class ForgeMessage {
|
public abstract class ForgeMessage {
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
public static class DimensionRegisterMessage extends ForgeMessage {
|
public static class DimensionRegisterMessage extends ForgeMessage {
|
||||||
/** The dimension ID to register on client */
|
/** The dimension ID to register on client */
|
||||||
int dimensionId;
|
int dimensionId;
|
||||||
|
@ -108,7 +112,7 @@ public abstract class ForgeMessage {
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.info("Legacy server message contains no default fluid list - there may be problems with fluids");
|
LOGGER.info("Legacy server message contains no default fluid list - there may be problems with fluids");
|
||||||
defaultFluids.clear();
|
defaultFluids.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,25 +21,32 @@ package net.minecraftforge.common.property;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
import java.util.function.Function;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import com.google.common.collect.ImmutableTable;
|
import com.google.common.collect.ImmutableTable;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.properties.IProperty;
|
import net.minecraft.block.state.BlockState;
|
||||||
import net.minecraft.block.state.BlockStateContainer;
|
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
|
import net.minecraft.state.AbstractStateHolder;
|
||||||
|
import net.minecraft.state.IProperty;
|
||||||
|
import net.minecraft.state.StateContainer;
|
||||||
|
|
||||||
public class ExtendedBlockState extends BlockStateContainer
|
public class ExtendedBlockState extends StateContainer<Block, IBlockState>
|
||||||
{
|
{
|
||||||
private final ImmutableSet<IUnlistedProperty<?>> unlistedProperties;
|
private final ImmutableSet<IUnlistedProperty<?>> unlistedProperties;
|
||||||
|
|
||||||
public ExtendedBlockState(Block blockIn, IProperty<?>[] properties, IUnlistedProperty<?>[] unlistedProperties)
|
public <A extends AbstractStateHolder<Block, IBlockState>> ExtendedBlockState(Block blockIn, StateContainer.IFactory<Block, IBlockState, ?> stateFactory, net.minecraft.state.IProperty<?>[] properties, IUnlistedProperty<?>[] unlistedProperties)
|
||||||
{
|
{
|
||||||
super(blockIn, properties, buildUnlistedMap(unlistedProperties));
|
super(blockIn, stateFactory, buildListedMap(properties));// TODO Unlisted properties?, buildUnlistedMap(unlistedProperties));
|
||||||
ImmutableSet.Builder<IUnlistedProperty<?>> builder = ImmutableSet.builder();
|
ImmutableSet.Builder<IUnlistedProperty<?>> builder = ImmutableSet.builder();
|
||||||
for(IUnlistedProperty<?> property : unlistedProperties)
|
for(IUnlistedProperty<?> property : unlistedProperties)
|
||||||
{
|
{
|
||||||
|
@ -53,6 +60,11 @@ public class ExtendedBlockState extends BlockStateContainer
|
||||||
return unlistedProperties;
|
return unlistedProperties;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static Map<String, IProperty<?>> buildListedMap(IProperty<?>[] properties)
|
||||||
|
{
|
||||||
|
return Arrays.stream(properties).collect(Collectors.toMap(IProperty::getName, Function.identity()));
|
||||||
|
}
|
||||||
|
|
||||||
private static ImmutableMap<IUnlistedProperty<?>, Optional<?>> buildUnlistedMap(IUnlistedProperty<?>[] unlistedProperties)
|
private static ImmutableMap<IUnlistedProperty<?>, Optional<?>> buildUnlistedMap(IUnlistedProperty<?>[] unlistedProperties)
|
||||||
{
|
{
|
||||||
ImmutableMap.Builder<IUnlistedProperty<?>, Optional<?>> builder = ImmutableMap.builder();
|
ImmutableMap.Builder<IUnlistedProperty<?>, Optional<?>> builder = ImmutableMap.builder();
|
||||||
|
|
|
@ -21,6 +21,9 @@ package net.minecraftforge.fluids;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import java.awt.Color;
|
import java.awt.Color;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
@ -34,8 +37,6 @@ import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.text.translation.I18n;
|
import net.minecraft.util.text.translation.I18n;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraft.world.WorldProvider;
|
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraft.item.EnumRarity;
|
import net.minecraft.item.EnumRarity;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -56,6 +57,8 @@ import net.minecraft.item.EnumRarity;
|
||||||
*/
|
*/
|
||||||
public class Fluid
|
public class Fluid
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
public static final int BUCKET_VOLUME = 1000;
|
public static final int BUCKET_VOLUME = 1000;
|
||||||
|
|
||||||
/** The unique identification name for this fluid. */
|
/** The unique identification name for this fluid. */
|
||||||
|
@ -189,7 +192,7 @@ public class Fluid
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("A mod has attempted to assign Block {} to the Fluid '{}' but this Fluid has already been linked to the Block {}. "
|
LOGGER.warn("A mod has attempted to assign Block {} to the Fluid '{}' but this Fluid has already been linked to the Block {}. "
|
||||||
+ "You may have duplicate Fluid Blocks as a result. It *may* be possible to configure your mods to avoid this.", block, fluidName, this.block);
|
+ "You may have duplicate Fluid Blocks as a result. It *may* be possible to configure your mods to avoid this.", block, fluidName, this.block);
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
|
|
|
@ -22,7 +22,6 @@ package net.minecraftforge.fluids;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraftforge.common.util.Constants;
|
import net.minecraftforge.common.util.Constants;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.registries.IRegistryDelegate;
|
import net.minecraftforge.registries.IRegistryDelegate;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
|
@ -40,8 +40,9 @@ public class ItemFluidContainer extends Item
|
||||||
/**
|
/**
|
||||||
* @param capacity The maximum capacity of this fluid container.
|
* @param capacity The maximum capacity of this fluid container.
|
||||||
*/
|
*/
|
||||||
public ItemFluidContainer(int capacity)
|
public ItemFluidContainer(Item.Builder builder, int capacity)
|
||||||
{
|
{
|
||||||
|
super(builder);
|
||||||
this.capacity = capacity;
|
this.capacity = capacity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,8 +21,10 @@ package net.minecraftforge.fluids.capability;
|
||||||
|
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
|
import net.minecraft.tileentity.TileEntityType;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
|
import net.minecraftforge.common.capabilities.OptionalCapabilityInstance;
|
||||||
import net.minecraftforge.fluids.Fluid;
|
import net.minecraftforge.fluids.Fluid;
|
||||||
import net.minecraftforge.fluids.FluidTank;
|
import net.minecraftforge.fluids.FluidTank;
|
||||||
|
|
||||||
|
@ -33,6 +35,13 @@ public class TileFluidHandler extends TileEntity
|
||||||
{
|
{
|
||||||
protected FluidTank tank = new FluidTank(Fluid.BUCKET_VOLUME);
|
protected FluidTank tank = new FluidTank(Fluid.BUCKET_VOLUME);
|
||||||
|
|
||||||
|
private final OptionalCapabilityInstance<IFluidHandler> holder = OptionalCapabilityInstance.of(() -> tank);
|
||||||
|
|
||||||
|
public TileFluidHandler(@Nonnull TileEntityType<?> p_i48289_1_)
|
||||||
|
{
|
||||||
|
super(p_i48289_1_);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readFromNBT(NBTTagCompound tag)
|
public void readFromNBT(NBTTagCompound tag)
|
||||||
{
|
{
|
||||||
|
@ -49,18 +58,11 @@ public class TileFluidHandler extends TileEntity
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasCapability(@Nonnull Capability<?> capability, @Nullable EnumFacing facing)
|
@Nonnull
|
||||||
{
|
public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
||||||
return capability == CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY || super.hasCapability(capability, facing);
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Override
|
|
||||||
@Nullable
|
|
||||||
public <T> T getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
|
||||||
{
|
{
|
||||||
if (capability == CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY)
|
if (capability == CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY)
|
||||||
return (T) tank;
|
return holder.cast();
|
||||||
return super.getCapability(capability, facing);
|
return super.getCapability(capability, facing);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
||||||
|
import net.minecraftforge.common.capabilities.OptionalCapabilityInstance;
|
||||||
import net.minecraftforge.fluids.*;
|
import net.minecraftforge.fluids.*;
|
||||||
import net.minecraftforge.fluids.capability.CapabilityFluidHandler;
|
import net.minecraftforge.fluids.capability.CapabilityFluidHandler;
|
||||||
import net.minecraftforge.fluids.capability.FluidTankProperties;
|
import net.minecraftforge.fluids.capability.FluidTankProperties;
|
||||||
|
@ -46,6 +47,8 @@ public class FluidHandlerItemStack implements IFluidHandlerItem, ICapabilityProv
|
||||||
{
|
{
|
||||||
public static final String FLUID_NBT_KEY = "Fluid";
|
public static final String FLUID_NBT_KEY = "Fluid";
|
||||||
|
|
||||||
|
private final OptionalCapabilityInstance<IFluidHandlerItem> holder = OptionalCapabilityInstance.of(() -> this);
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
protected ItemStack container;
|
protected ItemStack container;
|
||||||
protected int capacity;
|
protected int capacity;
|
||||||
|
@ -201,17 +204,10 @@ public class FluidHandlerItemStack implements IFluidHandlerItem, ICapabilityProv
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasCapability(@Nonnull Capability<?> capability, @Nullable EnumFacing facing)
|
@Nonnull
|
||||||
|
public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
||||||
{
|
{
|
||||||
return capability == CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY;
|
return OptionalCapabilityInstance.orEmpty(capability, CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY, holder);
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Override
|
|
||||||
@Nullable
|
|
||||||
public <T> T getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
|
||||||
{
|
|
||||||
return capability == CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY ? (T) this : null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -27,6 +27,7 @@ import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
||||||
|
import net.minecraftforge.common.capabilities.OptionalCapabilityInstance;
|
||||||
import net.minecraftforge.fluids.FluidStack;
|
import net.minecraftforge.fluids.FluidStack;
|
||||||
import net.minecraftforge.fluids.capability.FluidTankProperties;
|
import net.minecraftforge.fluids.capability.FluidTankProperties;
|
||||||
import net.minecraftforge.fluids.capability.IFluidHandlerItem;
|
import net.minecraftforge.fluids.capability.IFluidHandlerItem;
|
||||||
|
@ -43,6 +44,8 @@ public class FluidHandlerItemStackSimple implements IFluidHandlerItem, ICapabili
|
||||||
{
|
{
|
||||||
public static final String FLUID_NBT_KEY = "Fluid";
|
public static final String FLUID_NBT_KEY = "Fluid";
|
||||||
|
|
||||||
|
private final OptionalCapabilityInstance<IFluidHandlerItem> holder = OptionalCapabilityInstance.of(() -> this);
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
protected ItemStack container;
|
protected ItemStack container;
|
||||||
protected int capacity;
|
protected int capacity;
|
||||||
|
@ -178,17 +181,10 @@ public class FluidHandlerItemStackSimple implements IFluidHandlerItem, ICapabili
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasCapability(@Nonnull Capability<?> capability, @Nullable EnumFacing facing)
|
@Nonnull
|
||||||
|
public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
||||||
{
|
{
|
||||||
return capability == CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY;
|
return OptionalCapabilityInstance.orEmpty(capability, CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY, holder);
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Override
|
|
||||||
@Nullable
|
|
||||||
public <T> T getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
|
||||||
{
|
|
||||||
return capability == CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY ? (T) this : null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/*
|
/* TODO Fluids
|
||||||
* Minecraft Forge
|
* Minecraft Forge
|
||||||
* Copyright (c) 2016-2018.
|
* Copyright (c) 2016-2018.
|
||||||
*
|
*
|
||||||
|
@ -18,7 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package net.minecraftforge.fluids.capability.wrappers;
|
package net.minecraftforge.fluids.capability.wrappers;
|
||||||
|
/*
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
import net.minecraft.block.BlockLiquid;
|
import net.minecraft.block.BlockLiquid;
|
||||||
|
@ -40,7 +40,7 @@ import net.minecraftforge.fluids.capability.IFluidHandler;
|
||||||
/**
|
/**
|
||||||
* Wrapper to handle vanilla Water or Lava as an IFluidHandler.
|
* Wrapper to handle vanilla Water or Lava as an IFluidHandler.
|
||||||
* Methods are modeled after {@link ItemBucket#onItemRightClick(World, EntityPlayer, EnumHand)}
|
* Methods are modeled after {@link ItemBucket#onItemRightClick(World, EntityPlayer, EnumHand)}
|
||||||
*/
|
* /
|
||||||
public class BlockLiquidWrapper implements IFluidHandler
|
public class BlockLiquidWrapper implements IFluidHandler
|
||||||
{
|
{
|
||||||
protected final BlockLiquid blockLiquid;
|
protected final BlockLiquid blockLiquid;
|
||||||
|
@ -155,3 +155,4 @@ public class BlockLiquidWrapper implements IFluidHandler
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
|
@ -30,6 +30,7 @@ import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraftforge.common.ForgeMod;
|
import net.minecraftforge.common.ForgeMod;
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
||||||
|
import net.minecraftforge.common.capabilities.OptionalCapabilityInstance;
|
||||||
import net.minecraftforge.fluids.Fluid;
|
import net.minecraftforge.fluids.Fluid;
|
||||||
import net.minecraftforge.fluids.FluidRegistry;
|
import net.minecraftforge.fluids.FluidRegistry;
|
||||||
import net.minecraftforge.fluids.FluidStack;
|
import net.minecraftforge.fluids.FluidStack;
|
||||||
|
@ -45,6 +46,8 @@ import net.minecraftforge.fluids.capability.CapabilityFluidHandler;
|
||||||
*/
|
*/
|
||||||
public class FluidBucketWrapper implements IFluidHandlerItem, ICapabilityProvider
|
public class FluidBucketWrapper implements IFluidHandlerItem, ICapabilityProvider
|
||||||
{
|
{
|
||||||
|
private final OptionalCapabilityInstance<IFluidHandlerItem> holder = OptionalCapabilityInstance.of(() -> this);
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
protected ItemStack container;
|
protected ItemStack container;
|
||||||
|
|
||||||
|
@ -178,19 +181,9 @@ public class FluidBucketWrapper implements IFluidHandlerItem, ICapabilityProvide
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasCapability(@Nonnull Capability<?> capability, @Nullable EnumFacing facing)
|
@Nonnull
|
||||||
|
public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
||||||
{
|
{
|
||||||
return capability == CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY;
|
return OptionalCapabilityInstance.orEmpty(capability, CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY, holder);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
@Nullable
|
|
||||||
public <T> T getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
|
|
||||||
{
|
|
||||||
if (capability == CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY)
|
|
||||||
{
|
|
||||||
return CapabilityFluidHandler.FLUID_HANDLER_ITEM_CAPABILITY.cast(this);
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,11 +20,11 @@
|
||||||
package net.minecraftforge.fml.client;
|
package net.minecraftforge.fml.client;
|
||||||
|
|
||||||
import net.minecraft.client.gui.GuiScreen;
|
import net.minecraft.client.gui.GuiScreen;
|
||||||
import net.minecraftforge.fml.relauncher.Side;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.fml.relauncher.SideOnly;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
|
||||||
public interface IDisplayableError
|
public interface IDisplayableError
|
||||||
{
|
{
|
||||||
@SideOnly(Side.CLIENT)
|
@OnlyIn(Dist.CLIENT)
|
||||||
GuiScreen createGui();
|
GuiScreen createGui();
|
||||||
}
|
}
|
||||||
|
|
|
@ -203,7 +203,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch(IOException e)
|
catch(IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Could not save the splash.properties file", e);
|
LOGGER.error("Could not save the splash.properties file", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
miscPack = createResourcePack(miscPackFile);
|
miscPack = createResourcePack(miscPackFile);
|
||||||
|
@ -240,7 +240,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch (LWJGLException e)
|
catch (LWJGLException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error starting SplashProgress:", e);
|
LOGGER.error("Error starting SplashProgress:", e);
|
||||||
disableSplash(e);
|
disableSplash(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -537,7 +537,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch (LWJGLException e)
|
catch (LWJGLException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error setting GL context:", e);
|
LOGGER.error("Error setting GL context:", e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
glClearColor((float)((backgroundColor >> 16) & 0xFF) / 0xFF, (float)((backgroundColor >> 8) & 0xFF) / 0xFF, (float)(backgroundColor & 0xFF) / 0xFF, 1);
|
glClearColor((float)((backgroundColor >> 16) & 0xFF) / 0xFF, (float)((backgroundColor >> 8) & 0xFF) / 0xFF, (float)(backgroundColor & 0xFF) / 0xFF, 1);
|
||||||
|
@ -564,7 +564,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch (LWJGLException e)
|
catch (LWJGLException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error releasing GL context:", e);
|
LOGGER.error("Error releasing GL context:", e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
@ -578,7 +578,7 @@ public class SplashProgress
|
||||||
@Override
|
@Override
|
||||||
public void uncaughtException(Thread t, Throwable e)
|
public void uncaughtException(Thread t, Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Splash thread Exception", e);
|
LOGGER.error("Splash thread Exception", e);
|
||||||
threadError = e;
|
threadError = e;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -629,7 +629,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch (LWJGLException e)
|
catch (LWJGLException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error setting GL context:", e);
|
LOGGER.error("Error setting GL context:", e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -650,7 +650,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch (LWJGLException e)
|
catch (LWJGLException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error releasing GL context:", e);
|
LOGGER.error("Error releasing GL context:", e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
lock.unlock();
|
lock.unlock();
|
||||||
|
@ -673,7 +673,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error finishing SplashProgress:", e);
|
LOGGER.error("Error finishing SplashProgress:", e);
|
||||||
disableSplash(e);
|
disableSplash(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -726,7 +726,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch(IOException e)
|
catch(IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Could not save the splash.properties file", e);
|
LOGGER.error("Could not save the splash.properties file", e);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -843,7 +843,7 @@ public class SplashProgress
|
||||||
}
|
}
|
||||||
catch(IOException e)
|
catch(IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error reading texture from file: {}", location, e);
|
LOGGER.error("Error reading texture from file: {}", location, e);
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
|
|
@ -38,10 +38,11 @@ import net.minecraftforge.fml.client.config.GuiConfigEntries.IConfigEntry;
|
||||||
import net.minecraftforge.fml.client.event.ConfigChangedEvent;
|
import net.minecraftforge.fml.client.event.ConfigChangedEvent;
|
||||||
import net.minecraftforge.fml.client.event.ConfigChangedEvent.OnConfigChangedEvent;
|
import net.minecraftforge.fml.client.event.ConfigChangedEvent.OnConfigChangedEvent;
|
||||||
import net.minecraftforge.fml.client.event.ConfigChangedEvent.PostConfigChangedEvent;
|
import net.minecraftforge.fml.client.event.ConfigChangedEvent.PostConfigChangedEvent;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.fml.common.Loader;
|
import net.minecraftforge.fml.common.Loader;
|
||||||
import net.minecraftforge.eventbus.api.Event.Result;
|
import net.minecraftforge.eventbus.api.Event.Result;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.lwjgl.input.Keyboard;
|
import org.lwjgl.input.Keyboard;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
@ -54,6 +55,8 @@ import javax.annotation.Nullable;
|
||||||
*/
|
*/
|
||||||
public class GuiConfig extends GuiScreen
|
public class GuiConfig extends GuiScreen
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A reference to the screen object that created this. Used for navigating between screens.
|
* A reference to the screen object that created this. Used for navigating between screens.
|
||||||
*/
|
*/
|
||||||
|
@ -289,7 +292,7 @@ public class GuiConfig extends GuiScreen
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error performing GuiConfig action:", e);
|
LOGGER.error("Error performing GuiConfig action:", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flag)
|
if (flag)
|
||||||
|
|
|
@ -36,9 +36,11 @@ import net.minecraft.client.gui.GuiTextField;
|
||||||
import net.minecraft.client.resources.I18n;
|
import net.minecraft.client.resources.I18n;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraftforge.fml.ModList;
|
import net.minecraftforge.fml.ModList;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
import net.minecraftforge.fml.loading.moddiscovery.ModInfo;
|
import net.minecraftforge.fml.loading.moddiscovery.ModInfo;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.lwjgl.input.Keyboard;
|
import org.lwjgl.input.Keyboard;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -49,6 +51,8 @@ import org.lwjgl.input.Keyboard;
|
||||||
*/
|
*/
|
||||||
public class GuiConfigEntries extends GuiListExtended
|
public class GuiConfigEntries extends GuiListExtended
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
public final GuiConfig owningScreen;
|
public final GuiConfig owningScreen;
|
||||||
public final Minecraft mc;
|
public final Minecraft mc;
|
||||||
public List<IConfigEntry> listEntries;
|
public List<IConfigEntry> listEntries;
|
||||||
|
@ -129,7 +133,7 @@ public class GuiConfigEntries extends GuiListExtended
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("There was a critical error instantiating the custom IConfigEntry for config element {}.", configElement.getName(), e);
|
LOGGER.error("There was a critical error instantiating the custom IConfigEntry for config element {}.", configElement.getName(), e);
|
||||||
}
|
}
|
||||||
else if (configElement.isProperty())
|
else if (configElement.isProperty())
|
||||||
{
|
{
|
||||||
|
|
|
@ -33,7 +33,8 @@ import net.minecraft.util.text.TextFormatting;
|
||||||
import static net.minecraftforge.fml.client.config.GuiUtils.RESET_CHAR;
|
import static net.minecraftforge.fml.client.config.GuiUtils.RESET_CHAR;
|
||||||
import static net.minecraftforge.fml.client.config.GuiUtils.UNDO_CHAR;
|
import static net.minecraftforge.fml.client.config.GuiUtils.UNDO_CHAR;
|
||||||
|
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.lwjgl.input.Keyboard;
|
import org.lwjgl.input.Keyboard;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -44,6 +45,8 @@ import org.lwjgl.input.Keyboard;
|
||||||
*/
|
*/
|
||||||
public class GuiEditArray extends GuiScreen
|
public class GuiEditArray extends GuiScreen
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
protected GuiScreen parentScreen;
|
protected GuiScreen parentScreen;
|
||||||
protected IConfigElement configElement;
|
protected IConfigElement configElement;
|
||||||
protected GuiEditArrayEntries entryList;
|
protected GuiEditArrayEntries entryList;
|
||||||
|
@ -129,7 +132,7 @@ public class GuiEditArray extends GuiScreen
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error performing GuiEditArray action:", e);
|
LOGGER.error("Error performing GuiEditArray action:", e);
|
||||||
}
|
}
|
||||||
this.mc.displayGuiScreen(this.parentScreen);
|
this.mc.displayGuiScreen(this.parentScreen);
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,8 +29,9 @@ import net.minecraft.client.gui.GuiTextField;
|
||||||
import net.minecraft.client.resources.I18n;
|
import net.minecraft.client.resources.I18n;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraftforge.fml.client.config.GuiConfigEntries.ArrayEntry;
|
import net.minecraftforge.fml.client.config.GuiConfigEntries.ArrayEntry;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.lwjgl.input.Keyboard;
|
import org.lwjgl.input.Keyboard;
|
||||||
|
|
||||||
import static net.minecraftforge.fml.client.config.GuiUtils.INVALID;
|
import static net.minecraftforge.fml.client.config.GuiUtils.INVALID;
|
||||||
|
@ -42,6 +43,8 @@ import static net.minecraftforge.fml.client.config.GuiUtils.VALID;
|
||||||
*/
|
*/
|
||||||
public class GuiEditArrayEntries extends GuiListExtended
|
public class GuiEditArrayEntries extends GuiListExtended
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
protected GuiEditArray owningGui;
|
protected GuiEditArray owningGui;
|
||||||
public IConfigElement configElement;
|
public IConfigElement configElement;
|
||||||
public List<IArrayEntry> listEntries;
|
public List<IArrayEntry> listEntries;
|
||||||
|
@ -80,7 +83,7 @@ public class GuiEditArrayEntries extends GuiListExtended
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("There was a critical error instantiating the custom IGuiEditListEntry for property {}.", configElement.getName(), e);
|
LOGGER.error("There was a critical error instantiating the custom IGuiEditListEntry for property {}.", configElement.getName(), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -155,7 +158,7 @@ public class GuiEditArrayEntries extends GuiListExtended
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("There was a critical error instantiating the custom IGuiEditListEntry for property {}.", configElement.getName(), e);
|
LOGGER.error("There was a critical error instantiating the custom IGuiEditListEntry for property {}.", configElement.getName(), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (configElement.isList() && configElement.getType() == ConfigGuiType.BOOLEAN)
|
else if (configElement.isList() && configElement.getType() == ConfigGuiType.BOOLEAN)
|
||||||
|
@ -559,7 +562,7 @@ public class GuiEditArrayEntries extends GuiListExtended
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class BaseEntry implements IArrayEntry
|
public static class BaseEntry extends GuiListExtended.IGuiListEntry implements IArrayEntry
|
||||||
{
|
{
|
||||||
protected final GuiEditArray owningScreen;
|
protected final GuiEditArray owningScreen;
|
||||||
protected final GuiEditArrayEntries owningEntryList;
|
protected final GuiEditArrayEntries owningEntryList;
|
||||||
|
@ -592,31 +595,31 @@ public class GuiEditArrayEntries extends GuiListExtended
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawEntry(int slotIndex, int x, int y, int listWidth, int slotHeight, int mouseX, int mouseY, boolean isSelected, float partial)
|
public void func_194999_a(int entryWidth, int entryHeight, int mouseX, int mouseY, boolean isHovered, float partial)
|
||||||
{
|
{
|
||||||
if (this.getValue() != null && this.isValidated)
|
if (this.getValue() != null && this.isValidated)
|
||||||
owningEntryList.getMC().fontRenderer.drawString(
|
owningEntryList.getMC().fontRenderer.func_211126_b(
|
||||||
isValidValue ? TextFormatting.GREEN + VALID : TextFormatting.RED + INVALID,
|
isValidValue ? TextFormatting.GREEN + VALID : TextFormatting.RED + INVALID,
|
||||||
listWidth / 4 - owningEntryList.getMC().fontRenderer.getStringWidth(VALID) - 2,
|
entryWidth / 4 - owningEntryList.getMC().fontRenderer.getStringWidth(VALID) - 2,
|
||||||
y + slotHeight / 2 - owningEntryList.getMC().fontRenderer.FONT_HEIGHT / 2,
|
entryHeight / 2 - owningEntryList.getMC().fontRenderer.FONT_HEIGHT / 2,
|
||||||
16777215);
|
16777215);
|
||||||
|
|
||||||
int half = listWidth / 2;
|
int half = entryWidth / 2;
|
||||||
if (owningEntryList.canAddMoreEntries)
|
if (owningEntryList.canAddMoreEntries)
|
||||||
{
|
{
|
||||||
this.btnAddNewEntryAbove.visible = true;
|
this.btnAddNewEntryAbove.visible = true;
|
||||||
this.btnAddNewEntryAbove.x = half + ((half / 2) - 44);
|
this.btnAddNewEntryAbove.x = half + ((half / 2) - 44);
|
||||||
this.btnAddNewEntryAbove.y = y;
|
this.btnAddNewEntryAbove.y = this.func_195001_c();
|
||||||
this.btnAddNewEntryAbove.drawButton(owningEntryList.getMC(), mouseX, mouseY, partial);
|
this.btnAddNewEntryAbove.drawButton(owningEntryList.getMC(), mouseX, mouseY, partial);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
this.btnAddNewEntryAbove.visible = false;
|
this.btnAddNewEntryAbove.visible = false;
|
||||||
|
|
||||||
if (!configElement.isListLengthFixed() && slotIndex != owningEntryList.listEntries.size() - 1)
|
if (!configElement.isListLengthFixed() && this.field_195005_b != owningEntryList.listEntries.size() - 1)
|
||||||
{
|
{
|
||||||
this.btnRemoveEntry.visible = true;
|
this.btnRemoveEntry.visible = true;
|
||||||
this.btnRemoveEntry.x = half + ((half / 2) - 22);
|
this.btnRemoveEntry.x = half + ((half / 2) - 22);
|
||||||
this.btnRemoveEntry.y = y;
|
this.btnRemoveEntry.y = this.func_195001_c();
|
||||||
this.btnRemoveEntry.drawButton(owningEntryList.getMC(), mouseX, mouseY, partial);
|
this.btnRemoveEntry.drawButton(owningEntryList.getMC(), mouseX, mouseY, partial);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -689,7 +692,7 @@ public class GuiEditArrayEntries extends GuiListExtended
|
||||||
public void updatePosition(int p_178011_1_, int p_178011_2_, int p_178011_3_, float partial){}
|
public void updatePosition(int p_178011_1_, int p_178011_2_, int p_178011_3_, float partial){}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static interface IArrayEntry extends GuiListExtended.IGuiListEntry
|
public static interface IArrayEntry
|
||||||
{
|
{
|
||||||
void keyTyped(char eventChar, int eventKey);
|
void keyTyped(char eventChar, int eventKey);
|
||||||
|
|
||||||
|
|
|
@ -25,12 +25,14 @@ import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.GuiButton;
|
import net.minecraft.client.gui.GuiButton;
|
||||||
import net.minecraft.client.gui.GuiScreen;
|
import net.minecraft.client.gui.GuiScreen;
|
||||||
import net.minecraft.client.resources.I18n;
|
import net.minecraft.client.resources.I18n;
|
||||||
import net.minecraft.util.text.TextFormatting;
|
import net.minecraft.util.text.TextFormatting;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
import static net.minecraftforge.fml.client.config.GuiUtils.RESET_CHAR;
|
import static net.minecraftforge.fml.client.config.GuiUtils.RESET_CHAR;
|
||||||
import static net.minecraftforge.fml.client.config.GuiUtils.UNDO_CHAR;
|
import static net.minecraftforge.fml.client.config.GuiUtils.UNDO_CHAR;
|
||||||
|
@ -42,6 +44,8 @@ import static net.minecraftforge.fml.client.config.GuiUtils.UNDO_CHAR;
|
||||||
*/
|
*/
|
||||||
public class GuiSelectString extends GuiScreen
|
public class GuiSelectString extends GuiScreen
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
protected GuiScreen parentScreen;
|
protected GuiScreen parentScreen;
|
||||||
protected IConfigElement configElement;
|
protected IConfigElement configElement;
|
||||||
protected GuiSelectStringEntries entryList;
|
protected GuiSelectStringEntries entryList;
|
||||||
|
@ -129,7 +133,7 @@ public class GuiSelectString extends GuiScreen
|
||||||
}
|
}
|
||||||
catch (Throwable e)
|
catch (Throwable e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Error performing GuiSelectString action:", e);
|
LOGGER.error("Error performing GuiSelectString action:", e);
|
||||||
}
|
}
|
||||||
this.mc.displayGuiScreen(this.parentScreen);
|
this.mc.displayGuiScreen(this.parentScreen);
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,9 @@ package net.minecraftforge.fml.client.gui;
|
||||||
|
|
||||||
import net.minecraft.client.gui.FontRenderer;
|
import net.minecraft.client.gui.FontRenderer;
|
||||||
import net.minecraft.client.gui.GuiErrorScreen;
|
import net.minecraft.client.gui.GuiErrorScreen;
|
||||||
|
import net.minecraft.client.gui.GuiScreen;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
import net.minecraftforge.fml.client.IDisplayableError;
|
||||||
import net.minecraftforge.fml.common.EnhancedRuntimeException;
|
import net.minecraftforge.fml.common.EnhancedRuntimeException;
|
||||||
import net.minecraftforge.fml.common.IFMLHandledException;
|
import net.minecraftforge.fml.common.IFMLHandledException;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
|
|
@ -22,17 +22,21 @@ package net.minecraftforge.fml.client.gui;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import net.minecraft.client.gui.GuiButton;
|
import net.minecraft.client.gui.GuiButton;
|
||||||
import net.minecraft.client.gui.GuiScreen;
|
import net.minecraft.client.gui.GuiScreen;
|
||||||
import net.minecraft.client.gui.GuiYesNo;
|
import net.minecraft.client.gui.GuiYesNo;
|
||||||
import net.minecraft.client.gui.GuiYesNoCallback;
|
import net.minecraft.client.gui.GuiYesNoCallback;
|
||||||
import net.minecraftforge.fml.client.FMLClientHandler;
|
import net.minecraftforge.fml.client.FMLClientHandler;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.fml.StartupQuery;
|
import net.minecraftforge.fml.StartupQuery;
|
||||||
import net.minecraftforge.fml.common.ZipperUtil;
|
import net.minecraftforge.fml.common.ZipperUtil;
|
||||||
|
|
||||||
public class GuiOldSaveLoadConfirm extends GuiYesNo implements GuiYesNoCallback {
|
public class GuiOldSaveLoadConfirm extends GuiYesNo implements GuiYesNoCallback {
|
||||||
|
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private String dirName;
|
private String dirName;
|
||||||
private String saveName;
|
private String saveName;
|
||||||
private File zip;
|
private File zip;
|
||||||
|
@ -75,7 +79,7 @@ public class GuiOldSaveLoadConfirm extends GuiYesNo implements GuiYesNoCallback
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.info("Capturing current state of world {} into file {}", saveName, zip.getAbsolutePath());
|
LOGGER.info("Capturing current state of world {} into file {}", saveName, zip.getAbsolutePath());
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String skip = System.getProperty("fml.doNotBackup");
|
String skip = System.getProperty("fml.doNotBackup");
|
||||||
|
@ -86,11 +90,11 @@ public class GuiOldSaveLoadConfirm extends GuiYesNo implements GuiYesNoCallback
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (int x = 0; x < 10; x++)
|
for (int x = 0; x < 10; x++)
|
||||||
FMLLog.log.fatal("!!!!!!!!!! UPDATING WORLD WITHOUT DOING BACKUP !!!!!!!!!!!!!!!!");
|
LOGGER.fatal("!!!!!!!!!! UPDATING WORLD WITHOUT DOING BACKUP !!!!!!!!!!!!!!!!");
|
||||||
}
|
}
|
||||||
} catch (IOException e)
|
} catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("There was a problem saving the backup {}. Please fix and try again", zip.getName(), e);
|
LOGGER.warn("There was a problem saving the backup {}. Please fix and try again", zip.getName(), e);
|
||||||
FMLClientHandler.instance().showGuiScreen(new GuiBackupFailed(parent, zip));
|
FMLClientHandler.instance().showGuiScreen(new GuiBackupFailed(parent, zip));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,10 +52,10 @@ public class GuiSortingProblem extends GuiScreen {
|
||||||
this.drawCenteredString(this.fontRenderer, "The remainder of the cycle involves these mods", this.width / 2, offset, 0xFFFFFF);
|
this.drawCenteredString(this.fontRenderer, "The remainder of the cycle involves these mods", this.width / 2, offset, 0xFFFFFF);
|
||||||
offset+=5;
|
offset+=5;
|
||||||
for (ModContainer mc : failedList.getVisitedNodes())
|
for (ModContainer mc : failedList.getVisitedNodes())
|
||||||
{
|
{/* TODO Mod dependencies
|
||||||
offset+=10;
|
offset+=10;
|
||||||
this.drawCenteredString(this.fontRenderer, String.format("%s : before: %s, after: %s", mc.toString(), mc.getDependants(), mc.getDependencies()), this.width / 2, offset, 0xEEEEEE);
|
this.drawCenteredString(this.fontRenderer, String.format("%s : before: %s, after: %s", mc.toString(), mc.getDependants(), mc.getDependencies()), this.width / 2, offset, 0xEEEEEE);
|
||||||
}
|
*/}
|
||||||
offset+=20;
|
offset+=20;
|
||||||
this.drawCenteredString(this.fontRenderer, "The file 'ForgeModLoader-client-0.log' contains more information", this.width / 2, offset, 0xFFFFFF);
|
this.drawCenteredString(this.fontRenderer, "The file 'ForgeModLoader-client-0.log' contains more information", this.width / 2, offset, 0xFFFFFF);
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,13 +44,13 @@ public class ClientRegistry
|
||||||
* @param tileEntityClass
|
* @param tileEntityClass
|
||||||
* @param id
|
* @param id
|
||||||
* @param specialRenderer
|
* @param specialRenderer
|
||||||
*/
|
* / TODO GameRegistry
|
||||||
public static <T extends TileEntity> void registerTileEntity(Class<T> tileEntityClass, String id, TileEntityRenderer<? super T> specialRenderer)
|
public static <T extends TileEntity> void registerTileEntity(Class<T> tileEntityClass, String id, TileEntityRenderer<? super T> specialRenderer)
|
||||||
{
|
{
|
||||||
GameRegistry.registerTileEntity(tileEntityClass, id);
|
GameRegistry.registerTileEntity(tileEntityClass, id);
|
||||||
bindTileEntitySpecialRenderer(tileEntityClass, specialRenderer);
|
bindTileEntitySpecialRenderer(tileEntityClass, specialRenderer);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
public static <T extends TileEntity> void bindTileEntitySpecialRenderer(Class<T> tileEntityClass, TileEntityRenderer<? super T> specialRenderer)
|
public static <T extends TileEntity> void bindTileEntitySpecialRenderer(Class<T> tileEntityClass, TileEntityRenderer<? super T> specialRenderer)
|
||||||
{
|
{
|
||||||
TileEntityRendererDispatcher.instance.renderers.put(tileEntityClass, specialRenderer);
|
TileEntityRendererDispatcher.instance.renderers.put(tileEntityClass, specialRenderer);
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package net.minecraftforge.fml.common;
|
package net.minecraftforge.fml.common;
|
||||||
|
/* TODO ReflectionHelper
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
import net.minecraftforge.fml.common.asm.deobf.FMLDeobfuscatingRemapper;
|
import net.minecraftforge.fml.common.asm.deobf.FMLDeobfuscatingRemapper;
|
||||||
|
@ -31,7 +31,7 @@ import net.minecraftforge.fml.relauncher.ReflectionHelper.UnableToFindFieldExcep
|
||||||
*
|
*
|
||||||
* @author cpw
|
* @author cpw
|
||||||
*
|
*
|
||||||
*/
|
* /
|
||||||
public class ObfuscationReflectionHelper
|
public class ObfuscationReflectionHelper
|
||||||
{
|
{
|
||||||
public static <T, E> T getPrivateValue(Class<? super E> classToAccess, E instance, int fieldIndex)
|
public static <T, E> T getPrivateValue(Class<? super E> classToAccess, E instance, int fieldIndex)
|
||||||
|
@ -42,7 +42,7 @@ public class ObfuscationReflectionHelper
|
||||||
}
|
}
|
||||||
catch (UnableToAccessFieldException e)
|
catch (UnableToAccessFieldException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("There was a problem getting field index {} from {}", classToAccess.getName(), e);
|
LOGGER.error("There was a problem getting field index {} from {}", classToAccess.getName(), e);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -67,12 +67,12 @@ public class ObfuscationReflectionHelper
|
||||||
}
|
}
|
||||||
catch (UnableToFindFieldException e)
|
catch (UnableToFindFieldException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unable to locate any field {} on type {}", Arrays.toString(fieldNames), classToAccess.getName(), e);
|
LOGGER.error("Unable to locate any field {} on type {}", Arrays.toString(fieldNames), classToAccess.getName(), e);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
catch (UnableToAccessFieldException e)
|
catch (UnableToAccessFieldException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unable to access any field {} on type {}", classToAccess.getName(), e);
|
LOGGER.error("Unable to access any field {} on type {}", classToAccess.getName(), e);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -85,7 +85,7 @@ public class ObfuscationReflectionHelper
|
||||||
}
|
}
|
||||||
catch (UnableToAccessFieldException e)
|
catch (UnableToAccessFieldException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("There was a problem setting field index {} on type {}", classToAccess.getName(), e);
|
LOGGER.error("There was a problem setting field index {} on type {}", classToAccess.getName(), e);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -98,13 +98,14 @@ public class ObfuscationReflectionHelper
|
||||||
}
|
}
|
||||||
catch (UnableToFindFieldException e)
|
catch (UnableToFindFieldException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unable to locate any field {} on type {}", classToAccess.getName(), e);
|
LOGGER.error("Unable to locate any field {} on type {}", classToAccess.getName(), e);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
catch (UnableToAccessFieldException e)
|
catch (UnableToAccessFieldException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unable to set any field {} on type {}", classToAccess.getName(), e);
|
LOGGER.error("Unable to set any field {} on type {}", classToAccess.getName(), e);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package net.minecraftforge.fml.common.asm.transformers;
|
package net.minecraftforge.fml.common.asm.transformers;
|
||||||
|
/* TODO Class transformers
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
|
||||||
import org.objectweb.asm.ClassReader;
|
import org.objectweb.asm.ClassReader;
|
||||||
|
@ -167,3 +167,4 @@ public class SoundEngineFixTransformer implements IClassTransformer
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
*/
|
|
@ -31,6 +31,7 @@ import net.minecraftforge.registries.ForgeRegistryEntry;
|
||||||
import org.apache.commons.lang3.Validate;
|
import org.apache.commons.lang3.Validate;
|
||||||
|
|
||||||
import net.minecraft.entity.passive.EntityVillager;
|
import net.minecraft.entity.passive.EntityVillager;
|
||||||
|
import net.minecraft.entity.passive.EntityVillager.ITradeList;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.util.registry.RegistryNamespaced;
|
import net.minecraft.util.registry.RegistryNamespaced;
|
||||||
|
@ -43,18 +44,17 @@ import javax.annotation.Nullable;
|
||||||
*/
|
*/
|
||||||
public class VillagerRegistry
|
public class VillagerRegistry
|
||||||
{
|
{
|
||||||
/*
|
|
||||||
public static final RegistryObject<VillagerProfession> FARMER = RegistryObject.of("minecraft:farmer", ()->VillagerProfession.class);
|
public static final RegistryObject<VillagerProfession> FARMER = RegistryObject.of("minecraft:farmer", ()->VillagerProfession.class);
|
||||||
private static final VillagerRegistry INSTANCE = new VillagerRegistry();
|
private static final VillagerRegistry INSTANCE = new VillagerRegistry();
|
||||||
|
/* TODO village creation
|
||||||
private Map<Class<?>, IVillageCreationHandler> villageCreationHandlers = Maps.newHashMap();
|
private Map<Class<?>, IVillageCreationHandler> villageCreationHandlers = Maps.newHashMap();
|
||||||
|
*/
|
||||||
private VillagerRegistry()
|
private VillagerRegistry()
|
||||||
{
|
{
|
||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
*/
|
|
||||||
/**
|
/**
|
||||||
* Allow access to the {@link net.minecraft.world.gen.structure.StructureVillagePieces} array controlling new village
|
* Allow access to the {@link net.minecraft.world.gen.structure.StructureVillagePieces} array controlling new village
|
||||||
* creation so you can insert your own new village pieces
|
* creation so you can insert your own new village pieces
|
||||||
|
@ -100,13 +100,12 @@ public class VillagerRegistry
|
||||||
Village buildComponent(StructureVillagePieces.PieceWeight villagePiece, StructureVillagePieces.Start startPiece, List<StructureComponent> pieces, Random random, int p1,
|
Village buildComponent(StructureVillagePieces.PieceWeight villagePiece, StructureVillagePieces.Start startPiece, List<StructureComponent> pieces, Random random, int p1,
|
||||||
int p2, int p3, EnumFacing facing, int p5);
|
int p2, int p3, EnumFacing facing, int p5);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
public static VillagerRegistry instance()
|
public static VillagerRegistry instance()
|
||||||
{
|
{
|
||||||
return INSTANCE;
|
return INSTANCE;
|
||||||
}
|
}
|
||||||
|
|
||||||
*/
|
|
||||||
/**
|
/**
|
||||||
* Register a new village creation handler
|
* Register a new village creation handler
|
||||||
*
|
*
|
||||||
|
@ -132,7 +131,7 @@ public class VillagerRegistry
|
||||||
{
|
{
|
||||||
return instance().villageCreationHandlers.get(villagePiece.villagePieceClass).buildComponent(villagePiece, startPiece, pieces, random, p1, p2, p3, facing, p5);
|
return instance().villageCreationHandlers.get(villagePiece.villagePieceClass).buildComponent(villagePiece, startPiece, pieces, random, p1, p2, p3, facing, p5);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
RegistryNamespaced<ResourceLocation, VillagerProfession> REGISTRY = GameData.getWrapper(VillagerProfession.class);
|
RegistryNamespaced<ResourceLocation, VillagerProfession> REGISTRY = GameData.getWrapper(VillagerProfession.class);
|
||||||
|
|
||||||
private void register(VillagerProfession prof, int id)
|
private void register(VillagerProfession prof, int id)
|
||||||
|
@ -178,9 +177,9 @@ public class VillagerRegistry
|
||||||
"minecraft:textures/entity/zombie_villager/zombie_smith.png");
|
"minecraft:textures/entity/zombie_villager/zombie_smith.png");
|
||||||
{
|
{
|
||||||
register(prof, 3);
|
register(prof, 3);
|
||||||
(new VillagerCareer(prof, "armor")).init(VanillaTrades.trades[3][0]);
|
(new VillagerCareer(prof, "armorer")).init(VanillaTrades.trades[3][0]);
|
||||||
(new VillagerCareer(prof, "weapon")).init(VanillaTrades.trades[3][1]);
|
(new VillagerCareer(prof, "weapon_smith")).init(VanillaTrades.trades[3][1]);
|
||||||
(new VillagerCareer(prof, "tool")).init(VanillaTrades.trades[3][2]);
|
(new VillagerCareer(prof, "tool_smith")).init(VanillaTrades.trades[3][2]);
|
||||||
}
|
}
|
||||||
prof = new VillagerProfession("minecraft:butcher",
|
prof = new VillagerProfession("minecraft:butcher",
|
||||||
"minecraft:textures/entity/villager/butcher.png",
|
"minecraft:textures/entity/villager/butcher.png",
|
||||||
|
@ -188,7 +187,7 @@ public class VillagerRegistry
|
||||||
{
|
{
|
||||||
register(prof, 4);
|
register(prof, 4);
|
||||||
(new VillagerCareer(prof, "butcher")).init(VanillaTrades.trades[4][0]);
|
(new VillagerCareer(prof, "butcher")).init(VanillaTrades.trades[4][0]);
|
||||||
(new VillagerCareer(prof, "leather")).init(VanillaTrades.trades[4][1]);
|
(new VillagerCareer(prof, "leatherworker")).init(VanillaTrades.trades[4][1]);
|
||||||
}
|
}
|
||||||
prof = new VillagerProfession("minecraft:nitwit",
|
prof = new VillagerProfession("minecraft:nitwit",
|
||||||
"minecraft:textures/entity/villager/villager.png",
|
"minecraft:textures/entity/villager/villager.png",
|
||||||
|
@ -312,13 +311,12 @@ public class VillagerRegistry
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
*/
|
/**
|
||||||
/**
|
|
||||||
* Hook called when spawning a Villager, sets it's profession to a random registered profession.
|
* Hook called when spawning a Villager, sets it's profession to a random registered profession.
|
||||||
*
|
*
|
||||||
* @param entity The new entity
|
* @param entity The new entity
|
||||||
* @param rand The world's RNG
|
* @param rand The world's RNG
|
||||||
*//*
|
*/
|
||||||
|
|
||||||
public static void setRandomProfession(EntityVillager entity, Random rand)
|
public static void setRandomProfession(EntityVillager entity, Random rand)
|
||||||
{
|
{
|
||||||
|
@ -369,5 +367,5 @@ public class VillagerRegistry
|
||||||
//It is nasty I know but it's vanilla.
|
//It is nasty I know but it's vanilla.
|
||||||
private static final ITradeList[][][][] trades = EntityVillager.GET_TRADES_DONT_USE();
|
private static final ITradeList[][][][] trades = EntityVillager.GET_TRADES_DONT_USE();
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,12 +22,12 @@ package net.minecraftforge.fml.common.toposort;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import net.minecraft.client.gui.GuiScreen;
|
import net.minecraft.client.gui.GuiScreen;
|
||||||
import net.minecraftforge.fml.client.GuiSortingProblem;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.fml.client.IDisplayableError;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
import net.minecraftforge.fml.common.EnhancedRuntimeException;
|
|
||||||
import net.minecraftforge.fml.ModContainer;
|
import net.minecraftforge.fml.ModContainer;
|
||||||
import net.minecraftforge.fml.relauncher.Side;
|
import net.minecraftforge.fml.client.IDisplayableError;
|
||||||
import net.minecraftforge.fml.relauncher.SideOnly;
|
import net.minecraftforge.fml.client.gui.GuiSortingProblem;
|
||||||
|
import net.minecraftforge.fml.common.EnhancedRuntimeException;
|
||||||
|
|
||||||
public class ModSortingException extends EnhancedRuntimeException implements IDisplayableError
|
public class ModSortingException extends EnhancedRuntimeException implements IDisplayableError
|
||||||
{
|
{
|
||||||
|
@ -76,14 +76,14 @@ public class ModSortingException extends EnhancedRuntimeException implements IDi
|
||||||
stream.println("The first mod in the cycle is " + exceptionData.getFirstBadNode());
|
stream.println("The first mod in the cycle is " + exceptionData.getFirstBadNode());
|
||||||
stream.println("The mod cycle involves:");
|
stream.println("The mod cycle involves:");
|
||||||
for (ModContainer mc : exceptionData.getVisitedNodes())
|
for (ModContainer mc : exceptionData.getVisitedNodes())
|
||||||
{
|
{/* TODO Mod dependencies
|
||||||
stream.println(String.format("\t%s : before: %s, after: %s", mc.toString(), mc.getDependants(), mc.getDependencies()));
|
stream.println(String.format("\t%s : before: %s, after: %s", mc.toString(), mc.getDependants(), mc.getDependencies()));
|
||||||
}
|
*/}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SideOnly(Side.CLIENT)
|
@OnlyIn(Dist.CLIENT)
|
||||||
public GuiScreen createGui()
|
public GuiScreen createGui()
|
||||||
{
|
{
|
||||||
return new GuiSortingProblem(this);
|
return new GuiSortingProblem(this);
|
||||||
|
|
|
@ -30,6 +30,7 @@ import java.net.URISyntaxException;
|
||||||
import java.security.CodeSource;
|
import java.security.CodeSource;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -46,17 +47,22 @@ import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipInputStream;
|
import java.util.zip.ZipInputStream;
|
||||||
|
|
||||||
import org.apache.commons.lang3.tuple.Pair;
|
import org.apache.commons.lang3.tuple.Pair;
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.apache.maven.artifact.versioning.ArtifactVersion;
|
import org.apache.maven.artifact.versioning.ArtifactVersion;
|
||||||
|
|
||||||
import com.google.common.io.ByteStreams;
|
import com.google.common.io.ByteStreams;
|
||||||
import com.google.common.io.Files;
|
import com.google.common.io.Files;
|
||||||
import net.minecraft.launchwrapper.Launch;
|
|
||||||
|
import cpw.mods.modlauncher.Launcher;
|
||||||
import net.minecraftforge.common.ForgeVersion;
|
import net.minecraftforge.common.ForgeVersion;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
import net.minecraftforge.fml.loading.FMLCommonLaunchHandler;
|
||||||
import net.minecraftforge.fml.relauncher.FMLLaunchHandler;
|
import net.minecraftforge.fml.loading.FMLEnvironment;
|
||||||
|
|
||||||
public class LibraryManager
|
public class LibraryManager
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
public static final boolean DISABLE_EXTERNAL_MANIFEST = Boolean.parseBoolean(System.getProperty("forge.disable_external_manifest", "false"));
|
public static final boolean DISABLE_EXTERNAL_MANIFEST = Boolean.parseBoolean(System.getProperty("forge.disable_external_manifest", "false"));
|
||||||
public static final boolean ENABLE_AUTO_MOD_MOVEMENT = Boolean.parseBoolean(System.getProperty("forge.enable_auto_mod_movement", "false"));
|
public static final boolean ENABLE_AUTO_MOD_MOVEMENT = Boolean.parseBoolean(System.getProperty("forge.enable_auto_mod_movement", "false"));
|
||||||
private static final String LIBRARY_DIRECTORY_OVERRIDE = System.getProperty("forge.lib_folder", null);
|
private static final String LIBRARY_DIRECTORY_OVERRIDE = System.getProperty("forge.lib_folder", null);
|
||||||
|
@ -75,10 +81,10 @@ public class LibraryManager
|
||||||
public static void setup(File minecraftHome)
|
public static void setup(File minecraftHome)
|
||||||
{
|
{
|
||||||
File libDir = findLibraryFolder(minecraftHome);
|
File libDir = findLibraryFolder(minecraftHome);
|
||||||
FMLLog.log.debug("Determined Minecraft Libraries Root: {}", libDir);
|
LOGGER.debug("Determined Minecraft Libraries Root: {}", libDir);
|
||||||
Repository old = Repository.replace(libDir, "libraries");
|
Repository old = Repository.replace(libDir, "libraries");
|
||||||
if (old != null)
|
if (old != null)
|
||||||
FMLLog.log.debug(" Overwriting Previous: {}", old);
|
LOGGER.debug(" Overwriting Previous: {}", old);
|
||||||
libraries_dir = Repository.get("libraries");
|
libraries_dir = Repository.get("libraries");
|
||||||
|
|
||||||
File mods = new File(minecraftHome, "mods");
|
File mods = new File(minecraftHome, "mods");
|
||||||
|
@ -119,14 +125,14 @@ public class LibraryManager
|
||||||
{
|
{
|
||||||
if (LIBRARY_DIRECTORY_OVERRIDE != null)
|
if (LIBRARY_DIRECTORY_OVERRIDE != null)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("System variable set to override Library Directory: {}", LIBRARY_DIRECTORY_OVERRIDE);
|
LOGGER.error("System variable set to override Library Directory: {}", LIBRARY_DIRECTORY_OVERRIDE);
|
||||||
return new File(LIBRARY_DIRECTORY_OVERRIDE);
|
return new File(LIBRARY_DIRECTORY_OVERRIDE);
|
||||||
}
|
}
|
||||||
|
|
||||||
CodeSource source = ArtifactVersion.class.getProtectionDomain().getCodeSource();
|
CodeSource source = ArtifactVersion.class.getProtectionDomain().getCodeSource();
|
||||||
if (source == null)
|
if (source == null)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unable to determine codesource for {}. Using default libraries directory.", ArtifactVersion.class.getName());
|
LOGGER.error("Unable to determine codesource for {}. Using default libraries directory.", ArtifactVersion.class.getName());
|
||||||
return new File(minecraftHome, "libraries");
|
return new File(minecraftHome, "libraries");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,9 +148,9 @@ public class LibraryManager
|
||||||
|
|
||||||
if (!comp.endsWith("/org/apache/maven/maven-artifact/"))
|
if (!comp.endsWith("/org/apache/maven/maven-artifact/"))
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Apache Maven library folder was not in the format expected. Using default libraries directory.");
|
LOGGER.error("Apache Maven library folder was not in the format expected. Using default libraries directory.");
|
||||||
FMLLog.log.error("Full: {}", new File(source.getLocation().toURI()));
|
LOGGER.error("Full: {}", new File(source.getLocation().toURI()));
|
||||||
FMLLog.log.error("Trimmed: {}", comp);
|
LOGGER.error("Trimmed: {}", comp);
|
||||||
return new File(minecraftHome, "libraries");
|
return new File(minecraftHome, "libraries");
|
||||||
}
|
}
|
||||||
// maven-artifact /maven /apache /org /libraries
|
// maven-artifact /maven /apache /org /libraries
|
||||||
|
@ -152,7 +158,7 @@ public class LibraryManager
|
||||||
}
|
}
|
||||||
catch (URISyntaxException e)
|
catch (URISyntaxException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error(FMLLog.log.getMessageFactory().newMessage("Unable to determine file for {}. Using default libraries directory.", ArtifactVersion.class.getName()), e);
|
LOGGER.error(LOGGER.getMessageFactory().newMessage("Unable to determine file for {}. Using default libraries directory.", ArtifactVersion.class.getName()), e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new File(minecraftHome, "libraries"); //Everything else failed, return the default.
|
return new File(minecraftHome, "libraries"); //Everything else failed, return the default.
|
||||||
|
@ -163,7 +169,7 @@ public class LibraryManager
|
||||||
if (!dir.exists())
|
if (!dir.exists())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
FMLLog.log.debug("Cleaning up mods folder: {}", dir);
|
LOGGER.debug("Cleaning up mods folder: {}", dir);
|
||||||
for (File file : dir.listFiles(f -> f.isFile() && f.getName().endsWith(".jar")))
|
for (File file : dir.listFiles(f -> f.isFile() && f.getName().endsWith(".jar")))
|
||||||
{
|
{
|
||||||
Pair<Artifact, byte[]> ret = extractPacked(file, modlist, modDirs);
|
Pair<Artifact, byte[]> ret = extractPacked(file, modlist, modDirs);
|
||||||
|
@ -183,7 +189,7 @@ public class LibraryManager
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error(FMLLog.log.getMessageFactory().newMessage("Error updating modlist file {}", modlist.getName()), e);
|
LOGGER.error(LOGGER.getMessageFactory().newMessage("Error updating modlist file {}", modlist.getName()), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,20 +197,20 @@ public class LibraryManager
|
||||||
{
|
{
|
||||||
if (processed.contains(file))
|
if (processed.contains(file))
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("File already proccessed {}, Skipping", file.getAbsolutePath());
|
LOGGER.debug("File already proccessed {}, Skipping", file.getAbsolutePath());
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
JarFile jar = null;
|
JarFile jar = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
jar = new JarFile(file);
|
jar = new JarFile(file);
|
||||||
FMLLog.log.debug("Examining file: {}", file.getName());
|
LOGGER.debug("Examining file: {}", file.getName());
|
||||||
processed.add(file);
|
processed.add(file);
|
||||||
return extractPacked(jar, modlist, modDirs);
|
return extractPacked(jar, modlist, modDirs);
|
||||||
}
|
}
|
||||||
catch (IOException ioe)
|
catch (IOException ioe)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Unable to read the jar file {} - ignoring", file.getName(), ioe);
|
LOGGER.error("Unable to read the jar file {} - ignoring", file.getName(), ioe);
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
@ -228,7 +234,7 @@ public class LibraryManager
|
||||||
attrs = jar.getManifest().getMainAttributes();
|
attrs = jar.getManifest().getMainAttributes();
|
||||||
|
|
||||||
String modSide = attrs.getValue(LibraryManager.MODSIDE);
|
String modSide = attrs.getValue(LibraryManager.MODSIDE);
|
||||||
if (modSide != null && !"BOTH".equals(modSide) && !FMLLaunchHandler.side().name().equals(modSide))
|
if (modSide != null && !"BOTH".equals(modSide) && !FMLEnvironment.dist.name().equals(modSide))
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
if (attrs.containsKey(MODCONTAINSDEPS))
|
if (attrs.containsKey(MODCONTAINSDEPS))
|
||||||
|
@ -237,7 +243,7 @@ public class LibraryManager
|
||||||
{
|
{
|
||||||
if (!dep.endsWith(".jar"))
|
if (!dep.endsWith(".jar"))
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Contained Dep is not a jar file: {}", dep);
|
LOGGER.error("Contained Dep is not a jar file: {}", dep);
|
||||||
throw new IllegalStateException("Invalid contained dep, Must be jar: " + dep);
|
throw new IllegalStateException("Invalid contained dep, Must be jar: " + dep);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -247,14 +253,14 @@ public class LibraryManager
|
||||||
JarEntry depEntry = jar.getJarEntry(dep);
|
JarEntry depEntry = jar.getJarEntry(dep);
|
||||||
if (depEntry == null)
|
if (depEntry == null)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Contained Dep is not in the jar: {}", dep);
|
LOGGER.error("Contained Dep is not in the jar: {}", dep);
|
||||||
throw new IllegalStateException("Invalid contained dep, Missing from jar: " + dep);
|
throw new IllegalStateException("Invalid contained dep, Missing from jar: " + dep);
|
||||||
}
|
}
|
||||||
|
|
||||||
String depEndName = new File(dep).getName(); // extract last part of name
|
String depEndName = new File(dep).getName(); // extract last part of name
|
||||||
if (skipContainedDeps.contains(dep) || skipContainedDeps.contains(depEndName))
|
if (skipContainedDeps.contains(dep) || skipContainedDeps.contains(depEndName))
|
||||||
{
|
{
|
||||||
FMLLog.log.error("Skipping dep at request: {}", dep);
|
LOGGER.error("Skipping dep at request: {}", dep);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,14 +300,14 @@ public class LibraryManager
|
||||||
File target = new File(dir, depEndName);
|
File target = new File(dir, depEndName);
|
||||||
if (target.exists())
|
if (target.exists())
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Found existing ContainDep extracted to {}, skipping extraction", target.getCanonicalPath());
|
LOGGER.debug("Found existing ContainDep extracted to {}, skipping extraction", target.getCanonicalPath());
|
||||||
found = true;
|
found = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!found)
|
if (!found)
|
||||||
{
|
{
|
||||||
File target = new File(modDirs[0], depEndName);
|
File target = new File(modDirs[0], depEndName);
|
||||||
FMLLog.log.debug("Extracting ContainedDep {} from {} to {}", dep, jar.getName(), target.getCanonicalPath());
|
LOGGER.debug("Extracting ContainedDep {} from {} to {}", dep, jar.getName(), target.getCanonicalPath());
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
Files.createParentDirs(target);
|
Files.createParentDirs(target);
|
||||||
|
@ -313,12 +319,12 @@ public class LibraryManager
|
||||||
{
|
{
|
||||||
ByteStreams.copy(in, out);
|
ByteStreams.copy(in, out);
|
||||||
}
|
}
|
||||||
FMLLog.log.debug("Extracted ContainedDep {} from {} to {}", dep, jar.getName(), target.getCanonicalPath());
|
LOGGER.debug("Extracted ContainedDep {} from {} to {}", dep, jar.getName(), target.getCanonicalPath());
|
||||||
extractPacked(target, modlist, modDirs);
|
extractPacked(target, modlist, modDirs);
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("An error occurred extracting dependency", e);
|
LOGGER.error("An error occurred extracting dependency", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -330,7 +336,7 @@ public class LibraryManager
|
||||||
File target = artifact.getFile();
|
File target = artifact.getFile();
|
||||||
if (target.exists())
|
if (target.exists())
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Found existing ContainedDep {}({}) from {} extracted to {}, skipping extraction", dep, artifact.toString(), target.getCanonicalPath(), jar.getName());
|
LOGGER.debug("Found existing ContainedDep {}({}) from {} extracted to {}, skipping extraction", dep, artifact.toString(), target.getCanonicalPath(), jar.getName());
|
||||||
if (!ENABLE_AUTO_MOD_MOVEMENT)
|
if (!ENABLE_AUTO_MOD_MOVEMENT)
|
||||||
{
|
{
|
||||||
Pair<?, ?> child = extractPacked(target, modlist, modDirs); //If we're not building a real list we have to re-build the dep list every run. So search down.
|
Pair<?, ?> child = extractPacked(target, modlist, modDirs); //If we're not building a real list we have to re-build the dep list every run. So search down.
|
||||||
|
@ -342,7 +348,7 @@ public class LibraryManager
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Extracting ContainedDep {}({}) from {} to {}", dep, artifact.toString(), jar.getName(), target.getCanonicalPath());
|
LOGGER.debug("Extracting ContainedDep {}({}) from {} to {}", dep, artifact.toString(), jar.getName(), target.getCanonicalPath());
|
||||||
Files.createParentDirs(target);
|
Files.createParentDirs(target);
|
||||||
try
|
try
|
||||||
(
|
(
|
||||||
|
@ -352,7 +358,7 @@ public class LibraryManager
|
||||||
{
|
{
|
||||||
ByteStreams.copy(in, out);
|
ByteStreams.copy(in, out);
|
||||||
}
|
}
|
||||||
FMLLog.log.debug("Extracted ContainedDep {}({}) from {} to {}", dep, artifact.toString(), jar.getName(), target.getCanonicalPath());
|
LOGGER.debug("Extracted ContainedDep {}({}) from {} to {}", dep, artifact.toString(), jar.getName(), target.getCanonicalPath());
|
||||||
|
|
||||||
if (artifact.isSnapshot())
|
if (artifact.isSnapshot())
|
||||||
{
|
{
|
||||||
|
@ -375,11 +381,11 @@ public class LibraryManager
|
||||||
}
|
}
|
||||||
catch (NumberFormatException nfe)
|
catch (NumberFormatException nfe)
|
||||||
{
|
{
|
||||||
FMLLog.log.error(FMLLog.log.getMessageFactory().newMessage("An error occurred extracting dependency. Invalid Timestamp: {}", meta.getValue(TIMESTAMP)), nfe);
|
LOGGER.error(LOGGER.getMessageFactory().newMessage("An error occurred extracting dependency. Invalid Timestamp: {}", meta.getValue(TIMESTAMP)), nfe);
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error("An error occurred extracting dependency", e);
|
LOGGER.error("An error occurred extracting dependency", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -443,26 +449,26 @@ public class LibraryManager
|
||||||
List<File> list = new ArrayList<>();
|
List<File> list = new ArrayList<>();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
Map<String,String> args = (Map<String, String>)Launch.blackboard.get("launchArgs");
|
Map<String,String> args = Collections.emptyMap(); // TODO Launch args - do we need this? (Map<String, String>)Launcher.INSTANCE.blackboard().get("launchArgs");
|
||||||
String extraMods = args.get("--mods");
|
String extraMods = args.get("--mods");
|
||||||
if (extraMods != null)
|
if (extraMods != null)
|
||||||
{
|
{
|
||||||
FMLLog.log.info("Found mods from the command line:");
|
LOGGER.info("Found mods from the command line:");
|
||||||
for (String mod : extraMods.split(","))
|
for (String mod : extraMods.split(","))
|
||||||
{
|
{
|
||||||
File file = new File(mcDir, mod);
|
File file = new File(mcDir, mod);
|
||||||
if (!file.exists())
|
if (!file.exists())
|
||||||
{
|
{
|
||||||
FMLLog.log.info(" Failed to find mod file {} ({})", mod, file.getAbsolutePath());
|
LOGGER.info(" Failed to find mod file {} ({})", mod, file.getAbsolutePath());
|
||||||
}
|
}
|
||||||
else if (!list.contains(file))
|
else if (!list.contains(file))
|
||||||
{
|
{
|
||||||
FMLLog.log.debug(" Adding {} ({}) to the mod list", mod, file.getAbsolutePath());
|
LOGGER.debug(" Adding {} ({}) to the mod list", mod, file.getAbsolutePath());
|
||||||
list.add(file);
|
list.add(file);
|
||||||
}
|
}
|
||||||
else if (!list.contains(file))
|
else if (!list.contains(file))
|
||||||
{
|
{
|
||||||
FMLLog.log.debug(" Duplicte command line mod detected {} ({})", mod, file.getAbsolutePath());
|
LOGGER.debug(" Duplicte command line mod detected {} ({})", mod, file.getAbsolutePath());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -473,12 +479,12 @@ public class LibraryManager
|
||||||
if (!base.isDirectory() || !base.exists())
|
if (!base.isDirectory() || !base.exists())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
FMLLog.log.info("Searching {} for mods", base.getAbsolutePath());
|
LOGGER.info("Searching {} for mods", base.getAbsolutePath());
|
||||||
for (File f : base.listFiles(MOD_FILENAME_FILTER))
|
for (File f : base.listFiles(MOD_FILENAME_FILTER))
|
||||||
{
|
{
|
||||||
if (!list.contains(f))
|
if (!list.contains(f))
|
||||||
{
|
{
|
||||||
FMLLog.log.debug(" Adding {} to the mod list", f.getName());
|
LOGGER.debug(" Adding {} to the mod list", f.getName());
|
||||||
list.add(f);
|
list.add(f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,10 +26,13 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
public class LinkRepository extends Repository
|
public class LinkRepository extends Repository
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private Map<String, File> artifact_to_file = new HashMap<>();
|
private Map<String, File> artifact_to_file = new HashMap<>();
|
||||||
private Map<String, File> filesystem = new HashMap<>();
|
private Map<String, File> filesystem = new HashMap<>();
|
||||||
private Map<String, Artifact> snapshots = new HashMap<>();
|
private Map<String, Artifact> snapshots = new HashMap<>();
|
||||||
|
@ -46,14 +49,14 @@ public class LinkRepository extends Repository
|
||||||
known.add(file);
|
known.add(file);
|
||||||
if (artifact_to_file.containsKey(key))
|
if (artifact_to_file.containsKey(key))
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Maven file already exists for {}({}) at {}, ignoring duplicate.", file.getName(), artifact.toString(), artifact_to_file.get(key).getAbsolutePath());
|
LOGGER.debug("Maven file already exists for {}({}) at {}, ignoring duplicate.", file.getName(), artifact.toString(), artifact_to_file.get(key).getAbsolutePath());
|
||||||
|
|
||||||
if (artifact.isSnapshot())
|
if (artifact.isSnapshot())
|
||||||
{
|
{
|
||||||
Artifact old = snapshots.get(key);
|
Artifact old = snapshots.get(key);
|
||||||
if (old == null || old.compareVersion(artifact) < 0)
|
if (old == null || old.compareVersion(artifact) < 0)
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Overriding Snapshot {} -> {}", old == null ? "null" : old.getTimestamp(), artifact.getTimestamp());
|
LOGGER.debug("Overriding Snapshot {} -> {}", old == null ? "null" : old.getTimestamp(), artifact.getTimestamp());
|
||||||
snapshots.put(key, artifact);
|
snapshots.put(key, artifact);
|
||||||
artifact_to_file.put(key, file);
|
artifact_to_file.put(key, file);
|
||||||
filesystem.put(artifact.getPath(), file);
|
filesystem.put(artifact.getPath(), file);
|
||||||
|
@ -62,7 +65,7 @@ public class LinkRepository extends Repository
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Making maven link for {} in memory to {}.", key, file.getAbsolutePath());
|
LOGGER.debug("Making maven link for {} in memory to {}.", key, file.getAbsolutePath());
|
||||||
artifact_to_file.put(key, file);
|
artifact_to_file.put(key, file);
|
||||||
filesystem.put(artifact.getPath(), file);
|
filesystem.put(artifact.getPath(), file);
|
||||||
|
|
||||||
|
|
|
@ -30,18 +30,21 @@ import java.util.Map;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.google.common.io.Files;
|
import com.google.common.io.Files;
|
||||||
import com.google.gson.Gson;
|
import com.google.gson.Gson;
|
||||||
import com.google.gson.GsonBuilder;
|
import com.google.gson.GsonBuilder;
|
||||||
import com.google.gson.JsonSyntaxException;
|
import com.google.gson.JsonSyntaxException;
|
||||||
|
|
||||||
import net.minecraft.launchwrapper.Launch;
|
|
||||||
import net.minecraftforge.common.ForgeVersion;
|
import net.minecraftforge.common.ForgeVersion;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
public class ModList
|
public class ModList
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private static final Gson GSON = new GsonBuilder().setLenient().create();
|
private static final Gson GSON = new GsonBuilder().setLenient().create();
|
||||||
static final Map<String, ModList> cache = new HashMap<>();
|
static final Map<String, ModList> cache = new HashMap<>();
|
||||||
|
|
||||||
|
@ -54,7 +57,7 @@ public class ModList
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error(FMLLog.log.getMessageFactory().newMessage("Unable to load ModList json at {}.", json.getAbsoluteFile()), e);
|
LOGGER.error(LOGGER.getMessageFactory().newMessage("Unable to load ModList json at {}.", json.getAbsoluteFile()), e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ModList(json, mcdir);
|
return new ModList(json, mcdir);
|
||||||
|
@ -63,7 +66,7 @@ public class ModList
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
public static List<ModList> getKnownLists(File mcdir)
|
public static List<ModList> getKnownLists(File mcdir)
|
||||||
{
|
{
|
||||||
for (String list : new String[] {"mods/mod_list.json", "mods/" + ForgeVersion.mcVersion + "/mod_list.json", ((Map<String, String>)Launch.blackboard.get("launchArgs")).get("--modListFile")})
|
for (String list : new String[] {"mods/mod_list.json", "mods/" + ForgeVersion.mcVersion + "/mod_list.json"/* , TODO Launch args ((Map<String, String>)Launch.blackboard.get("launchArgs")).get("--modListFile")*/})
|
||||||
{
|
{
|
||||||
if (list != null)
|
if (list != null)
|
||||||
{
|
{
|
||||||
|
@ -84,7 +87,7 @@ public class ModList
|
||||||
if (memory != null)
|
if (memory != null)
|
||||||
lst.add(memory);
|
lst.add(memory);
|
||||||
|
|
||||||
for (String list : new String[] {"mods/mod_list.json", "mods/" + ForgeVersion.mcVersion + "/mod_list.json", ((Map<String, String>)Launch.blackboard.get("launchArgs")).get("--modListFile")})
|
for (String list : new String[] {"mods/mod_list.json", "mods/" + ForgeVersion.mcVersion + "/mod_list.json"/* TODO Launch args, ((Map<String, String>)Launch.blackboard.get("launchArgs")).get("--modListFile")*/})
|
||||||
{
|
{
|
||||||
if (list != null)
|
if (list != null)
|
||||||
{
|
{
|
||||||
|
@ -127,11 +130,11 @@ public class ModList
|
||||||
}
|
}
|
||||||
catch (JsonSyntaxException jse)
|
catch (JsonSyntaxException jse)
|
||||||
{
|
{
|
||||||
FMLLog.log.info(FMLLog.log.getMessageFactory().newMessage("Failed to parse modList json file {}.", path), jse);
|
LOGGER.info(LOGGER.getMessageFactory().newMessage("Failed to parse modList json file {}.", path), jse);
|
||||||
}
|
}
|
||||||
catch (IOException ioe)
|
catch (IOException ioe)
|
||||||
{
|
{
|
||||||
FMLLog.log.info(FMLLog.log.getMessageFactory().newMessage("Failed to read modList json file {}.", path), ioe);
|
LOGGER.info(LOGGER.getMessageFactory().newMessage("Failed to read modList json file {}.", path), ioe);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.mod_list = temp_list == null ? new JsonModList() : temp_list;
|
this.mod_list = temp_list == null ? new JsonModList() : temp_list;
|
||||||
|
@ -148,7 +151,7 @@ public class ModList
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.info(FMLLog.log.getMessageFactory().newMessage("Failed to create repository for modlist at {}.", mod_list.repositoryRoot), e);
|
LOGGER.info(LOGGER.getMessageFactory().newMessage("Failed to create repository for modlist at {}.", mod_list.repositoryRoot), e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.repo = temp;
|
this.repo = temp;
|
||||||
|
@ -209,7 +212,7 @@ public class ModList
|
||||||
}
|
}
|
||||||
catch (IOException ioe)
|
catch (IOException ioe)
|
||||||
{
|
{
|
||||||
FMLLog.log.info(FMLLog.log.getMessageFactory().newMessage("Unable to canonicalize path {} relative to {}", path, root.getAbsolutePath()));
|
LOGGER.info(LOGGER.getMessageFactory().newMessage("Unable to canonicalize path {} relative to {}", path, root.getAbsolutePath()));
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,13 +25,16 @@ import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import com.google.common.hash.Hashing;
|
import com.google.common.hash.Hashing;
|
||||||
import com.google.common.io.Files;
|
import com.google.common.io.Files;
|
||||||
|
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
|
|
||||||
public class Repository
|
public class Repository
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
static final Map<String, Repository> cache = new LinkedHashMap<>();
|
static final Map<String, Repository> cache = new LinkedHashMap<>();
|
||||||
|
|
||||||
public static Repository create(File root) throws IOException
|
public static Repository create(File root) throws IOException
|
||||||
|
@ -129,12 +132,12 @@ public class Repository
|
||||||
{
|
{
|
||||||
if (target.exists())
|
if (target.exists())
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Maven file already exists for {}({}) at {}, deleting duplicate.", file.getName(), artifact.toString(), target.getAbsolutePath());
|
LOGGER.debug("Maven file already exists for {}({}) at {}, deleting duplicate.", file.getName(), artifact.toString(), target.getAbsolutePath());
|
||||||
file.delete();
|
file.delete();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Moving file {}({}) to maven repo at {}.", file.getName(), artifact.toString(), target.getAbsolutePath());
|
LOGGER.debug("Moving file {}({}) to maven repo at {}.", file.getName(), artifact.toString(), target.getAbsolutePath());
|
||||||
Files.move(file, target);
|
Files.move(file, target);
|
||||||
|
|
||||||
if (artifact.isSnapshot())
|
if (artifact.isSnapshot())
|
||||||
|
@ -154,7 +157,7 @@ public class Repository
|
||||||
}
|
}
|
||||||
catch (IOException e)
|
catch (IOException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.error(FMLLog.log.getMessageFactory().newMessage("Error moving file {} to {}", file, target.getAbsolutePath()), e);
|
LOGGER.error(LOGGER.getMessageFactory().newMessage("Error moving file {} to {}", file, target.getAbsolutePath()), e);
|
||||||
}
|
}
|
||||||
return file;
|
return file;
|
||||||
}
|
}
|
||||||
|
|
|
@ -133,19 +133,19 @@ public class ServerLifecycleHooks
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
FMLLog.log.info("Waiting for the server to terminate/save.");
|
LOGGER.info("Waiting for the server to terminate/save.");
|
||||||
if (!latch.await(10, TimeUnit.SECONDS))
|
if (!latch.await(10, TimeUnit.SECONDS))
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("The server didn't stop within 10 seconds, exiting anyway.");
|
LOGGER.warn("The server didn't stop within 10 seconds, exiting anyway.");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
FMLLog.log.info("Server terminated.");
|
LOGGER.info("Server terminated.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (InterruptedException e)
|
catch (InterruptedException e)
|
||||||
{
|
{
|
||||||
FMLLog.log.warn("Interrupted wait, exiting.");
|
LOGGER.warn("Interrupted wait, exiting.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -74,10 +74,11 @@ public class ItemHandlerHelper
|
||||||
|
|
||||||
// Metadata value only matters when the item has subtypes
|
// Metadata value only matters when the item has subtypes
|
||||||
// Vanilla stacks non-subtype items with different metadata together
|
// Vanilla stacks non-subtype items with different metadata together
|
||||||
// e.g. a stick with metadata 0 and a stick with metadata 1 stack
|
// TODO Item subtypes, is this still necessary?
|
||||||
|
/* e.g. a stick with metadata 0 and a stick with metadata 1 stack
|
||||||
if (a.getHasSubtypes() && a.getMetadata() != b.getMetadata())
|
if (a.getHasSubtypes() && a.getMetadata() != b.getMetadata())
|
||||||
return false;
|
return false;
|
||||||
|
*/
|
||||||
if (a.hasTagCompound() != b.hasTagCompound())
|
if (a.hasTagCompound() != b.hasTagCompound())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
|
@ -24,12 +24,13 @@ import net.minecraft.inventory.IInventory;
|
||||||
import net.minecraft.inventory.InventoryBasic;
|
import net.minecraft.inventory.InventoryBasic;
|
||||||
import net.minecraft.inventory.Slot;
|
import net.minecraft.inventory.Slot;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.util.text.TextComponentString;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
|
|
||||||
public class SlotItemHandler extends Slot
|
public class SlotItemHandler extends Slot
|
||||||
{
|
{
|
||||||
private static IInventory emptyInventory = new InventoryBasic("[Null]", true, 0);
|
private static IInventory emptyInventory = new InventoryBasic(new TextComponentString("[Null]"), 0);
|
||||||
private final IItemHandler itemHandler;
|
private final IItemHandler itemHandler;
|
||||||
private final int index;
|
private final int index;
|
||||||
|
|
||||||
|
@ -140,10 +141,10 @@ public class SlotItemHandler extends Slot
|
||||||
{
|
{
|
||||||
return itemHandler;
|
return itemHandler;
|
||||||
}
|
}
|
||||||
|
/* TODO Slot patches
|
||||||
@Override
|
@Override
|
||||||
public boolean isSameInventory(Slot other)
|
public boolean isSameInventory(Slot other)
|
||||||
{
|
{
|
||||||
return other instanceof SlotItemHandler && ((SlotItemHandler) other).getItemHandler() == this.itemHandler;
|
return other instanceof SlotItemHandler && ((SlotItemHandler) other).getItemHandler() == this.itemHandler;
|
||||||
}
|
}*/
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
package net.minecraftforge.items;
|
package net.minecraftforge.items;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.tileentity.TileEntityChest;
|
import net.minecraft.tileentity.TileEntityChest;
|
||||||
|
@ -58,7 +59,7 @@ public class VanillaDoubleChestItemHandler extends WeakReference<TileEntityChest
|
||||||
if (world == null || pos == null || !world.isBlockLoaded(pos))
|
if (world == null || pos == null || !world.isBlockLoaded(pos))
|
||||||
return null; // Still loading
|
return null; // Still loading
|
||||||
|
|
||||||
Block blockType = chest.getBlockType();
|
IBlockState state = chest.func_195044_w();
|
||||||
|
|
||||||
EnumFacing[] horizontals = EnumFacing.HORIZONTALS;
|
EnumFacing[] horizontals = EnumFacing.HORIZONTALS;
|
||||||
for (int i = horizontals.length - 1; i >= 0; i--) // Use reverse order so we can return early
|
for (int i = horizontals.length - 1; i >= 0; i--) // Use reverse order so we can return early
|
||||||
|
@ -67,7 +68,7 @@ public class VanillaDoubleChestItemHandler extends WeakReference<TileEntityChest
|
||||||
BlockPos blockpos = pos.offset(enumfacing);
|
BlockPos blockpos = pos.offset(enumfacing);
|
||||||
Block block = world.getBlockState(blockpos).getBlock();
|
Block block = world.getBlockState(blockpos).getBlock();
|
||||||
|
|
||||||
if (block == blockType)
|
if (block == state.getBlock())
|
||||||
{
|
{
|
||||||
TileEntity otherTE = world.getTileEntity(blockpos);
|
TileEntity otherTE = world.getTileEntity(blockpos);
|
||||||
|
|
||||||
|
@ -125,7 +126,7 @@ public class VanillaDoubleChestItemHandler extends WeakReference<TileEntityChest
|
||||||
TileEntityChest chest = getChest(accessingUpperChest);
|
TileEntityChest chest = getChest(accessingUpperChest);
|
||||||
if (chest != null)
|
if (chest != null)
|
||||||
{
|
{
|
||||||
IItemHandler singleHandler = chest.getSingleChestHandler();
|
IItemHandler singleHandler = null; // TODO TileEntityChest patches chest.getSingleChestHandler();
|
||||||
if (singleHandler instanceof IItemHandlerModifiable)
|
if (singleHandler instanceof IItemHandlerModifiable)
|
||||||
{
|
{
|
||||||
((IItemHandlerModifiable) singleHandler).setStackInSlot(targetSlot, stack);
|
((IItemHandlerModifiable) singleHandler).setStackInSlot(targetSlot, stack);
|
||||||
|
@ -148,7 +149,7 @@ public class VanillaDoubleChestItemHandler extends WeakReference<TileEntityChest
|
||||||
return stack;
|
return stack;
|
||||||
|
|
||||||
int starting = stack.getCount();
|
int starting = stack.getCount();
|
||||||
ItemStack ret = chest.getSingleChestHandler().insertItem(targetSlot, stack, simulate);
|
ItemStack ret = ItemStack.EMPTY; // TODO TileEntityChest patches chest.getSingleChestHandler().insertItem(targetSlot, stack, simulate);
|
||||||
if (ret.getCount() != starting && !simulate)
|
if (ret.getCount() != starting && !simulate)
|
||||||
{
|
{
|
||||||
chest = getChest(!accessingUpperChest);
|
chest = getChest(!accessingUpperChest);
|
||||||
|
@ -169,7 +170,7 @@ public class VanillaDoubleChestItemHandler extends WeakReference<TileEntityChest
|
||||||
if (chest == null)
|
if (chest == null)
|
||||||
return ItemStack.EMPTY;
|
return ItemStack.EMPTY;
|
||||||
|
|
||||||
ItemStack ret = chest.getSingleChestHandler().extractItem(targetSlot, amount, simulate);
|
ItemStack ret = ItemStack.EMPTY; // TODO TileEntityChest patches chest.getSingleChestHandler().extractItem(targetSlot, amount, simulate);
|
||||||
if (!ret.isEmpty() && !simulate)
|
if (!ret.isEmpty() && !simulate)
|
||||||
{
|
{
|
||||||
chest = getChest(!accessingUpperChest);
|
chest = getChest(!accessingUpperChest);
|
||||||
|
@ -195,7 +196,7 @@ public class VanillaDoubleChestItemHandler extends WeakReference<TileEntityChest
|
||||||
TileEntityChest chest = getChest(accessingUpperChest);
|
TileEntityChest chest = getChest(accessingUpperChest);
|
||||||
if (chest != null)
|
if (chest != null)
|
||||||
{
|
{
|
||||||
return chest.getSingleChestHandler().isItemValid(targetSlot, stack);
|
return false; // TODO TileEntityChest patches chest.getSingleChestHandler().isItemValid(targetSlot, stack);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,8 @@ import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.MathHelper;
|
import net.minecraft.util.math.MathHelper;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
import net.minecraftforge.common.capabilities.OptionalCapabilityInstance;
|
||||||
|
|
||||||
import org.apache.commons.lang3.tuple.ImmutablePair;
|
import org.apache.commons.lang3.tuple.ImmutablePair;
|
||||||
import org.apache.commons.lang3.tuple.Pair;
|
import org.apache.commons.lang3.tuple.Pair;
|
||||||
|
|
||||||
|
@ -46,10 +48,8 @@ public class VanillaInventoryCodeHooks
|
||||||
@Nullable
|
@Nullable
|
||||||
public static Boolean extractHook(IHopper dest)
|
public static Boolean extractHook(IHopper dest)
|
||||||
{
|
{
|
||||||
Pair<IItemHandler, Object> itemHandlerResult = getItemHandler(dest, EnumFacing.UP);
|
return getItemHandler(dest, EnumFacing.UP)
|
||||||
if (itemHandlerResult == null)
|
.map(itemHandlerResult -> {
|
||||||
return null;
|
|
||||||
|
|
||||||
IItemHandler handler = itemHandlerResult.getKey();
|
IItemHandler handler = itemHandlerResult.getKey();
|
||||||
|
|
||||||
for (int i = 0; i < handler.getSlots(); i++)
|
for (int i = 0; i < handler.getSlots(); i++)
|
||||||
|
@ -78,6 +78,8 @@ public class VanillaInventoryCodeHooks
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
})
|
||||||
|
.orElse(null); // TODO bad null
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -87,13 +89,8 @@ public class VanillaInventoryCodeHooks
|
||||||
{
|
{
|
||||||
EnumFacing enumfacing = world.getBlockState(pos).getValue(BlockDropper.FACING);
|
EnumFacing enumfacing = world.getBlockState(pos).getValue(BlockDropper.FACING);
|
||||||
BlockPos blockpos = pos.offset(enumfacing);
|
BlockPos blockpos = pos.offset(enumfacing);
|
||||||
Pair<IItemHandler, Object> destinationResult = getItemHandler(world, (double) blockpos.getX(), (double) blockpos.getY(), (double) blockpos.getZ(), enumfacing.getOpposite());
|
return getItemHandler(world, (double) blockpos.getX(), (double) blockpos.getY(), (double) blockpos.getZ(), enumfacing.getOpposite())
|
||||||
if (destinationResult == null)
|
.map(destinationResult -> {
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
IItemHandler itemHandler = destinationResult.getKey();
|
IItemHandler itemHandler = destinationResult.getKey();
|
||||||
Object destination = destinationResult.getValue();
|
Object destination = destinationResult.getValue();
|
||||||
ItemStack dispensedStack = stack.copy().splitStack(1);
|
ItemStack dispensedStack = stack.copy().splitStack(1);
|
||||||
|
@ -111,7 +108,8 @@ public class VanillaInventoryCodeHooks
|
||||||
|
|
||||||
dropper.setInventorySlotContents(slot, remainder);
|
dropper.setInventorySlotContents(slot, remainder);
|
||||||
return false;
|
return false;
|
||||||
}
|
})
|
||||||
|
.orElse(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -119,14 +117,9 @@ public class VanillaInventoryCodeHooks
|
||||||
*/
|
*/
|
||||||
public static boolean insertHook(TileEntityHopper hopper)
|
public static boolean insertHook(TileEntityHopper hopper)
|
||||||
{
|
{
|
||||||
EnumFacing hopperFacing = BlockHopper.getFacing(hopper.getBlockMetadata());
|
EnumFacing hopperFacing = hopper.func_195044_w().getValue(BlockHopper.FACING);
|
||||||
Pair<IItemHandler, Object> destinationResult = getItemHandler(hopper, hopperFacing);
|
return getItemHandler(hopper, hopperFacing)
|
||||||
if (destinationResult == null)
|
.map(destinationResult -> {
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
IItemHandler itemHandler = destinationResult.getKey();
|
IItemHandler itemHandler = destinationResult.getKey();
|
||||||
Object destination = destinationResult.getValue();
|
Object destination = destinationResult.getValue();
|
||||||
if (isFull(itemHandler))
|
if (isFull(itemHandler))
|
||||||
|
@ -154,7 +147,8 @@ public class VanillaInventoryCodeHooks
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
})
|
||||||
|
.orElse(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ItemStack putStackInInventoryAllSlots(TileEntity source, Object destination, IItemHandler destInventory, ItemStack stack)
|
private static ItemStack putStackInInventoryAllSlots(TileEntity source, Object destination, IItemHandler destInventory, ItemStack stack)
|
||||||
|
@ -200,7 +194,7 @@ public class VanillaInventoryCodeHooks
|
||||||
if (!destinationHopper.mayTransfer())
|
if (!destinationHopper.mayTransfer())
|
||||||
{
|
{
|
||||||
int k = 0;
|
int k = 0;
|
||||||
|
/* TODO TileEntityHopper patches
|
||||||
if (source instanceof TileEntityHopper)
|
if (source instanceof TileEntityHopper)
|
||||||
{
|
{
|
||||||
if (destinationHopper.getLastUpdateTime() >= ((TileEntityHopper) source).getLastUpdateTime())
|
if (destinationHopper.getLastUpdateTime() >= ((TileEntityHopper) source).getLastUpdateTime())
|
||||||
|
@ -208,7 +202,7 @@ public class VanillaInventoryCodeHooks
|
||||||
k = 1;
|
k = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
destinationHopper.setTransferCooldown(8 - k);
|
destinationHopper.setTransferCooldown(8 - k);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -218,12 +212,11 @@ public class VanillaInventoryCodeHooks
|
||||||
return stack;
|
return stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
private static OptionalCapabilityInstance<Pair<IItemHandler, Object>> getItemHandler(IHopper hopper, EnumFacing hopperFacing)
|
||||||
private static Pair<IItemHandler, Object> getItemHandler(IHopper hopper, EnumFacing hopperFacing)
|
|
||||||
{
|
{
|
||||||
double x = hopper.getXPos() + (double) hopperFacing.getFrontOffsetX();
|
double x = hopper.getXPos() + (double) hopperFacing.getXOffset();
|
||||||
double y = hopper.getYPos() + (double) hopperFacing.getFrontOffsetY();
|
double y = hopper.getYPos() + (double) hopperFacing.getYOffset();
|
||||||
double z = hopper.getZPos() + (double) hopperFacing.getFrontOffsetZ();
|
double z = hopper.getZPos() + (double) hopperFacing.getZOffset();
|
||||||
return getItemHandler(hopper.getWorld(), x, y, z, hopperFacing.getOpposite());
|
return getItemHandler(hopper.getWorld(), x, y, z, hopperFacing.getOpposite());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,10 +246,8 @@ public class VanillaInventoryCodeHooks
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
public static OptionalCapabilityInstance<Pair<IItemHandler, Object>> getItemHandler(World worldIn, double x, double y, double z, final EnumFacing side)
|
||||||
public static Pair<IItemHandler, Object> getItemHandler(World worldIn, double x, double y, double z, final EnumFacing side)
|
|
||||||
{
|
{
|
||||||
Pair<IItemHandler, Object> destination = null;
|
|
||||||
int i = MathHelper.floor(x);
|
int i = MathHelper.floor(x);
|
||||||
int j = MathHelper.floor(y);
|
int j = MathHelper.floor(y);
|
||||||
int k = MathHelper.floor(z);
|
int k = MathHelper.floor(z);
|
||||||
|
@ -264,19 +255,16 @@ public class VanillaInventoryCodeHooks
|
||||||
net.minecraft.block.state.IBlockState state = worldIn.getBlockState(blockpos);
|
net.minecraft.block.state.IBlockState state = worldIn.getBlockState(blockpos);
|
||||||
Block block = state.getBlock();
|
Block block = state.getBlock();
|
||||||
|
|
||||||
if (block.hasTileEntity(state))
|
if (block.hasTileEntity(/* TODO Block patches // state */))
|
||||||
{
|
{
|
||||||
TileEntity tileentity = worldIn.getTileEntity(blockpos);
|
TileEntity tileentity = worldIn.getTileEntity(blockpos);
|
||||||
if (tileentity != null)
|
if (tileentity != null)
|
||||||
{
|
{
|
||||||
if (tileentity.hasCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, side))
|
return tileentity.getCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, side)
|
||||||
{
|
.map(capability -> ImmutablePair.<IItemHandler, Object>of(capability, tileentity));
|
||||||
IItemHandler capability = tileentity.getCapability(CapabilityItemHandler.ITEM_HANDLER_CAPABILITY, side);
|
|
||||||
destination = ImmutablePair.<IItemHandler, Object>of(capability, tileentity);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return destination;
|
return OptionalCapabilityInstance.empty();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -98,17 +98,17 @@ public class ModelLoaderErrorMessage extends SimpleMessage
|
||||||
if(exception instanceof ModelLoader.ItemLoadingException)
|
if(exception instanceof ModelLoader.ItemLoadingException)
|
||||||
{
|
{
|
||||||
ModelLoader.ItemLoadingException ex = (ModelLoader.ItemLoadingException)exception;
|
ModelLoader.ItemLoadingException ex = (ModelLoader.ItemLoadingException)exception;
|
||||||
// FMLLog.log.error("{}, normal location exception: ", errorMsg, ex.normalException);
|
// LOGGER.error("{}, normal location exception: ", errorMsg, ex.normalException);
|
||||||
// FMLLog.log.error("{}, blockstate location exception: ", errorMsg, ex.blockstateException);
|
// LOGGER.error("{}, blockstate location exception: ", errorMsg, ex.blockstateException);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// FMLLog.log.error(errorMsg, entry.getValue());
|
// LOGGER.error(errorMsg, entry.getValue());
|
||||||
}
|
}
|
||||||
// ResourceLocation blockstateLocation = new ResourceLocation(resourceLocation.getResourceDomain(), resourceLocation.getResourcePath());
|
// ResourceLocation blockstateLocation = new ResourceLocation(resourceLocation.getResourceDomain(), resourceLocation.getResourcePath());
|
||||||
// if(loadingExceptions.containsKey(blockstateLocation) && !printedBlockStateErrors.contains(blockstateLocation))
|
// if(loadingExceptions.containsKey(blockstateLocation) && !printedBlockStateErrors.contains(blockstateLocation))
|
||||||
// {
|
// {
|
||||||
// FMLLog.log.error("Exception loading blockstate for the variant {}: ", location, loadingExceptions.get(blockstateLocation));
|
// LOGGER.error("Exception loading blockstate for the variant {}: ", location, loadingExceptions.get(blockstateLocation));
|
||||||
// printedBlockStateErrors.add(blockstateLocation);
|
// printedBlockStateErrors.add(blockstateLocation);
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package net.minecraftforge.oredict;
|
package net.minecraftforge.oredict;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -53,7 +52,6 @@ import net.minecraftforge.fml.common.Loader;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class OreDictionary
|
public class OreDictionary
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -381,7 +379,7 @@ public class OreDictionary
|
||||||
ItemStack.EMPTY //So the above can have a comma and we don't have to keep editing extra lines.
|
ItemStack.EMPTY //So the above can have a comma and we don't have to keep editing extra lines.
|
||||||
};
|
};
|
||||||
|
|
||||||
FMLLog.log.info("Starts to replace vanilla recipe ingredients with ore ingredients.");
|
LOGGER.info("Starts to replace vanilla recipe ingredients with ore ingredients.");
|
||||||
int replaced = 0;
|
int replaced = 0;
|
||||||
// Search vanilla recipes for recipes to replace
|
// Search vanilla recipes for recipes to replace
|
||||||
for(IRecipe obj : CraftingManager.REGISTRY)
|
for(IRecipe obj : CraftingManager.REGISTRY)
|
||||||
|
@ -413,7 +411,7 @@ public class OreDictionary
|
||||||
matches = true;
|
matches = true;
|
||||||
if (oreName != null && !oreName.equals(ent.getValue()))
|
if (oreName != null && !oreName.equals(ent.getValue()))
|
||||||
{
|
{
|
||||||
FMLLog.log.info("Invalid recipe found with multiple oredict ingredients in the same ingredient..."); //TODO: Write a dumper?
|
LOGGER.info("Invalid recipe found with multiple oredict ingredients in the same ingredient..."); //TODO: Write a dumper?
|
||||||
skip = true;
|
skip = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -441,14 +439,14 @@ public class OreDictionary
|
||||||
if(DEBUG && replacedIngs.add(ing))
|
if(DEBUG && replacedIngs.add(ing))
|
||||||
{
|
{
|
||||||
String recipeName = obj.getRegistryName().getResourcePath();
|
String recipeName = obj.getRegistryName().getResourcePath();
|
||||||
FMLLog.log.debug("Replaced {} of the recipe \'{}\' with \"{}\".", ing.getMatchingStacks(), recipeName, oreName);
|
LOGGER.debug("Replaced {} of the recipe \'{}\' with \"{}\".", ing.getMatchingStacks(), recipeName, oreName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
FMLLog.log.info("Replaced {} ore ingredients", replaced);
|
LOGGER.info("Replaced {} ore ingredients", replaced);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -504,7 +502,7 @@ public class OreDictionary
|
||||||
int id;
|
int id;
|
||||||
if (registryName == null)
|
if (registryName == null)
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Attempted to find the oreIDs for an unregistered object ({}). This won't work very well.", stack);
|
LOGGER.debug("Attempted to find the oreIDs for an unregistered object ({}). This won't work very well.", stack);
|
||||||
return new int[0];
|
return new int[0];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -736,7 +734,7 @@ public class OreDictionary
|
||||||
int hash;
|
int hash;
|
||||||
if (name == null)
|
if (name == null)
|
||||||
{
|
{
|
||||||
FMLLog.log.debug("Defaulting unregistered ore dictionary entry for ore dictionary {}: type {} to -1", getOreName(id), ore.getItem().getClass());
|
LOGGER.debug("Defaulting unregistered ore dictionary entry for ore dictionary {}: type {} to -1", getOreName(id), ore.getItem().getClass());
|
||||||
hash = -1;
|
hash = -1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package net.minecraftforge.oredict;
|
package net.minecraftforge.oredict;
|
||||||
|
/*
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ import net.minecraft.creativetab.CreativeTabs;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
import net.minecraft.util.NonNullList;
|
import net.minecraft.util.NonNullList;
|
||||||
|
*/
|
||||||
public class OreIngredient //extends Ingredient
|
public class OreIngredient //extends Ingredient
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package net.minecraftforge.oredict;
|
package net.minecraftforge.oredict;
|
||||||
|
/*
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.client.util.RecipeItemHelper;
|
import net.minecraft.client.util.RecipeItemHelper;
|
||||||
|
@ -42,7 +42,7 @@ import com.google.common.collect.Lists;
|
||||||
import com.google.gson.JsonElement;
|
import com.google.gson.JsonElement;
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import com.google.gson.JsonParseException;
|
import com.google.gson.JsonParseException;
|
||||||
|
*/
|
||||||
public class ShapelessOreRecipe {} /*extends IForgeRegistryEntry.Impl<IRecipe> implements IRecipe
|
public class ShapelessOreRecipe {} /*extends IForgeRegistryEntry.Impl<IRecipe> implements IRecipe
|
||||||
{
|
{
|
||||||
@Nonnull
|
@Nonnull
|
||||||
|
|
|
@ -22,6 +22,7 @@ package net.minecraftforge.registries;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.enchantment.Enchantment;
|
import net.minecraft.enchantment.Enchantment;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
|
import net.minecraft.entity.EntityType;
|
||||||
import net.minecraft.init.Bootstrap;
|
import net.minecraft.init.Bootstrap;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.crafting.IRecipe;
|
import net.minecraft.item.crafting.IRecipe;
|
||||||
|
@ -50,10 +51,9 @@ public class ForgeRegistries
|
||||||
public static final IForgeRegistry<PotionType> POTION_TYPES = RegistryManager.ACTIVE.getRegistry(PotionType.class);
|
public static final IForgeRegistry<PotionType> POTION_TYPES = RegistryManager.ACTIVE.getRegistry(PotionType.class);
|
||||||
public static final IForgeRegistry<Enchantment> ENCHANTMENTS = RegistryManager.ACTIVE.getRegistry(Enchantment.class);
|
public static final IForgeRegistry<Enchantment> ENCHANTMENTS = RegistryManager.ACTIVE.getRegistry(Enchantment.class);
|
||||||
public static final IForgeRegistry<VillagerProfession> VILLAGER_PROFESSIONS = RegistryManager.ACTIVE.getRegistry(VillagerProfession.class);
|
public static final IForgeRegistry<VillagerProfession> VILLAGER_PROFESSIONS = RegistryManager.ACTIVE.getRegistry(VillagerProfession.class);
|
||||||
public static final IForgeRegistry<EntityEntry> ENTITIES = RegistryManager.ACTIVE.getRegistry(EntityEntry.class);
|
public static final IForgeRegistry<EntityType<?>> ENTITIES = RegistryManager.ACTIVE.getRegistry(EntityType.class);
|
||||||
public static final IForgeRegistry<IRecipe> RECIPES = RegistryManager.ACTIVE.getRegistry(IRecipe.class);
|
public static final IForgeRegistry<IRecipe> RECIPES = RegistryManager.ACTIVE.getRegistry(IRecipe.class);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This function is just to make sure static inializers in other classes have run and setup their registries before we query them.
|
* This function is just to make sure static inializers in other classes have run and setup their registries before we query them.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -28,6 +28,7 @@ import net.minecraft.block.BlockAir;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.enchantment.Enchantment;
|
import net.minecraft.enchantment.Enchantment;
|
||||||
|
import net.minecraft.entity.EntityType;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemBlock;
|
import net.minecraft.item.ItemBlock;
|
||||||
import net.minecraft.potion.Potion;
|
import net.minecraft.potion.Potion;
|
||||||
|
@ -42,6 +43,7 @@ import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.event.RegistryEvent;
|
import net.minecraftforge.event.RegistryEvent;
|
||||||
import net.minecraftforge.event.RegistryEvent.MissingMappings;
|
import net.minecraftforge.event.RegistryEvent.MissingMappings;
|
||||||
import net.minecraftforge.fml.common.EnhancedRuntimeException;
|
import net.minecraftforge.fml.common.EnhancedRuntimeException;
|
||||||
|
import net.minecraftforge.fml.common.registry.VillagerRegistry.VillagerProfession;
|
||||||
import net.minecraftforge.fml.ModThreadContext;
|
import net.minecraftforge.fml.ModThreadContext;
|
||||||
import net.minecraftforge.fml.StartupQuery;
|
import net.minecraftforge.fml.StartupQuery;
|
||||||
|
|
||||||
|
@ -127,8 +129,9 @@ public class GameData
|
||||||
makeRegistry(POTIONTYPES, PotionType.class, MAX_POTIONTYPE_ID, new ResourceLocation("empty")).create();
|
makeRegistry(POTIONTYPES, PotionType.class, MAX_POTIONTYPE_ID, new ResourceLocation("empty")).create();
|
||||||
makeRegistry(ENCHANTMENTS, Enchantment.class, MAX_ENCHANTMENT_ID).create();
|
makeRegistry(ENCHANTMENTS, Enchantment.class, MAX_ENCHANTMENT_ID).create();
|
||||||
// makeRegistry(RECIPES, IRecipe.class, MAX_RECIPE_ID).disableSaving().allowModification().addCallback(RecipeCallbacks.INSTANCE).create();
|
// makeRegistry(RECIPES, IRecipe.class, MAX_RECIPE_ID).disableSaving().allowModification().addCallback(RecipeCallbacks.INSTANCE).create();
|
||||||
// makeRegistry(PROFESSIONS, VillagerProfession.class, MAX_PROFESSION_ID).create();
|
makeRegistry(PROFESSIONS, VillagerProfession.class, MAX_PROFESSION_ID).create();
|
||||||
// entityRegistry = (ForgeRegistry<EntityEntry>)makeRegistry(ENTITIES, EntityEntry.class, MAX_ENTITY_ID).addCallback(EntityCallbacks.INSTANCE).create();
|
// TODO do we need the callback and the static field anymore?
|
||||||
|
makeRegistry(ENTITIES, EntityType.class, MAX_ENTITY_ID).create();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static <T extends IForgeRegistryEntry<T>> RegistryBuilder<T> makeRegistry(ResourceLocation name, Class<T> type, int min, int max)
|
private static <T extends IForgeRegistryEntry<T>> RegistryBuilder<T> makeRegistry(ResourceLocation name, Class<T> type, int min, int max)
|
||||||
|
|
|
@ -46,7 +46,7 @@ public enum ObjectHolderRegistry
|
||||||
INSTANCE;
|
INSTANCE;
|
||||||
private static final Logger LOGGER = LogManager.getLogger();
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
private List<ObjectHolderRef> objectHolders = Lists.newArrayList();
|
private List<ObjectHolderRef> objectHolders = Lists.newArrayList();
|
||||||
|
/* TODO annotation data
|
||||||
public void findObjectHolders(ASMDataTable table)
|
public void findObjectHolders(ASMDataTable table)
|
||||||
{
|
{
|
||||||
LOGGER.info("Processing ObjectHolder annotations");
|
LOGGER.info("Processing ObjectHolder annotations");
|
||||||
|
@ -69,7 +69,7 @@ public enum ObjectHolderRegistry
|
||||||
});
|
});
|
||||||
LOGGER.info("Found {} ObjectHolder annotations", objectHolders.size());
|
LOGGER.info("Found {} ObjectHolder annotations", objectHolders.size());
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
private void scanTarget(Map<String, String> classModIds, Map<String, Class<?>> classCache, String className, @Nullable String annotationTarget, String value, boolean isClass, boolean extractFromValue)
|
private void scanTarget(Map<String, String> classModIds, Map<String, Class<?>> classCache, String className, @Nullable String annotationTarget, String value, boolean isClass, boolean extractFromValue)
|
||||||
{
|
{
|
||||||
Class<?> clazz;
|
Class<?> clazz;
|
||||||
|
|
|
@ -41,12 +41,12 @@ public class TextComponentHelper
|
||||||
{
|
{
|
||||||
if (isVanillaClient(source))
|
if (isVanillaClient(source))
|
||||||
{
|
{
|
||||||
return new TextComponentString(LanguageMap.getInstance().translateKey(translation, args));
|
return new TextComponentString(String.format(LanguageMap.getInstance().translateKey(translation), args));
|
||||||
}
|
}
|
||||||
return new TextComponentTranslation(translation, args);
|
return new TextComponentTranslation(translation, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isVanillaClient(ICommandSender sender)
|
private static boolean isVanillaClient(ICommandSource sender)
|
||||||
{
|
{
|
||||||
if (sender instanceof EntityPlayerMP)
|
if (sender instanceof EntityPlayerMP)
|
||||||
{
|
{
|
||||||
|
|
|
@ -22,8 +22,10 @@ package net.minecraftforge.server.console;
|
||||||
import static com.google.common.base.Preconditions.checkNotNull;
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.concurrent.ExecutionException;
|
||||||
import java.util.concurrent.Future;
|
import java.util.concurrent.Future;
|
||||||
|
import java.util.concurrent.FutureTask;
|
||||||
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
|
@ -60,7 +62,7 @@ final class ConsoleCommandCompleter implements Completer
|
||||||
}
|
}
|
||||||
|
|
||||||
final String input = buffer;
|
final String input = buffer;
|
||||||
Future<List<String>> tabComplete = this.server.callFromMainThread(() -> this.server.getTabCompletions(this.server, input, this.server.getPosition(), false));
|
Future<List<String>> tabComplete = new FutureTask<>(() -> Collections.emptyList());// TODO commands this.server.callFromMainThread(() -> this.server.getTabCompletions(this.server, input, this.server.getPosition(), false));
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -71,9 +71,9 @@ public final class TerminalHandler
|
||||||
|
|
||||||
line = line.trim();
|
line = line.trim();
|
||||||
if (!line.isEmpty())
|
if (!line.isEmpty())
|
||||||
{
|
{/* TODO Commands
|
||||||
server.addPendingCommand(line, server);
|
server.addPendingCommand(line, server);
|
||||||
}
|
*/}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (UserInterruptException e)
|
catch (UserInterruptException e)
|
||||||
|
|
|
@ -21,7 +21,6 @@ package net.minecraftforge.server.permission;
|
||||||
|
|
||||||
import com.mojang.authlib.GameProfile;
|
import com.mojang.authlib.GameProfile;
|
||||||
import net.minecraft.server.MinecraftServer;
|
import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraftforge.fml.common.FMLCommonHandler;
|
|
||||||
import net.minecraftforge.server.permission.context.IContext;
|
import net.minecraftforge.server.permission.context.IContext;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
@ -72,7 +71,7 @@ public enum DefaultPermissionHandler implements IPermissionHandler
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
MinecraftServer server = FMLCommonHandler.instance().getMinecraftServerInstance();
|
MinecraftServer server = null; // TODO FMLCommonHandler FMLCommonHandler.instance().getMinecraftServerInstance();
|
||||||
return server != null && server.getPlayerList().canSendCommands(profile);
|
return server != null && server.getPlayerList().canSendCommands(profile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,15 +22,18 @@ package net.minecraftforge.server.permission;
|
||||||
import com.google.common.base.Preconditions;
|
import com.google.common.base.Preconditions;
|
||||||
import com.mojang.authlib.GameProfile;
|
import com.mojang.authlib.GameProfile;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
|
||||||
import net.minecraftforge.fml.common.Loader;
|
|
||||||
import net.minecraftforge.server.permission.context.IContext;
|
import net.minecraftforge.server.permission.context.IContext;
|
||||||
import net.minecraftforge.server.permission.context.PlayerContext;
|
import net.minecraftforge.server.permission.context.PlayerContext;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.LogManager;
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
public class PermissionAPI
|
public class PermissionAPI
|
||||||
{
|
{
|
||||||
|
private static final Logger LOGGER = LogManager.getLogger();
|
||||||
|
|
||||||
private static IPermissionHandler permissionHandler = DefaultPermissionHandler.INSTANCE;
|
private static IPermissionHandler permissionHandler = DefaultPermissionHandler.INSTANCE;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -39,8 +42,8 @@ public class PermissionAPI
|
||||||
public static void setPermissionHandler(IPermissionHandler handler)
|
public static void setPermissionHandler(IPermissionHandler handler)
|
||||||
{
|
{
|
||||||
Preconditions.checkNotNull(handler, "Permission handler can't be null!");
|
Preconditions.checkNotNull(handler, "Permission handler can't be null!");
|
||||||
Preconditions.checkState(Loader.instance().getLoaderState().ordinal() <= LoaderState.PREINITIALIZATION.ordinal(), "Can't register after IPermissionHandler PreInit!");
|
// TODO Loader states Preconditions.checkState(Loader.instance().getLoaderState().ordinal() <= LoaderState.PREINITIALIZATION.ordinal(), "Can't register after IPermissionHandler PreInit!");
|
||||||
FMLLog.log.warn("Replacing {} with {}", permissionHandler.getClass().getName(), handler.getClass().getName());
|
LOGGER.warn("Replacing {} with {}", permissionHandler.getClass().getName(), handler.getClass().getName());
|
||||||
permissionHandler = handler;
|
permissionHandler = handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +65,7 @@ public class PermissionAPI
|
||||||
Preconditions.checkNotNull(level, "Permission level can't be null!");
|
Preconditions.checkNotNull(level, "Permission level can't be null!");
|
||||||
Preconditions.checkNotNull(desc, "Permission description can't be null!");
|
Preconditions.checkNotNull(desc, "Permission description can't be null!");
|
||||||
Preconditions.checkArgument(!node.isEmpty(), "Permission node can't be empty!");
|
Preconditions.checkArgument(!node.isEmpty(), "Permission node can't be empty!");
|
||||||
Preconditions.checkState(Loader.instance().getLoaderState().ordinal() > LoaderState.PREINITIALIZATION.ordinal(), "Can't register permission nodes before Init!");
|
// TODO Loader states Preconditions.checkState(Loader.instance().getLoaderState().ordinal() > LoaderState.PREINITIALIZATION.ordinal(), "Can't register permission nodes before Init!");
|
||||||
permissionHandler.registerNode(node, level, desc);
|
permissionHandler.registerNode(node, level, desc);
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue