org.apache.rocketmq.shade.ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy Maven / Gradle / Ivy
/**
* Logback: the reliable, generic, fast and flexible logging framework.
* Copyright (C) 1999-2015, QOS.ch. All rights reserved.
*
* This program and the accompanying materials are dual-licensed under
* either the terms of the Eclipse Public License v1.0 as published by
* the Eclipse Foundation
*
* or (per the licensee's choosing)
*
* under the terms of the GNU Lesser General Public License version 2.1
* as published by the Free Software Foundation.
*/
package org.apache.rocketmq.shade.ch.qos.logback.core.rolling;
import org.apache.rocketmq.shade.ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP.Usage;
import org.apache.rocketmq.shade.ch.qos.logback.core.util.FileSize;
public class SizeAndTimeBasedRollingPolicy extends TimeBasedRollingPolicy {
FileSize maxFileSize;
@Override
public void start() {
SizeAndTimeBasedFNATP sizeAndTimeBasedFNATP = new SizeAndTimeBasedFNATP(Usage.EMBEDDED);
if (maxFileSize == null) {
addError("maxFileSize property is mandatory.");
return;
} else {
addInfo("Archive files will be limited to [" + maxFileSize + "] each.");
}
sizeAndTimeBasedFNATP.setMaxFileSize(maxFileSize);
timeBasedFileNamingAndTriggeringPolicy = sizeAndTimeBasedFNATP;
if (!isUnboundedTotalSizeCap() && totalSizeCap.getSize() < maxFileSize.getSize()) {
addError("totalSizeCap of [" + totalSizeCap + "] is smaller than maxFileSize [" + maxFileSize
+ "] which is non-sensical");
return;
}
// most work is done by the parent
super.start();
}
public void setMaxFileSize(FileSize aMaxFileSize) {
this.maxFileSize = aMaxFileSize;
}
@Override
public String toString() {
return "c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@" + this.hashCode();
}
}