Mercurial > hg > ccmieditor
diff java/src/uk/ac/qmul/eecs/ccmi/utils/CCmIUncaughtExceptionHandler.java @ 0:9418ab7b7f3f
Initial import
author | Fiore Martin <fiore@eecs.qmul.ac.uk> |
---|---|
date | Fri, 16 Dec 2011 17:35:51 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/java/src/uk/ac/qmul/eecs/ccmi/utils/CCmIUncaughtExceptionHandler.java Fri Dec 16 17:35:51 2011 +0000 @@ -0,0 +1,73 @@ +/* + CCmI Editor - A Collaborative Cross-Modal Diagram Editing Tool + + Copyright (C) 2011 Queen Mary University of London (http://ccmi.eecs.qmul.ac.uk/) + + 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 3 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/>. +*/ + +package uk.ac.qmul.eecs.ccmi.utils; + +import java.io.IOException; +import java.io.PrintWriter; +import java.io.StringWriter; +import java.io.Writer; +import java.lang.Thread.UncaughtExceptionHandler; +import java.util.logging.FileHandler; +import java.util.logging.Level; +import java.util.logging.Logger; + +/** + * The UncaughtExceptionHandler for the CCmI Editor. It logs the occurred exception stack trace + * on a file (errorN.log, where N is an integer number automatically assigned to avoid + * collision with other files of the same type) which is created in the same directory where + * the program is run. The exception stack trace will be in the format defined by the {@code XMLFormatter} class + * of the java.utli.logging package. + * + * @see java.util.logging.XMLFormatter + */ +public class CCmIUncaughtExceptionHandler implements UncaughtExceptionHandler { + + @Override + public void uncaughtException(Thread thread, Throwable throwable) { + try{ + Logger logger = Logger.getLogger("uncaught_exception"); + logger.setLevel(Level.SEVERE); + FileHandler fileHandler = null; + try { + fileHandler = new FileHandler("error%u.log",true); + } catch (IOException e) { + System.err.println(throwable.toString()); + System.err.println(); + System.err.println("Could not use error log file"); + e.printStackTrace(); + return; + } + fileHandler.setLevel(Level.SEVERE); + logger.addHandler(fileHandler); + StringBuilder builder = new StringBuilder(throwable.toString()); + builder.append('\n'); + final Writer result = new StringWriter(); + final PrintWriter printWriter = new PrintWriter(result); + throwable.printStackTrace(printWriter); + builder.append(result.toString()); + logger.severe(builder.toString()); + fileHandler.close(); + throwable.printStackTrace(); + }catch(Exception exception){ + exception.printStackTrace(); + System.exit(-1); + } + } +}