001/** 002 * 003 * Copyright (c) 2014, the Railo Company Ltd. All rights reserved. 004 * 005 * This library is free software; you can redistribute it and/or 006 * modify it under the terms of the GNU Lesser General Public 007 * License as published by the Free Software Foundation; either 008 * version 2.1 of the License, or (at your option) any later version. 009 * 010 * This library is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 013 * Lesser General Public License for more details. 014 * 015 * You should have received a copy of the GNU Lesser General Public 016 * License along with this library. If not, see <http://www.gnu.org/licenses/>. 017 * 018 **/ 019package lucee.runtime.engine; 020 021import java.io.PrintWriter; 022import java.util.Map; 023 024import lucee.commons.lang.SystemOut; 025import lucee.runtime.PageContext; 026 027public class ConsoleExecutionLog extends ExecutionLogSupport { 028 029 private PrintWriter pw; 030 private PageContext pc; 031 032 protected void _init(PageContext pc,Map<String,String> arguments) { 033 this.pc=pc; 034 035 if(pw==null) { 036 // stream type 037 String type=arguments.get("stream-type"); 038 if(type!=null && type.trim().equalsIgnoreCase("error")) 039 pw=new PrintWriter(System.err); 040 else 041 pw=new PrintWriter(System.out); 042 043 } 044 } 045 046 @Override 047 protected void _log(int startPos, int endPos, long startTime, long endTime) { 048 049 long diff=endTime-startTime; 050 SystemOut.print(pw, pc.getId()+":"+pc.getCurrentPageSource().getDisplayPath()+":"+positons(startPos,endPos)+" > "+timeLongToString(diff)); 051 } 052 053 protected void _release() {} 054 055 private static String positons(int startPos, int endPos) { 056 if(startPos==endPos) return startPos+""; 057 return startPos+":"+endPos; 058 } 059 060}