org.apache.log4j

Class TTCCLayout

Implemented Interfaces:
OptionHandler

public class TTCCLayout
extends DateLayout

TTCC layout format consists of time, thread, category and nested diagnostic context information, hence the name.

Each of the four fields can be individually enabled or disabled. The time format depends on the DateFormat used.

Here is an example TTCCLayout output with the RelativeTimeDateFormat.

176 [main] INFO  org.apache.log4j.examples.Sort - Populating an array of 2 elements in reverse order.
225 [main] INFO  org.apache.log4j.examples.SortAlgo - Entered the sort method.
262 [main] DEBUG org.apache.log4j.examples.SortAlgo.OUTER i=1 - Outer loop.
276 [main] DEBUG org.apache.log4j.examples.SortAlgo.SWAP i=1 j=0 - Swapping intArray[0] = 1 and intArray[1] = 0
290 [main] DEBUG org.apache.log4j.examples.SortAlgo.OUTER i=0 - Outer loop.
304 [main] INFO  org.apache.log4j.examples.SortAlgo.DUMP - Dump of interger array:
317 [main] INFO  org.apache.log4j.examples.SortAlgo.DUMP - Element [0] = 0
331 [main] INFO  org.apache.log4j.examples.SortAlgo.DUMP - Element [1] = 1
343 [main] INFO  org.apache.log4j.examples.Sort - The next log statement should be an error message.
346 [main] ERROR org.apache.log4j.examples.SortAlgo.DUMP - Tried to dump an uninitialized array.
at org.apache.log4j.examples.SortAlgo.dump(SortAlgo.java:58)
at org.apache.log4j.examples.Sort.main(Sort.java:64)
467 [main] INFO  org.apache.log4j.examples.Sort - Exiting main method.

The first field is the number of milliseconds elapsed since the start of the program. The second field is the thread outputting the log statement. The third field is the level, the fourth field is the category to which the statement belongs.

The fifth field (just before the '-') is the nested diagnostic context. Note the nested diagnostic context may be empty as in the first two statements. The text after the '-' is the message of the statement.

WARNING Do not use the same TTCCLayout instance from within different appenders. The TTCCLayout is not thread safe when used in his way. However, it is perfectly safe to use a TTCCLayout instance from just one appender.

PatternLayout offers a much more flexible alternative.

Authors:
Ceki Gülcü
Heinz Richter

Field Summary

protected StringBuffer
buf

Fields inherited from class org.apache.log4j.helpers.DateLayout

DATE_FORMAT_OPTION, NULL_DATE_FORMAT, RELATIVE_TIME_DATE_FORMAT, TIMEZONE_OPTION, date, dateFormat, pos

Fields inherited from class org.apache.log4j.Layout

LINE_SEP, LINE_SEP_LEN

Constructor Summary

TTCCLayout()
Instantiate a TTCCLayout object with RelativeTimeDateFormat as the date formatter in the local time zone.
TTCCLayout(String dateFormatType)
Instantiate a TTCCLayout object using the local time zone.

Method Summary

String
format(LoggingEvent event)
In addition to the level of the statement and message, the returned byte array includes time, thread, category and NDC information.
boolean
getCategoryPrefixing()
Returns value of the CategoryPrefixing option.
boolean
getContextPrinting()
Returns value of the ContextPrinting option.
boolean
getThreadPrinting()
Returns value of the ThreadPrinting option.
boolean
ignoresThrowable()
The TTCCLayout does not handle the throwable contained within LoggingEvents.
void
setCategoryPrefixing(boolean categoryPrefixing)
The CategoryPrefixing option specifies whether Category name is part of log output or not.
void
setContextPrinting(boolean contextPrinting)
The ContextPrinting option specifies log output will include the nested context information belonging to the current thread.
void
setThreadPrinting(boolean threadPrinting)
The ThreadPrinting option specifies whether the name of the current thread is part of log output or not.

Methods inherited from class org.apache.log4j.helpers.DateLayout

activateOptions, dateFormat, getDateFormat, getOptionStrings, getTimeZone, setDateFormat, setDateFormat, setDateFormat, setOption, setTimeZone

Methods inherited from class org.apache.log4j.Layout

format, getContentType, getFooter, getHeader, ignoresThrowable

Field Details

buf

protected final StringBuffer buf

Constructor Details

TTCCLayout

public TTCCLayout()
Instantiate a TTCCLayout object with RelativeTimeDateFormat as the date formatter in the local time zone.
Since:
0.7.5

TTCCLayout

public TTCCLayout(String dateFormatType)
Instantiate a TTCCLayout object using the local time zone. The DateFormat used will depend on the dateFormatType.

This constructor just calls the DateLayout.setDateFormat method.

Method Details

format

public String format(LoggingEvent event)
In addition to the level of the statement and message, the returned byte array includes time, thread, category and NDC information.

Time, thread, category and diagnostic context are printed depending on options.

Overrides:
format in interface Layout
Parameters:
event - The event to format

getCategoryPrefixing

public boolean getCategoryPrefixing()
Returns value of the CategoryPrefixing option.

getContextPrinting

public boolean getContextPrinting()
Returns value of the ContextPrinting option.

getThreadPrinting

public boolean getThreadPrinting()
Returns value of the ThreadPrinting option.

ignoresThrowable

public boolean ignoresThrowable()
Overrides:
ignoresThrowable in interface Layout
Since:
version 0.8.4

setCategoryPrefixing

public void setCategoryPrefixing(boolean categoryPrefixing)
The CategoryPrefixing option specifies whether Category name is part of log output or not. This is true by default.

setContextPrinting

public void setContextPrinting(boolean contextPrinting)
The ContextPrinting option specifies log output will include the nested context information belonging to the current thread. This is true by default.

setThreadPrinting

public void setThreadPrinting(boolean threadPrinting)
The ThreadPrinting option specifies whether the name of the current thread is part of log output or not. This is true by default.

Copyright 2000-2005 Apache Software Foundation.