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}