/* * This file is part of NeptuneVanilla, licensed under the MIT License (MIT). * * Copyright (c) 2015-2017, Jamie Mansfield <https://github.com/jamierocks> * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package org.neptunepowered.vanilla.mixin.canary.hook; import co.aikar.timings.TimingsManager; import com.google.common.collect.ArrayListMultimap; import net.canarymod.Canary; import net.canarymod.hook.Hook; import net.canarymod.hook.HookExecutionException; import net.canarymod.hook.HookExecutor; import net.canarymod.plugin.RegisteredPluginListener; import org.neptunepowered.vanilla.interfaces.canary.plugin.IMixinRegisteredPluginListener; import org.spongepowered.asm.mixin.Final; import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.Overwrite; import org.spongepowered.asm.mixin.Shadow; import java.util.Iterator; @Mixin(value = HookExecutor.class, remap = false) public abstract class MixinHookExecutor { @Shadow @Final public ArrayListMultimap<Class<? extends Hook>, RegisteredPluginListener> listeners; /** * @author jamierocks - 1st October 2016 * @reason Add relevant timings */ @Overwrite public void callHook(Hook hook) { if (!hook.executed()) { hook.hasExecuted(); if (this.listeners.containsKey(hook.getClass())) { Iterator iter = this.listeners.get(hook.getClass()).iterator(); TimingsManager.PLUGIN_HOOK_HANDLER.startTimingIfSync(); // Neptune - timings while (iter.hasNext()) { RegisteredPluginListener listener = (RegisteredPluginListener) iter.next(); try { ((IMixinRegisteredPluginListener) listener).getTimingsHandler().startTimingIfSync(); // Neptune - timings listener.execute(hook); ((IMixinRegisteredPluginListener) listener).getTimingsHandler().stopTimingIfSync(); // Neptune - timings } catch (HookExecutionException ex) { ((IMixinRegisteredPluginListener) listener).getTimingsHandler().stopTimingIfSync(); // Neptune - timings Canary.log.error("Exception while executing Hook: " + hook.getHookName() + " in PluginListener: " + listener.getListener().getClass().getSimpleName() + " (Plugin: " + listener.getPlugin().getName() + ")", ex); } } TimingsManager.PLUGIN_HOOK_HANDLER.stopTimingIfSync(); // Neptune - timings } } } }