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
LocationInfo.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.
*/
// Contributors: Mathias Rupprecht <mmathias.rupprecht@fja.com>
package org.apache.log4j.spi;
import org.apache.log4j.helpers.PlatformInfo;
import org.apache.log4j.spi.location.LegacyExtractor;
import org.apache.log4j.spi.location.StackTraceElementExtractor;
/**
The internal representation of caller location information.
@since 0.8.3
*/
public class LocationInfo implements java.io.Serializable {
/**
When location information is not available the constant
<code>NA</code> is returned. Current value of this string
constant is <b>?</b>. */
public static final String NA = "?";
static final long serialVersionUID = -1325822038990805636L;
/**
* NA_LOCATION_INFO is used in conjunction with deserialized LoggingEvents
* without real location info available.
* @since 1.3
*/
public static LocationInfo NA_LOCATION_INFO = new LocationInfo(NA, NA, NA, NA);
/**
Caller's line number.
*/
public String lineNumber;
/**
Caller's file name.
*/
public String fileName;
/**
Caller's fully qualified class name.
*/
public String className;
/**
Caller's method name.
*/
public String methodName;
/**
All available caller information, in the format
<code>fully.qualified.classname.of.caller.methodName(Filename.java:line)</code>
*/
public transient String fullInfo;
public LocationInfo(
String fileName, String className, String methodName, String lineNumber) {
this.fileName = fileName;
this.className = className;
this.methodName = methodName;
this.lineNumber = lineNumber;
}
/**
Instantiate location information based on a Throwable. We
expect the Throwable <code>t</code>, to be in the format
<pre>
java.lang.Throwable
...
at org.apache.log4j.PatternLayout.format(PatternLayout.java:413)
at org.apache.log4j.FileAppender.doAppend(FileAppender.java:183)
at org.apache.log4j.Category.callAppenders(Category.java:131)
at org.apache.log4j.Category.log(Category.java:512)
at callers.fully.qualified.className.methodName(FileName.java:74)
...
</pre>
<p>However, we can also deal with JIT compilers that "lose" the
location information, especially between the parentheses.
*/
public LocationInfo(Throwable t, String fqnOfInvokingClass) {
if (t == null) {
return;
}
if(PlatformInfo.hasStackTraceElement()) {
StackTraceElementExtractor.extract(this, t, fqnOfInvokingClass);
} else {
LegacyExtractor.extract(this, t, fqnOfInvokingClass);
}
}
public boolean equals(Object o) {
//LogLog.info("equals called");
if (this == o) {
return true;
}
if (!(o instanceof LocationInfo)) {
//LogLog.info("inequality point 1");
return false;
}
LocationInfo r = (LocationInfo) o;
if(!getClassName().equals(r.getClassName())){
//LogLog.info("inequality point 2");
return false;
}
if(!getFileName().equals(r.getFileName())) {
//LogLog.info("inequality point 3");
return false;
}
if(!getMethodName().equals(r.getMethodName())){
//LogLog.info("inequality point 4");
return false;
}
if(!getLineNumber().equals(r.getLineNumber())){
//LogLog.info("inequality point 5");
return false;
}
return true;
}
/**
Return the fully qualified class name of the caller making the
logging request.
*/
public String getClassName() {
return className;
}
/**
Return the file name of the caller.
<p>This information is not always available.
*/
public String getFileName() {
return fileName;
}
/**
Returns the line number of the caller.
<p>This information is not always available.
*/
public String getLineNumber() {
return lineNumber;
}
/**
Returns the method name of the caller.
*/
public String getMethodName() {
return methodName;
}
/**
* fullInfo format is:
* <code>fully.qualified.classname.of.caller.methodName(Filename.java:line)</code>
*/
public String getFullInfo() {
if(fullInfo == null) {
fullInfo = getClassName()+"."+getMethodName()+"("+getFileName()+":"+
getLineNumber()+")";
}
return fullInfo;
}
public String toString() {
return "(class="+getClassName()+", file="+getFileName()+", line="+getLineNumber()+", methodName="+getMethodName();
}
}