Remove java 8 and prior reflection code from CustomTimingsHandler (#7096)

This commit is contained in:
chickeneer 2021-12-12 01:03:06 -06:00
parent 389b1401e9
commit b98020331a

View File

@ -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(); }
+
} }