/* * #%L * OME Bio-Formats manual and automated test suite. * %% * Copyright (C) 2006 - 2015 Open Microscopy Environment: * - Board of Regents of the University of Wisconsin-Madison * - Glencoe Software, Inc. * - University of Dundee * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 2 of the * License, or (at your option) any later version. * * This program 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 for more details. * * You should have received a copy of the GNU General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/gpl-2.0.html>. * #L% */ package loci.tests.testng; import loci.common.DateTools; import ch.qos.logback.classic.spi.ILoggingEvent; import ch.qos.logback.core.FileAppender; /** * A class for appending a timestamp to the log file name produced by the * logging framework. * * @author Blazej Pindelski <bpindelski at dundee dot ac dot uk> */ public class TimestampedLogFileAppender extends FileAppender<ILoggingEvent> { @Override public void start() { if (this.fileName != null) { this.setFile(this.getNewFileName()); } super.start(); } private String getNewFileName() { final int lastDotIndex = this.fileName.lastIndexOf("."); String newFileName = ""; String timestamp = "-" + DateTools.getFileTimestamp(); if (lastDotIndex != -1) { newFileName = this.fileName.substring(0, lastDotIndex) + timestamp + this.fileName.substring(lastDotIndex); } else { newFileName = this.fileName + timestamp; } return newFileName; } }