/**
*
* Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
**/
package lucee.runtime.exp;
import java.io.PrintWriter;
import lucee.commons.io.log.Log;
import lucee.commons.io.log.LogUtil;
import lucee.commons.lang.ExceptionUtil;
import lucee.runtime.PageContext;
import lucee.runtime.config.Config;
import lucee.runtime.config.ConfigImpl;
import lucee.runtime.engine.ThreadLocalPageContext;
import lucee.runtime.op.Caster;
/**
* Handle Excpetions
*/
public final class ExceptionHandler {
public static void log(Config config, Throwable t) {
PageException pe=Caster.toPageException(t);
pe.printStackTrace(config.getErrWriter());
// apllication Log
LogUtil.log(config.getLog("application"),Log.LEVEL_ERROR, "",pe);
// exception.log
String st = ExceptionUtil.getStacktrace(pe,true);
LogUtil.log(config.getLog("exception"),Log.LEVEL_ERROR, "",pe);
}
public static void printStackTrace(PageContext pc, Throwable t) {
PrintWriter pw = (pc.getConfig()).getErrWriter();
t.printStackTrace(pw);
pw.flush();
}
public static void printStackTrace(Throwable t) {
PageContext pc = ThreadLocalPageContext.get();
if(pc!=null)printStackTrace(pc,t);
else t.printStackTrace();
}
}