package NET.worlds.console; import java.awt.Component; import java.awt.Event; import java.io.BufferedReader; import java.io.File; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; import java.text.DateFormat; import java.util.Date; import java.util.Observer; import javax.swing.JScrollPane; import javax.swing.JTextArea; public class ChatArea extends JScrollPane implements SharedTextArea { private JTextArea textArea; private static String sharedText; private boolean isShared; private String unsharedText; private String unaddedText; private boolean haveFocus; private PrintWriter logFile; private String logFileName; private static final long oneMeg = 1048576L; private static final long logLengthLimit = 524288L; private static PublicObservable obsLogFile = new PublicObservable(); public ChatArea(int rows, int cols, boolean isShared) { this.textArea = new JTextArea(rows, cols); this.isShared = isShared; this.textArea.setEditable(false); this.setViewportView(this.textArea); super.setHorizontalScrollBarPolicy(31); super.setVerticalScrollBarPolicy(20); } @Override public Component getComponent() { return this; } @Override public void finalize() { this.disableLogging(); } @Override public synchronized void validate() { super.validate(); String text = this.isShared ? sharedText : this.unsharedText; if (text != null) { this.textArea.replaceRange("", 0, this.textArea.getText().length()); this.textArea.append(text); } } @Override public synchronized void enableLogging(String fileName, String title, boolean append) { if (this.logFile != null) { if (this.logFileName.equals(fileName)) { return; } this.logFile.close(); } try { if (append && new File(fileName).exists()) { this.truncateIfExceeds(fileName, title, 524288L); this.logFile = new PrintWriter(new FileWriter(fileName, true)); } else { this.logFile = new PrintWriter(new FileWriter(fileName, false)); obsLogFile.setChanged(true); this.logFile.println(""); this.logFile.println(""); this.logFile.println("" + title + ""); this.logFile.println(""); this.logFile.println(""); } this.logFileName = fileName; this.logFile.println("
"); this.logFile.println("

Conversation of " + DateFormat.getDateTimeInstance().format(new Date()) + "

"); this.logFile.flush(); obsLogFile.notifyObservers(this); } catch (IOException var5) { System.out.println("Log file not opened: " + var5); } } public static void addLogObserver(Observer o) { obsLogFile.addObserver(o); } public static void deleteLogObserver(Observer o) { obsLogFile.deleteObserver(o); } private synchronized void truncateIfExceeds(String fileName, String title, long lengthLimit) { File f = new File(fileName); if (f.length() > lengthLimit) { File tf = new File(fileName + ".temp"); try { BufferedReader in = new BufferedReader(new FileReader(f)); PrintWriter out = new PrintWriter(new FileWriter(tf)); out.println(""); out.println(""); out.println("" + title + ""); out.println(""); out.println(""); in.skip(f.length() - lengthLimit / 2L); String line = in.readLine(); for (String var13 = in.readLine(); var13 != null; var13 = in.readLine()) { out.println(var13); } in.close(); out.close(); f.delete(); f = new File(fileName); tf.renameTo(f); } catch (FileNotFoundException var10) { System.out.println("DuplexPart fatal: " + var10); } catch (IOException var11) { System.out.println("DuplexPart: Unable to write, " + var11); } } } @Override public synchronized void disableLogging() { if (this.logFile != null) { this.logFile.close(); this.logFile = null; } } @Override public boolean canAddText() { return !this.haveFocus; } private String toHtml(String s) { assert s != null; String h = ""; for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); switch (c) { case '"': h = h + """; break; case '&': h = h + "&"; break; case '<': h = h + "<"; break; case '>': h = h + ">"; break; default: h = h + c; } } return h; } @Override public synchronized void println(String msg) { if (this.logFile != null && msg != null) { this.logFile.println(this.toHtml(msg) + "
"); this.logFile.flush(); } if (this.unaddedText == null) { this.unaddedText = msg; } else if (msg != null) { this.unaddedText = this.unaddedText + "\n" + msg; } if (this.unaddedText != null && this.canAddText()) { if (this.textArea.getText().length() == 0) { this.textArea.append(this.unaddedText); } else { this.textArea.append("\n" + this.unaddedText); } this.unaddedText = null; String text = this.textArea.getText(); if (text.length() > 20000) { int linePos = text.indexOf(10, 10240); if (linePos >= 0) { text = text.substring(linePos + 1); linePos = text.lastIndexOf(10); if (linePos > 0) { this.textArea.setText(text.substring(0, linePos)); this.textArea.append(text.substring(linePos)); } } } if (this.isShared) { sharedText = text; } else { this.unsharedText = text; } } } @Override public synchronized void scrollToBottom() { String text = this.textArea.getText(); int textlen = text.length(); this.textArea.select(textlen, textlen); } @Override public synchronized boolean handleEvent(Event event) { if (event.id == 1004) { this.haveFocus = true; } else if (event.id == 1005) { this.haveFocus = false; } this.poll(); return super.handleEvent(event); } @Override public void poll() { if (this.unaddedText != null) { this.println(null); } } @Override public boolean isFocusTraversable() { return false; } }