geforkt von Mirrors/Paper
Remove java 8 and prior reflection code from CustomTimingsHandler (#7096)
Dieser Commit ist enthalten in:
Ursprung
389b1401e9
Commit
b98020331a
@ -3565,21 +3565,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ */
|
+ */
|
||||||
package org.spigotmc;
|
package org.spigotmc;
|
||||||
|
|
||||||
import java.io.PrintStream;
|
-import java.io.PrintStream;
|
||||||
@@ -0,0 +0,0 @@ import java.util.Queue;
|
-import java.util.Queue;
|
||||||
import java.util.concurrent.ConcurrentLinkedQueue;
|
-import java.util.concurrent.ConcurrentLinkedQueue;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.World;
|
-import org.bukkit.World;
|
||||||
-import org.bukkit.command.defaults.TimingsCommand;
|
-import org.bukkit.command.defaults.TimingsCommand;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
-import org.jetbrains.annotations.Nullable;
|
||||||
+import org.bukkit.plugin.AuthorNagException;
|
+import org.bukkit.plugin.AuthorNagException;
|
||||||
+import org.bukkit.plugin.Plugin;
|
|
||||||
+import co.aikar.timings.Timing;
|
+import co.aikar.timings.Timing;
|
||||||
+import co.aikar.timings.Timings;
|
+import co.aikar.timings.Timings;
|
||||||
+import co.aikar.timings.TimingsManager;
|
+import co.aikar.timings.TimingsManager;
|
||||||
+
|
+
|
||||||
+import java.lang.reflect.InvocationTargetException;
|
|
||||||
+import java.lang.reflect.Method;
|
+import java.lang.reflect.Method;
|
||||||
+import java.util.logging.Level;
|
+import java.util.logging.Level;
|
||||||
|
|
||||||
@ -3607,25 +3605,17 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+@Deprecated
|
+@Deprecated
|
||||||
+public final class CustomTimingsHandler {
|
+public final class CustomTimingsHandler {
|
||||||
+ private final Timing handler;
|
+ private final Timing handler;
|
||||||
+ private static Boolean sunReflectAvailable;
|
|
||||||
+ private static Method getCallerClass;
|
|
||||||
|
|
||||||
public CustomTimingsHandler(@NotNull String name) {
|
public CustomTimingsHandler(@NotNull String name) {
|
||||||
- this(name, null);
|
- this(name, null);
|
||||||
- }
|
- }
|
||||||
+ if (sunReflectAvailable == null) {
|
-
|
||||||
+ String javaVer = System.getProperty("java.version");
|
|
||||||
+ String[] elements = javaVer.split("\\.");
|
|
||||||
|
|
||||||
- public CustomTimingsHandler(@NotNull String name, @Nullable CustomTimingsHandler parent) {
|
- public CustomTimingsHandler(@NotNull String name, @Nullable CustomTimingsHandler parent) {
|
||||||
- this.name = name;
|
- this.name = name;
|
||||||
- this.parent = parent;
|
- this.parent = parent;
|
||||||
- HANDLERS.add(this);
|
- HANDLERS.add(this);
|
||||||
- }
|
- }
|
||||||
+ int major = Integer.parseInt(elements.length >= 2 ? elements[1] : javaVer);
|
-
|
||||||
+ if (major <= 8) {
|
|
||||||
+ sunReflectAvailable = true;
|
|
||||||
|
|
||||||
- /**
|
- /**
|
||||||
- * Prints the timings and extra data to the given stream.
|
- * Prints the timings and extra data to the given stream.
|
||||||
- *
|
- *
|
||||||
@ -3638,14 +3628,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
- long count = timings.count;
|
- long count = timings.count;
|
||||||
- if (count == 0) {
|
- if (count == 0) {
|
||||||
- continue;
|
- continue;
|
||||||
+ try {
|
- }
|
||||||
+ Class<?> reflection = Class.forName("sun.reflect.Reflection");
|
|
||||||
+ getCallerClass = reflection.getMethod("getCallerClass", int.class);
|
|
||||||
+ } catch (ClassNotFoundException | NoSuchMethodException ignored) {
|
|
||||||
+ }
|
|
||||||
+ } else {
|
|
||||||
+ sunReflectAvailable = false;
|
|
||||||
}
|
|
||||||
- long avg = time / count;
|
- long avg = time / count;
|
||||||
-
|
-
|
||||||
- printStream.println(" " + timings.name + " Time: " + time + " Count: " + count + " Avg: " + avg + " Violations: " + timings.violations);
|
- printStream.println(" " + timings.name + " Time: " + time + " Count: " + count + " Avg: " + avg + " Violations: " + timings.violations);
|
||||||
@ -3656,11 +3639,11 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
- for (World world : Bukkit.getWorlds()) {
|
- for (World world : Bukkit.getWorlds()) {
|
||||||
- entities += world.getEntities().size();
|
- entities += world.getEntities().size();
|
||||||
- livingEntities += world.getLivingEntities().size();
|
- livingEntities += world.getLivingEntities().size();
|
||||||
}
|
- }
|
||||||
- printStream.println("# Entities " + entities);
|
- printStream.println("# Entities " + entities);
|
||||||
- printStream.println("# LivingEntities " + livingEntities);
|
- printStream.println("# LivingEntities " + livingEntities);
|
||||||
- }
|
- }
|
||||||
|
-
|
||||||
- /**
|
- /**
|
||||||
- * Resets all timings.
|
- * Resets all timings.
|
||||||
- */
|
- */
|
||||||
@ -3668,16 +3651,11 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
- if (Bukkit.getPluginManager().useTimings()) {
|
- if (Bukkit.getPluginManager().useTimings()) {
|
||||||
- for (CustomTimingsHandler timings : HANDLERS) {
|
- for (CustomTimingsHandler timings : HANDLERS) {
|
||||||
- timings.reset();
|
- timings.reset();
|
||||||
+ Class calling = null;
|
- }
|
||||||
+ if (sunReflectAvailable) {
|
- }
|
||||||
+ try {
|
|
||||||
+ calling = (Class) getCallerClass.invoke(null, 2);
|
|
||||||
+ } catch (IllegalAccessException | InvocationTargetException ignored) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
- TimingsCommand.timingStart = System.nanoTime();
|
- TimingsCommand.timingStart = System.nanoTime();
|
||||||
- }
|
- }
|
||||||
|
-
|
||||||
- /**
|
- /**
|
||||||
- * Ticked every tick by CraftBukkit to count the number of times a timer
|
- * Ticked every tick by CraftBukkit to count the number of times a timer
|
||||||
- * caused TPS loss.
|
- * caused TPS loss.
|
||||||
@ -3705,12 +3683,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
- if (parent != null && ++parent.timingDepth == 1) {
|
- if (parent != null && ++parent.timingDepth == 1) {
|
||||||
- parent.start = start;
|
- parent.start = start;
|
||||||
- }
|
- }
|
||||||
- }
|
+ new AuthorNagException("Deprecated use of CustomTimingsHandler. Please Switch to Timings.of ASAP").printStackTrace();
|
||||||
- }
|
|
||||||
+ Plugin plugin = null;
|
|
||||||
+ try {
|
+ try {
|
||||||
+ plugin = TimingsManager.getPluginByClassloader(calling);
|
+ final Method ofSafe = TimingsManager.class.getDeclaredMethod("getHandler", String.class, String.class, Timing.class);
|
||||||
+ } catch (Exception ignored) {}
|
+ ofSafe.setAccessible(true);
|
||||||
|
+ timing = (Timing) ofSafe.invoke(null,"Minecraft", "(Deprecated API) " + name, null);
|
||||||
|
+ } catch (Exception e) {
|
||||||
|
+ e.printStackTrace();
|
||||||
|
+ Bukkit.getLogger().log(Level.SEVERE, "This handler could not be registered");
|
||||||
|
+ timing = Timings.NULL_HANDLER;
|
||||||
|
}
|
||||||
|
+ handler = timing;
|
||||||
|
}
|
||||||
|
|
||||||
- /**
|
- /**
|
||||||
- * Stops timing a section of code.
|
- * Stops timing a section of code.
|
||||||
@ -3727,22 +3711,11 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
- start = 0;
|
- start = 0;
|
||||||
- if (parent != null) {
|
- if (parent != null) {
|
||||||
- parent.stopTiming();
|
- parent.stopTiming();
|
||||||
+ new AuthorNagException("Deprecated use of CustomTimingsHandler. Please Switch to Timings.of ASAP").printStackTrace();
|
- }
|
||||||
+ if (plugin != null) {
|
- }
|
||||||
+ timing = Timings.of(plugin, "(Deprecated API) " + name);
|
- }
|
||||||
+ } else {
|
+ public void startTiming() { handler.startTiming(); }
|
||||||
+ try {
|
+ public void stopTiming() { handler.stopTiming(); }
|
||||||
+ final Method ofSafe = TimingsManager.class.getDeclaredMethod("getHandler", String.class, String.class, Timing.class);
|
|
||||||
+ ofSafe.setAccessible(true);
|
|
||||||
+ timing = (Timing) ofSafe.invoke(null,"Minecraft", "(Deprecated API) " + name, null);
|
|
||||||
+ } catch (Exception e) {
|
|
||||||
+ e.printStackTrace();
|
|
||||||
+ Bukkit.getLogger().log(Level.SEVERE, "This handler could not be registered");
|
|
||||||
+ timing = Timings.NULL_HANDLER;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+ handler = timing;
|
|
||||||
}
|
|
||||||
|
|
||||||
- /**
|
- /**
|
||||||
- * Reset this timer, setting all values to zero.
|
- * Reset this timer, setting all values to zero.
|
||||||
@ -3755,7 +3728,4 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
- start = 0;
|
- start = 0;
|
||||||
- timingDepth = 0;
|
- timingDepth = 0;
|
||||||
- }
|
- }
|
||||||
+ public void startTiming() { handler.startTiming(); }
|
|
||||||
+ public void stopTiming() { handler.stopTiming(); }
|
|
||||||
+
|
|
||||||
}
|
}
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren