All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.maizegenetics.gui.TasselLogging.kt Maven / Gradle / Ivy

package net.maizegenetics.gui

import javafx.application.Platform
import javafx.geometry.Insets
import javafx.geometry.Pos
import javafx.scene.Scene
import javafx.scene.control.Button
import javafx.scene.control.CheckBox
import javafx.scene.control.TextArea
import javafx.scene.control.Tooltip
import javafx.scene.layout.BorderPane
import javafx.scene.layout.HBox
import javafx.scene.layout.Priority
import javafx.scene.layout.VBox
import javafx.stage.FileChooser
import javafx.stage.Modality
import javafx.stage.Stage
import net.maizegenetics.plugindef.AbstractPlugin
import net.maizegenetics.plugindef.DataSet
import net.maizegenetics.prefs.TasselPrefs
import net.maizegenetics.tassel.TASSELMainApp
import net.maizegenetics.util.Utils
import net.maizegenetics.util.setupDebugLogging
import net.maizegenetics.util.setupLogging
import org.apache.logging.log4j.LogManager
import java.io.OutputStream
import java.io.PrintStream


/**
 * @author Terry Casstevens
 * Created November 07, 2018
 */

private val myLogger = LogManager.getLogger(TasselLogging::class.java)

class TasselLogging private constructor() : AbstractPlugin() {

    private val dialog = Stage()
    private val text = TextArea()
    private val textAreaOutputStream = TextAreaStream(text)
    private val printStream = PrintStream(textAreaOutputStream, true)

    init {
        dialog.initModality(Modality.NONE)
        dialog.isResizable = true
        dialog.title = "TASSEL Logging"

        createDialog()
        setupLogging(printStream)
        basicLoggingInfo()

        if (TasselPrefs.getLogSendToConsole()) {
            setupLogging()
        }
    }

    override fun performFunction(input: DataSet?): DataSet? {
        setupLogging(printStream)
        Platform.runLater { dialog.show() }
        fireProgress(100)
        return null
    }

    private fun createDialog() {

        val main = BorderPane()
        val scene = Scene(main)

        val x = TasselPrefs.getLogXDim()
        val y = TasselPrefs.getLogYDim()
        if (x < 50 || y < 50) {
            dialog.setWidth(500.0)
            dialog.setHeight(400.0)
        } else {
            dialog.setWidth(x.toDouble())
            dialog.setHeight(y.toDouble())
        }

        text.isWrapText = true
        text.padding = Insets(10.0)
        text.isEditable = false
        HBox.setHgrow(text, Priority.ALWAYS)
        VBox.setVgrow(text, Priority.ALWAYS)

        val isDebug = CheckBox("Debug Level")
        isDebug.isSelected = TasselPrefs.getLogDebug()
        isDebug.tooltip = Tooltip("Set to show Debug Logging Messages")
        isDebug.setOnAction { event ->
            val debugMode = isDebug.isSelected
            isDebug.isSelected = debugMode
            TasselPrefs.putLogDebug(debugMode)
            setupLogging(printStream)
        }

        val closeButton = Button("Close")
        closeButton.setOnAction { close() }

        val clearButton = Button("Clear")
        clearButton.setOnAction {
            text.clear()
            basicLoggingInfo()
        }

        val saveButton = Button("Save")
        saveButton.setOnAction {
            val chooser = FileChooser()
            val theFile = chooser.showOpenDialog(dialog)
            if (theFile != null) {
                try {
                    Utils.getBufferedWriter(theFile).use { writer -> writer.write(text.getText()) }
                } catch (ex: Exception) {
                    showError(ex.message)
                }

            }
        }

        val pnlButtons = HBox()
        pnlButtons.alignment = Pos.CENTER
        pnlButtons.padding = Insets(10.0)
        pnlButtons.spacing = 20.0
        pnlButtons.children.add(closeButton)
        pnlButtons.children.add(clearButton)
        pnlButtons.children.add(saveButton)
        pnlButtons.children.add(isDebug)

        main.center = text
        main.bottom = pnlButtons

        dialog.setScene(scene)

    }

    private fun updateLogging() {
        if (TasselPrefs.getLogSendToConsole()) {
            setupLogging()
        } else {
            setupDebugLogging(printStream)
        }
    }

    private fun close() {
        TasselPrefs.putLogXDim(dialog.width.toInt())
        TasselPrefs.putLogYDim(dialog.height.toInt())
        dialog.close()
        if (TasselPrefs.getLogSendToConsole()) {
            setupLogging()
        }
    }

    override fun icon(): String {
        return "/images/log.gif"
    }

    override fun getButtonName(): String {
        return "Logging"
    }

    override fun getToolTipText(): String {
        return "Logging"
    }

    companion object {
        val instance = TasselLogging()

        fun updateLoggingLocation() {
            instance.updateLogging()
        }
    }
}

fun basicLoggingInfo() {
    myLogger.info("Tassel Version: " + TASSELMainApp.version + "  Date: " + TASSELMainApp.versionDate)
    myLogger.info("Max Available Memory Reported by JVM: " + Utils.getMaxHeapSizeMB() + " MB")
    myLogger.info("Java Version: " + System.getProperty("java.version"))
    myLogger.info("OS: " + System.getProperty("os.name"))
    myLogger.info("Number of Processors: " + Runtime.getRuntime().availableProcessors())
}

class TextAreaStream(private val textArea: TextArea) : OutputStream() {

    override fun write(i: Int) {
        Platform.runLater { textArea.appendText(i.toChar().toString()) }
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy