Mercurial Hosting > luan
view src/goodjava/logger/RollingFileAppender.java @ 2023:544ccce564f6 default tip
minor
| author | Franklin Schmidt <fschmidt@gmail.com> | 
|---|---|
| date | Mon, 20 Oct 2025 17:34:14 -0600 | 
| parents | 97cc73664ca8 | 
| children | 
line wrap: on
 line source
package goodjava.logger; import java.io.File; import java.io.FileWriter; import java.io.IOException; import goodjava.io.IoUtils; public class RollingFileAppender extends WriterAppender { protected final String[] fileNames; protected final File file; public long maxFileSize = 10*1024*1024; public RollingFileAppender(Layout layout,String[] fileNames) throws IOException { super(layout,null); this.fileNames = fileNames; this.file = new File(fileNames[0]); open(); } protected void open() throws IOException { this.writer = new FileWriter(file,true); } public synchronized void append(LoggingEvent event) { super.append(event); if( file.length() > maxFileSize ) { rollOver(); } } protected void rollOver() { close(); File backup = new File(fileNames[fileNames.length-1]); try { IoUtils.delete(backup); for( int i=fileNames.length-2; i>=1; i-- ) { File f = backup; backup = new File(fileNames[i]); IoUtils.move(backup,f); } IoUtils.move(file,backup); open(); } catch(IOException e) { throw new RuntimeException(e); } } }
