#region Apache License // // Licensed to the Apache Software Foundation (ASF) under one or more // contributor license agreements. See the NOTICE file distributed with // this work for additional information regarding copyright ownership. // The ASF licenses this file to you 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. // #endregion using System; using System.IO; using System.Text; using log4net.Util; using log4net.Core; namespace log4net.Layout { /// /// A very simple layout /// /// /// /// SimpleLayout consists of the level of the log statement, /// followed by " - " and then the log message itself. For example, /// /// DEBUG - Hello world /// /// /// /// Nicko Cadell /// Gert Driesen public class SimpleLayout : LayoutSkeleton { #region Constructors /// /// Constructs a SimpleLayout /// public SimpleLayout() { IgnoresException = true; } #endregion #region Implementation of IOptionHandler /// /// Initialize layout options /// /// /// /// This is part of the delayed object /// activation scheme. The method must /// be called on this object after the configuration properties have /// been set. Until is called this /// object is in an undefined state and must not be used. /// /// /// If any of the configuration properties are modified then /// must be called again. /// /// override public void ActivateOptions() { // nothing to do. } #endregion #region Override implementation of LayoutSkeleton /// /// Produces a simple formatted output. /// /// the event being logged /// The TextWriter to write the formatted event to /// /// /// Formats the event as the level of the even, /// followed by " - " and then the log message itself. The /// output is terminated by a newline. /// /// override public void Format(TextWriter writer, LoggingEvent loggingEvent) { if (loggingEvent == null) { throw new ArgumentNullException("loggingEvent"); } writer.Write(loggingEvent.Level.DisplayName); writer.Write(" - "); loggingEvent.WriteRenderedMessage(writer); writer.WriteLine(); } #endregion } }