/* File: Log.java ; This file is part of Twister. Version: 2.003 Copyright (C) 2012-2013 , Luxoft Authors: Andrei Costachi <acostachi@luxoft.com> Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ import java.awt.Color; import java.io.File; import java.io.FileNotFoundException; import java.util.Scanner; import javax.swing.JPanel; import javax.swing.JTextArea; import javax.swing.JScrollPane; import java.net.URL; import java.net.URLConnection; import java.io.BufferedReader; import java.io.InputStreamReader; import java.awt.Font; import java.awt.GridBagLayout; import java.awt.GridBagConstraints; import java.awt.BorderLayout; import javax.swing.JLabel; import javax.swing.JTextField; import java.awt.Dimension; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import javax.swing.text.Element; import javax.swing.text.BadLocationException; import javax.swing.text.Highlighter.HighlightPainter; import javax.swing.text.Highlighter; import javax.swing.text.DefaultHighlighter; import javax.swing.JButton; import javax.swing.BorderFactory; import java.io.FileInputStream; import java.io.FileWriter; import javax.swing.JFileChooser; import javax.xml.bind.DatatypeConverter; import javax.swing.text.DefaultCaret; import javax.swing.JOptionPane; import com.twister.CustomDialog; import javax.swing.JCheckBox; public class Log extends JPanel{ private static final long serialVersionUID = 1L; private long size; private int line; public String log; public JTextArea textarea; public JScrollPane scroll; private long length = 0; private long response = 0; public JPanel container; private int lastIndexFound = -1; public JButton clearlog; public Log(final String log){ this.log = log; size = 0; line = 0; textarea = new JTextArea(); textarea.setBorder(BorderFactory.createEmptyBorder(10, 10, 10, 10)); ((DefaultCaret)textarea.getCaret()).setUpdatePolicy(DefaultCaret.ALWAYS_UPDATE); scroll = new JScrollPane(textarea); scroll.setSize(450, 600); scroll.setVerticalScrollBarPolicy(22); container = new JPanel(); container.setLayout(new BorderLayout()); JPanel findpanel = new JPanel(); JLabel findlabel = new JLabel("Search: "); findpanel.add(findlabel); JButton next = new JButton("Next"); next.setFont(new Font("TimesRoman", Font.PLAIN, 10)); final JTextField find = new JTextField(); next.addActionListener(new ActionListener(){ public void actionPerformed(ActionEvent ev){ findNext(find.getText(),false,null);}}); find.setPreferredSize(new Dimension(150,25)); findpanel.add(find); JButton prev = new JButton("Prev"); prev.setFont(new Font("TimesRoman", Font.PLAIN, 10)); prev.addActionListener(new ActionListener(){ public void actionPerformed(ActionEvent ev){ findPrevious(find.getText());}}); JButton savelog = new JButton("Save log"); savelog.setFont(new Font("TimesRoman", Font.PLAIN, 10)); savelog.addActionListener(new ActionListener(){ public void actionPerformed(ActionEvent ev){ saveLog();}}); clearlog = new JButton("Clear log"); clearlog.setFont(new Font("TimesRoman", Font.PLAIN, 10)); clearlog.addActionListener(new ActionListener(){ public void actionPerformed(ActionEvent ev){ clearLog();}}); findpanel.add(next); findpanel.add(prev); findpanel.add(savelog); findpanel.add(clearlog); JPanel l = new JPanel(); l.setPreferredSize(new Dimension(40,25)); findpanel.add(l); // JLabel logsize = new JLabel("Log size: "); // findpanel.add(logsize); // JTextField tlogsize = new JTextField(); // tlogsize.setPreferredSize(new Dimension(80,25)); // findpanel.add(tlogsize); // // JCheckBox unlimited = new JCheckBox("Unlimited"); // findpanel.add(unlimited); container.add(scroll,BorderLayout.CENTER); container.add(findpanel,BorderLayout.PAGE_END); textarea.setEditable(false); textarea.setBackground(Color.BLACK); textarea.setForeground(Color.WHITE); textarea.setFont(new Font("Monospaced",Font.PLAIN, 12)); new Thread(){ public void run(){ updateLog();}}.start();} /* * interpret result from CE * and update Log on screen accordingly */ public void updateLog(){ String result; while(RunnerRepository.run){ try{Thread.sleep(500); if(container.isShowing()){ if(response==length){ result = RunnerRepository.getRPCClient().execute("getLogFile", new Object[]{RunnerRepository.getUser(), "0","0",log}).toString(); response = Long.parseLong(result);} if(response>length){ result = RunnerRepository.getRPCClient().execute("getLogFile", new Object[]{RunnerRepository.getUser(), "1",length+"",log})+""; readText(result); length = response;} else if(response<length){ clearScreen();} } } catch (Exception e){ e.printStackTrace(); clearScreen(); textarea.append("This log has the folowing error: "+e.toString());}}} /* * find previous occurrence of "toFind" * in this log */ public void findPrevious(String toFind){ Element paragraph = textarea.getDocument().getDefaultRootElement(); int contentCount = paragraph.getElementCount(); if(lastIndexFound==-1)lastIndexFound=0; for (int i=lastIndexFound-1; i>=-1; i--){ if(i==-1){i=contentCount-1;} Element e = paragraph.getElement(i); int rangeStart = e.getStartOffset(); int rangeEnd = e.getEndOffset(); try{if(textarea.getText(rangeStart, rangeEnd-rangeStart).indexOf(toFind)!=-1){ lastIndexFound = i; highlite(toFind,rangeStart,rangeEnd); break;}} catch (BadLocationException ex){i=contentCount-1;} catch(Exception ex){ex.printStackTrace();} if(i==(lastIndexFound+1))break;}} /* * highlite string int log */ public void highlite(String toFind,int rangeStart,int rangeEnd)throws Exception{ HighlightPainter myHighlighter = new MyHighlightPainter(Color.RED); int index = textarea.getText(rangeStart, rangeEnd-rangeStart).indexOf(toFind); textarea.setCaretPosition(0); textarea.setCaretPosition(rangeStart); Highlighter hilite = textarea.getHighlighter(); hilite.removeAllHighlights(); hilite.addHighlight(rangeStart+index, rangeStart+index+toFind.length(), myHighlighter); hilite.paint(textarea.getGraphics());} /* * find next occurrence of "toFind" * in this log */ public void findNext(String toFind, boolean start, String stext){ Element paragraph = textarea.getDocument().getDefaultRootElement(); int contentCount = paragraph.getElementCount(); if(contentCount==1)return; for (int i=lastIndexFound+1; i<contentCount; i++){ Element e = paragraph.getElement(i); int rangeStart = e.getStartOffset(); int rangeEnd = e.getEndOffset(); try{if(textarea.getText(rangeStart, rangeEnd-rangeStart).indexOf(toFind)!=-1){ if(start){ if(textarea.getText(rangeStart, rangeEnd-rangeStart).indexOf(stext)!=-1){ lastIndexFound = i; highlite(toFind,rangeStart,rangeEnd); break; } } else { lastIndexFound = i; highlite(toFind,rangeStart,rangeEnd); break; } } } catch (BadLocationException ex){} catch(Exception ex){ex.printStackTrace();} if(i==(contentCount-1)){ i=-1; if(lastIndexFound==-1)break; } if(i==(lastIndexFound-1))break;}} /* * clear log screen */ public void clearScreen(){ textarea.setText(""); length = 0; response = 0;} /* * open filechooser * and save log localy */ public void saveLog(){ JFileChooser chooser = new JFileChooser(); chooser.setApproveButtonText("Save"); chooser.setCurrentDirectory(new java.io.File(".")); chooser.setDialogTitle("Choose Location"); chooser.setAcceptAllFileFilterUsed(false); if (chooser.showOpenDialog(RunnerRepository.window) == JFileChooser.APPROVE_OPTION) { File theone = new File(chooser.getSelectedFile()+""); try{theone.createNewFile(); FileWriter writer = new FileWriter(theone); writer.write(textarea.getText()); writer.flush(); writer.close();} catch(Exception e){}}} /* * clear log localy and on server */ public void clearLog(){ int resp = (Integer)CustomDialog.showDialog(new JLabel("Clear log?"),JOptionPane.QUESTION_MESSAGE, JOptionPane.OK_CANCEL_OPTION,this , "Clear Log!",null); if(resp == JOptionPane.OK_OPTION){ clearScreen(); try{String result = RunnerRepository.getRPCClient().execute("resetLog", new Object[]{RunnerRepository.getUser(), log})+"";} catch(Exception e){e.printStackTrace();} } } /* * decode string and append to Log screen */ public void readText(String content){ byte mydata[]=null; try{mydata = DatatypeConverter.parseBase64Binary(content);} catch(Exception e){e.printStackTrace();} textarea.append(new String(mydata)); // byte mydata[]=null; // try{mydata = base64.decodeBuffer(content);} // catch(Exception e){e.printStackTrace();} // textarea.append(new String(mydata)); scroll.getHorizontalScrollBar().setValue(0);}} class MyHighlightPainter extends DefaultHighlighter.DefaultHighlightPainter { public MyHighlightPainter(Color color) { super(color);}}