/*
 * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */

package com.sun.javafx.tk.quantum;

import com.sun.javafx.tk.Toolkit;
import com.sun.prism.impl.PrismSettings;

import java.security.AccessController;
import java.security.PrivilegedAction;

Class containing implementation for logging, and performance tracking.
/** * Class containing implementation for logging, and performance tracking. */
abstract class PerformanceTrackerHelper { private static final PerformanceTrackerHelper instance = createInstance(); public static PerformanceTrackerHelper getInstance() { return instance; } private PerformanceTrackerHelper() { } private static PerformanceTrackerHelper createInstance() { PerformanceTrackerHelper trackerImpl = AccessController.doPrivileged( new PrivilegedAction<PerformanceTrackerHelper>() { @Override public PerformanceTrackerHelper run() { try { if (PrismSettings.perfLog != null) { final PerformanceTrackerHelper trackerImpl = new PerformanceTrackerDefaultImpl(); if (PrismSettings.perfLogExitFlush) { Runtime.getRuntime().addShutdownHook( new Thread() { @Override public void run() { trackerImpl.outputLog(); } }); } return trackerImpl; } } catch (Throwable t) { } return null; } }); if (trackerImpl == null) { trackerImpl = new PerformanceTrackerDummyImpl(); } return trackerImpl; } public abstract void logEvent(final String s); public abstract void outputLog(); public abstract boolean isPerfLoggingEnabled(); public final long nanoTime() { return Toolkit.getToolkit().getMasterTimer().nanos(); } private static final class PerformanceTrackerDefaultImpl extends PerformanceTrackerHelper { private long firstTime; private long lastTime; @Override public void logEvent(final String s) { final long time = System.currentTimeMillis(); if (firstTime == 0) { firstTime = time; } PerformanceLogger.setTime("JavaFX> " + s + " (" + (time - firstTime) + "ms total, " + (time - lastTime) + "ms)"); lastTime = time; } @Override public void outputLog() { logLaunchTime(); // Output the log PerformanceLogger.outputLog(); } @Override public boolean isPerfLoggingEnabled() { return true; } private void logLaunchTime() { try { // Attempt to log launchTime, if not set already if (PerformanceLogger.getStartTime() <= 0) { // Standalone apps record launch time as sysprop String launchTimeString = AccessController.doPrivileged( (PrivilegedAction<String>) () -> System.getProperty("launchTime")); if (launchTimeString != null && !launchTimeString.equals("")) { long launchTime = Long.parseLong(launchTimeString); PerformanceLogger.setStartTime("LaunchTime", launchTime); } } } catch (Throwable t) { t.printStackTrace(); } } } private static final class PerformanceTrackerDummyImpl extends PerformanceTrackerHelper { @Override public void logEvent(final String s) { } @Override public void outputLog() { } @Override public boolean isPerfLoggingEnabled() { return false; } } }