#region Copyright & License // // Copyright 2001-2005 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. // #endregion using System; using System.Text; using System.IO; using log4net.Core; namespace log4net.Layout.Pattern { /// /// Converter to output the relative time of the event /// /// /// /// Converter to output the time of the event relative to the start of the program. /// /// /// Nicko Cadell internal sealed class RelativeTimePatternConverter : PatternLayoutConverter { /// /// Write the relative time to the output /// /// that will receive the formatted result. /// the event being logged /// /// /// Writes out the relative time of the event in milliseconds. /// That is the number of milliseconds between the event /// and the . /// /// override protected void Convert(TextWriter writer, LoggingEvent loggingEvent) { writer.Write( TimeDifferenceInMillis(LoggingEvent.StartTime, loggingEvent.TimeStamp).ToString(System.Globalization.NumberFormatInfo.InvariantInfo) ); } /// /// Helper method to get the time difference between two DateTime objects /// /// start time (in the current local time zone) /// end time (in the current local time zone) /// the time difference in milliseconds private static long TimeDifferenceInMillis(DateTime start, DateTime end) { // We must convert all times to UTC before performing any mathematical // operations on them. This allows use to take into account discontinuities // caused by daylight savings time transitions. return (long)(end.ToUniversalTime() - start.ToUniversalTime()).TotalMilliseconds; } } }