1
2
3
4
5
6
7
8
9
10
11
12 package ch.qos.logback.core.rolling;
13
14 import java.io.File;
15 import java.time.Instant;
16 import java.util.Date;
17
18 import ch.qos.logback.core.joran.spi.NoAutoStart;
19 import ch.qos.logback.core.rolling.helper.TimeBasedArchiveRemover;
20
21
22
23
24
25
26
27
28
29
30
31 @NoAutoStart
32 public class DefaultTimeBasedFileNamingAndTriggeringPolicy<E> extends TimeBasedFileNamingAndTriggeringPolicyBase<E> {
33
34 @Override
35 public void start() {
36 super.start();
37 if (!super.isErrorFree())
38 return;
39 if (tbrp.fileNamePattern.hasIntegerTokenCOnverter()) {
40 addError("Filename pattern [" + tbrp.fileNamePattern
41 + "] contains an integer token converter, i.e. %i, INCOMPATIBLE with this configuration. Please remove it.");
42 return;
43 }
44
45 archiveRemover = new TimeBasedArchiveRemover(tbrp.fileNamePattern, rc);
46 archiveRemover.setContext(context);
47 started = true;
48 }
49
50 public boolean isTriggeringEvent(File activeFile, final E event) {
51 long currentTime = getCurrentTime();
52 long localNextCheck = atomicNextCheck.get();
53 if (currentTime >= localNextCheck) {
54 long nextCheck = computeNextCheck(currentTime);
55 atomicNextCheck.set(nextCheck);
56 Instant instantOfElapsedPeriod = dateInCurrentPeriod;
57 addInfo("Elapsed period: " + instantOfElapsedPeriod.toString());
58 this.elapsedPeriodsFileName = tbrp.fileNamePatternWithoutCompSuffix.convert(instantOfElapsedPeriod);
59 setDateInCurrentPeriod(currentTime);
60 return true;
61 } else {
62 return false;
63 }
64 }
65
66 @Override
67 public String toString() {
68 return "c.q.l.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy";
69 }
70
71 }