mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-22 16:31:55 +01:00
54 lines
1.6 KiB
Diff
54 lines
1.6 KiB
Diff
|
--- a/net/minecraft/util/TickThrottler.java
|
||
|
+++ b/net/minecraft/util/TickThrottler.java
|
||
|
@@ -1,10 +1,14 @@
|
||
|
package net.minecraft.util;
|
||
|
|
||
|
+// CraftBukkit start
|
||
|
+import java.util.concurrent.atomic.AtomicInteger;
|
||
|
+// CraftBukkit end
|
||
|
+
|
||
|
public class TickThrottler {
|
||
|
|
||
|
private final int incrementStep;
|
||
|
private final int threshold;
|
||
|
- private int count;
|
||
|
+ private final AtomicInteger count = new AtomicInteger(); // CraftBukkit - multithreaded field
|
||
|
|
||
|
public TickThrottler(int i, int j) {
|
||
|
this.incrementStep = i;
|
||
|
@@ -12,17 +16,32 @@
|
||
|
}
|
||
|
|
||
|
public void increment() {
|
||
|
- this.count += this.incrementStep;
|
||
|
+ this.count.addAndGet(this.incrementStep); // CraftBukkit - use thread-safe field access instead
|
||
|
}
|
||
|
|
||
|
public void tick() {
|
||
|
+ // CraftBukkit start
|
||
|
+ for (int val; (val = this.count.get()) > 0 && !count.compareAndSet(val, val - 1); ) ;
|
||
|
+ /* Use thread-safe field access instead
|
||
|
if (this.count > 0) {
|
||
|
--this.count;
|
||
|
}
|
||
|
+ */
|
||
|
+ // CraftBukkit end
|
||
|
|
||
|
}
|
||
|
|
||
|
public boolean isUnderThreshold() {
|
||
|
- return this.count < this.threshold;
|
||
|
+ // CraftBukkit start - use thread-safe field access instead
|
||
|
+ return this.count.get() < this.threshold;
|
||
|
+ }
|
||
|
+
|
||
|
+ public boolean isIncrementAndUnderThreshold() {
|
||
|
+ return isIncrementAndUnderThreshold(this.incrementStep, this.threshold);
|
||
|
+ }
|
||
|
+
|
||
|
+ public boolean isIncrementAndUnderThreshold(int incrementStep, int threshold) {
|
||
|
+ return this.count.addAndGet(incrementStep) < threshold;
|
||
|
+ // CraftBukkit end
|
||
|
}
|
||
|
}
|