The version of Apache log4j used by SoundHelix.
Clone
HTTPS:
git clone https://vervis.peers.community/repos/aEp6o
SSH:
git clone USERNAME@vervis.peers.community:aEp6o
Branches
Tags
- 1.3alpha-7
- CHAINSAW_2_SANDBOX_MERGE
- CORE_VERSION
- LEVEL_REPLACES_PRIORITY
- PREALPHA_1_3_AS_OF_2004_05_12
- PRE_CHAINSAW_MODEL_CONVERSION
- PRE_UGLI_MOVE
- TAG_CHAINSAW2_MOVE
- log4j-1.2.17
- log4j-1.2.17-rc1
- v1.3alpha8
- v1.3alpha8-temp
- v1_2_1
- v1_2_10-recalled
- v1_2_11
- v1_2_11_rc1
- v1_2_11rc3
- v1_2_12
- v1_2_12_rc1
- v1_2_12_rc2
- v1_2_12_rc3
- v1_2_12_rc4
- v1_2_12_rc5
- v1_2_12_rc6
- v1_2_13
- v1_2_13_rc1
- v1_2_13_rc2
- v1_2_13_site_update
- v1_2_14
- v1_2_14_maven
- v1_2_14_rc1
- v1_2_14_site_update
- v1_2_15
- v1_2_15_rc1
- v1_2_15_rc2
- v1_2_15_rc3
- v1_2_15_rc4
- v1_2_15_rc5
- v1_2_15_rc6
- v1_2_16
- v1_2_16_rc1
- v1_2_16_rc2
- v1_2_17
- v1_2_17-rc1
- v1_2_17_rc1
- v1_2_17_rc2
- v1_2_17_rc3
- v1_2_2
- v1_2_3
- v1_2_4
- v1_2_6
- v1_2_7
- v1_2_9
- v1_2_alpha0
- v1_2_alpha7
- v1_2beta1
- v1_2final
- v1_3alpha_1
- v1_3alpha_6
- v_1_0
- v_1_0_1
- v_1_0_4
- v_1_1
- v_1_1_1
- v_1_1_2
- v_1_1_3
- v_1_1_b1
- v_1_1b2
- v_1_1b3
- v_1_1b5
- v_1_1b6
- v_1_1b7
- v_1_2beta3
PatternConverter.java
/*
* Copyright 1999,2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.log4j.pattern;
import org.apache.log4j.spi.LoggingEvent;
import java.io.IOException;
import java.io.Writer;
import java.util.List;
/**
<p>PatternConverter is an abtract class that provides the
formatting functionality that derived classes need.
<p>Conversion specifiers in a conversion patterns are parsed to
individual PatternConverters. Each of which is responsible for
converting a logging event in a converter specific manner.
@author <a href="mailto:cakalijp@Maritz.com">James P. Cakalic</a>
@author Ceki Gülcü
@author Chris Nokes
@since 0.8.2
*/
public abstract class PatternConverter {
static String[] SPACES =
{
" ", " ", " ", " ", //1,2,4,8 spaces
" ", // 16 spaces
" " // 32 spaces
};
public PatternConverter next;
int min = -1;
int max = 0x7FFFFFFF;
boolean leftAlign = false;
//String option;
protected PatternConverter() {
}
protected PatternConverter(FormattingInfo fi) {
min = fi.min;
max = fi.max;
leftAlign = fi.leftAlign;
}
public void setFormattingInfo(FormattingInfo fi) {
min = fi.min;
max = fi.max;
leftAlign = fi.leftAlign;
}
/**
Derived pattern converters must override this method in order to
convert conversion specifiers in the correct way.
IMPORTANT: Note that an implementing class may always return the same
StringBuffer instance in order to avoid superflous object creation.
*/
protected abstract StringBuffer convert(LoggingEvent event);
/**
A template method for formatting in a converter specific way.
*/
public void format(Writer output, LoggingEvent e) throws IOException {
StringBuffer s = convert(e);
if (s == null) {
if (0 < min) {
spacePad(output, min);
}
return;
}
int len = s.length();
if (len > max) {
output.write(s.substring(len - max));
} else if (len < min) {
if (leftAlign) {
output.write(s.toString());
spacePad(output, min - len);
} else {
spacePad(output, min - len);
output.write(s.toString());
}
} else {
output.write(s.toString());
}
}
/**
Fast space padding method.
*/
public void spacePad(Writer output, int length) throws IOException {
while (length >= 32) {
output.write(SPACES[5]);
length -= 32;
}
for (int i = 4; i >= 0; i--) {
if ((length & (1 << i)) != 0) {
output.write(SPACES[i]);
}
}
}
/**
* Sets multiple options for the converter.
* @param options list of options, may be null.
*/
public void setOptions(List options) {
// NOP implementation. Most PC's do not deal with options.
}
/**
* This method returns the name of the conversion pattern.
*
* The name can be useful to certain Layouts such as HTMLLayout.
*
* @return the name of the conversion pattern
*/
public abstract String getName();
/**
* This method returns the CSS style class that should be applied to
* the LoggingEvent passed as parameter, which can be null.
*
* This information is currently used only by HTMLLayout.
*
* @param e null values are accepted
* @return the name of the conversion pattern
*/
public abstract String getStyleClass(LoggingEvent e);
/**
* Normally pattern converters are now meant to handle Exceptions although
* few pattern converters might.
*
* By examining the return values for this methd, the containing layout will
* determine whether it handles throwables or not.
* @return true if this PatternConverter handles throwables
*/
public boolean handlesThrowable() {
return false;
}
/**
* This method computes whether a chain of converters handles exceptions
* or not.
*
* @param head The first element of the chain
* @return true if can handle the throwable contained in logging events
*/
public static boolean chainHandlesThrowable(PatternConverter head) {
PatternConverter c = head;
while (c != null) {
if (c.handlesThrowable()) {
return true;
}
c = c.next;
}
return false;
}
}