2015-04-19 20:20:50 +10:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: md_5 <git@md-5.net>
|
|
|
|
Date: Sun, 19 Apr 2015 09:19:39 +1000
|
|
|
|
Subject: [PATCH] Use CLQ for main thread tasks.
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
|
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
|
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
|
|
@@ -0,0 +0,0 @@ public abstract class MinecraftServer implements Runnable, ICommandListener, IAs
|
2016-03-01 08:33:06 +11:00
|
|
|
private final GameProfileRepository W;
|
|
|
|
private final UserCache X;
|
|
|
|
private long Y = 0L;
|
2015-04-19 20:20:50 +10:00
|
|
|
- protected final Queue<FutureTask<?>> j = Queues.newArrayDeque();
|
|
|
|
+ protected final Queue<FutureTask<?>> j = new java.util.concurrent.ConcurrentLinkedQueue<FutureTask<?>>(); // Spigot, PAIL: Rename
|
|
|
|
private Thread serverThread;
|
2016-03-01 08:33:06 +11:00
|
|
|
private long aa = av();
|
2015-04-19 20:20:50 +10:00
|
|
|
|
|
|
|
@@ -0,0 +0,0 @@ public abstract class MinecraftServer implements Runnable, ICommandListener, IAs
|
|
|
|
this.methodProfiler.a("jobs");
|
|
|
|
Queue queue = this.j;
|
|
|
|
|
|
|
|
- synchronized (this.j) {
|
|
|
|
- while (!this.j.isEmpty()) {
|
|
|
|
- SystemUtils.a((FutureTask) this.j.poll(), MinecraftServer.LOGGER);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
+ // Spigot start
|
|
|
|
+ FutureTask<?> entry;
|
|
|
|
+ int count = this.j.size();
|
2015-04-20 19:11:52 +10:00
|
|
|
+ while (count-- > 0 && (entry = this.j.poll()) != null) {
|
2015-04-19 20:20:50 +10:00
|
|
|
+ SystemUtils.a(entry, MinecraftServer.LOGGER);
|
|
|
|
+ }
|
|
|
|
+ // Spigot end
|
|
|
|
|
|
|
|
this.methodProfiler.c("levels");
|
|
|
|
|
|
|
|
@@ -0,0 +0,0 @@ public abstract class MinecraftServer implements Runnable, ICommandListener, IAs
|
|
|
|
ListenableFutureTask listenablefuturetask = ListenableFutureTask.create(callable);
|
|
|
|
Queue queue = this.j;
|
|
|
|
|
|
|
|
- synchronized (this.j) {
|
|
|
|
- this.j.add(listenablefuturetask);
|
|
|
|
- return listenablefuturetask;
|
|
|
|
- }
|
|
|
|
+ // Spigot start
|
|
|
|
+ this.j.add(listenablefuturetask);
|
|
|
|
+ return listenablefuturetask;
|
|
|
|
+ // Spigot end
|
|
|
|
} else {
|
|
|
|
try {
|
|
|
|
return Futures.immediateFuture(callable.call());
|
|
|
|
--
|