1 package org.apache.helix.tools;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import java.io.File;
23 import java.io.IOException;
24 import java.lang.management.ManagementFactory;
25 import java.lang.management.RuntimeMXBean;
26 import java.text.SimpleDateFormat;
27 import java.util.Calendar;
28 import java.util.Date;
29 import java.util.List;
30
31 import org.apache.log4j.FileAppender;
32 import org.apache.log4j.Layout;
33 import org.apache.log4j.spi.ErrorCode;
34
35 public class CLMLogFileAppender extends FileAppender
36 {
37 public CLMLogFileAppender()
38 {
39 }
40
41 public CLMLogFileAppender(Layout layout, String filename, boolean append,
42 boolean bufferedIO, int bufferSize) throws IOException
43 {
44 super(layout, filename, append, bufferedIO, bufferSize);
45 }
46
47 public CLMLogFileAppender(Layout layout, String filename, boolean append)
48 throws IOException
49 {
50 super(layout, filename, append);
51 }
52
53 public CLMLogFileAppender(Layout layout, String filename) throws IOException
54 {
55 super(layout, filename);
56 }
57
58 public void activateOptions()
59 {
60 if (fileName != null)
61 {
62 try
63 {
64 fileName = getNewLogFileName();
65 setFile(fileName, fileAppend, bufferedIO, bufferSize);
66 } catch (Exception e)
67 {
68 errorHandler.error("Error while activating log options", e,
69 ErrorCode.FILE_OPEN_FAILURE);
70 }
71 }
72 }
73
74 private String getNewLogFileName()
75 {
76 Calendar cal = Calendar.getInstance();
77 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss-SSS");
78 String time = sdf.format(cal.getTime());
79
80 StackTraceElement[] stack = Thread.currentThread().getStackTrace();
81 StackTraceElement main = stack[stack.length - 1];
82 String mainClass = main.getClassName();
83
84 return System.getProperty("user.home") + "/EspressoLogs/" + mainClass + "_"
85 + time + ".txt";
86 }
87 }