mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-17 23:01:01 +01:00
More vanilla friendly methods to update trades
This commit is contained in:
parent
9db4bb7ac6
commit
533bc0c468
2 changed files with 66 additions and 12 deletions
|
@ -24,25 +24,25 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -214,7 +222,18 @@
|
@@ -216,7 +224,18 @@
|
||||||
|
|
||||||
public boolean assignProfessionWhenSpawned() {
|
|
||||||
return this.assignProfessionWhenSpawned;
|
return this.assignProfessionWhenSpawned;
|
||||||
+ }
|
}
|
||||||
+
|
|
||||||
+ // Spigot Start
|
+ // Spigot Start
|
||||||
+ @Override
|
@Override
|
||||||
+ public void inactiveTick() {
|
+ public void inactiveTick() {
|
||||||
+ // SPIGOT-3874, SPIGOT-3894, SPIGOT-3846, SPIGOT-5286 :(
|
+ // SPIGOT-3874, SPIGOT-3894, SPIGOT-3846, SPIGOT-5286 :(
|
||||||
+ if (this.level().spigotConfig.tickInactiveVillagers && this.isEffectiveAi()) {
|
+ if (this.level().spigotConfig.tickInactiveVillagers && this.isEffectiveAi()) {
|
||||||
+ this.customServerAiStep((ServerLevel) this.level());
|
+ this.customServerAiStep((ServerLevel) this.level());
|
||||||
+ }
|
+ }
|
||||||
+ super.inactiveTick();
|
+ super.inactiveTick();
|
||||||
}
|
+ }
|
||||||
+ // Spigot End
|
+ // Spigot End
|
||||||
|
+
|
||||||
@Override
|
+ @Override
|
||||||
protected void customServerAiStep(ServerLevel world) {
|
protected void customServerAiStep(ServerLevel world) {
|
||||||
|
ProfilerFiller gameprofilerfiller = Profiler.get();
|
||||||
|
|
||||||
@@ -235,7 +254,7 @@
|
@@ -235,7 +254,7 @@
|
||||||
this.increaseProfessionLevelOnUpdate = false;
|
this.increaseProfessionLevelOnUpdate = false;
|
||||||
}
|
}
|
||||||
|
@ -156,7 +156,33 @@
|
||||||
|
|
||||||
if (entitywitch == null) {
|
if (entitywitch == null) {
|
||||||
super.thunderHit(world, lightning);
|
super.thunderHit(world, lightning);
|
||||||
@@ -906,7 +946,7 @@
|
@@ -855,6 +895,12 @@
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void updateTrades() {
|
||||||
|
+ // Paper start - More vanilla friendly methods to update trades
|
||||||
|
+ updateTrades(TRADES_PER_LEVEL);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ public boolean updateTrades(int amount) {
|
||||||
|
+ // Paper end - More vanilla friendly methods to update trades
|
||||||
|
VillagerData villagerdata = this.getVillagerData();
|
||||||
|
Int2ObjectMap int2objectmap;
|
||||||
|
|
||||||
|
@@ -872,9 +918,11 @@
|
||||||
|
if (avillagertrades_imerchantrecipeoption != null) {
|
||||||
|
MerchantOffers merchantrecipelist = this.getOffers();
|
||||||
|
|
||||||
|
- this.addOffersFromItemListings(merchantrecipelist, avillagertrades_imerchantrecipeoption, 2);
|
||||||
|
+ this.addOffersFromItemListings(merchantrecipelist, avillagertrades_imerchantrecipeoption, amount); // Paper - More vanilla friendly methods to update trades
|
||||||
|
+ return true; // Paper - More vanilla friendly methods to update trades
|
||||||
|
}
|
||||||
|
}
|
||||||
|
+ return false; // Paper - More vanilla friendly methods to update trades
|
||||||
|
}
|
||||||
|
|
||||||
|
public void gossip(ServerLevel world, Villager villager, long time) {
|
||||||
|
@@ -906,7 +954,7 @@
|
||||||
}).limit(5L).toList();
|
}).limit(5L).toList();
|
||||||
|
|
||||||
if (list1.size() >= requiredCount) {
|
if (list1.size() >= requiredCount) {
|
||||||
|
@ -165,7 +191,7 @@
|
||||||
list.forEach(GolemSensor::golemDetected);
|
list.forEach(GolemSensor::golemDetected);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -963,7 +1003,7 @@
|
@@ -963,7 +1011,7 @@
|
||||||
@Override
|
@Override
|
||||||
public void startSleeping(BlockPos pos) {
|
public void startSleeping(BlockPos pos) {
|
||||||
super.startSleeping(pos);
|
super.startSleeping(pos);
|
||||||
|
@ -174,7 +200,7 @@
|
||||||
this.brain.eraseMemory(MemoryModuleType.WALK_TARGET);
|
this.brain.eraseMemory(MemoryModuleType.WALK_TARGET);
|
||||||
this.brain.eraseMemory(MemoryModuleType.CANT_REACH_WALK_TARGET_SINCE);
|
this.brain.eraseMemory(MemoryModuleType.CANT_REACH_WALK_TARGET_SINCE);
|
||||||
}
|
}
|
||||||
@@ -971,7 +1011,7 @@
|
@@ -971,7 +1019,7 @@
|
||||||
@Override
|
@Override
|
||||||
public void stopSleeping() {
|
public void stopSleeping() {
|
||||||
super.stopSleeping();
|
super.stopSleeping();
|
||||||
|
|
|
@ -98,6 +98,34 @@ public class CraftVillager extends CraftAbstractVillager implements Villager {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Paper start
|
// Paper start
|
||||||
|
@Override
|
||||||
|
public boolean increaseLevel(int amount) {
|
||||||
|
Preconditions.checkArgument(amount > 0, "Level earned must be positive");
|
||||||
|
int supposedFinalLevel = this.getVillagerLevel() + amount;
|
||||||
|
Preconditions.checkArgument(net.minecraft.world.entity.npc.VillagerData.MIN_VILLAGER_LEVEL <= supposedFinalLevel && supposedFinalLevel <= net.minecraft.world.entity.npc.VillagerData.MAX_VILLAGER_LEVEL,
|
||||||
|
"Final level reached after the donation (%d) must be between [%d, %d]".formatted(supposedFinalLevel, net.minecraft.world.entity.npc.VillagerData.MIN_VILLAGER_LEVEL, net.minecraft.world.entity.npc.VillagerData.MAX_VILLAGER_LEVEL));
|
||||||
|
|
||||||
|
it.unimi.dsi.fastutil.ints.Int2ObjectMap<net.minecraft.world.entity.npc.VillagerTrades.ItemListing[]> trades =
|
||||||
|
net.minecraft.world.entity.npc.VillagerTrades.TRADES.get(this.getHandle().getVillagerData().getProfession());
|
||||||
|
|
||||||
|
if (trades == null || trades.isEmpty()) {
|
||||||
|
this.getHandle().setVillagerData(this.getHandle().getVillagerData().setLevel(supposedFinalLevel));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (amount > 0) {
|
||||||
|
this.getHandle().increaseMerchantCareer();
|
||||||
|
amount--;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean addTrades(int amount) {
|
||||||
|
Preconditions.checkArgument(amount > 0, "Number of trades unlocked must be positive");
|
||||||
|
return this.getHandle().updateTrades(amount);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getRestocksToday() {
|
public int getRestocksToday() {
|
||||||
return getHandle().numberOfRestocksToday;
|
return getHandle().numberOfRestocksToday;
|
||||||
|
|
Loading…
Reference in a new issue