#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 log4net.Core; namespace log4net.Filter { /// /// Subclass this type to implement customized logging event filtering /// /// /// /// Users should extend this class to implement customized logging /// event filtering. Note that and /// , the parent class of all standard /// appenders, have built-in filtering rules. It is suggested that you /// first use and understand the built-in rules before rushing to write /// your own custom filters. /// /// /// This abstract class assumes and also imposes that filters be /// organized in a linear chain. The /// method of each filter is called sequentially, in the order of their /// addition to the chain. /// /// /// The method must return one /// of the integer constants , /// or . /// /// /// If the value is returned, then the log event is dropped /// immediately without consulting with the remaining filters. /// /// /// If the value is returned, then the next filter /// in the chain is consulted. If there are no more filters in the /// chain, then the log event is logged. Thus, in the presence of no /// filters, the default behavior is to log all logging events. /// /// /// If the value is returned, then the log /// event is logged without consulting the remaining filters. /// /// /// The philosophy of log4net filters is largely inspired from the /// Linux ipchains. /// /// /// Nicko Cadell /// Gert Driesen public abstract class FilterSkeleton : IFilter { #region Member Variables /// /// Points to the next filter in the filter chain. /// /// /// /// See for more information. /// /// private IFilter m_next; #endregion #region Implementation of IOptionHandler /// /// Initialize the filter with the options set /// /// /// /// 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. /// /// /// Typically filter's options become active immediately on set, /// however this method must still be called. /// /// virtual public void ActivateOptions() { } #endregion #region Implementation of IFilter /// /// Decide if the should be logged through an appender. /// /// The to decide upon /// The decision of the filter /// /// /// If the decision is , then the event will be /// dropped. If the decision is , then the next /// filter, if any, will be invoked. If the decision is then /// the event will be logged without consulting with other filters in /// the chain. /// /// /// This method is marked abstract and must be implemented /// in a subclass. /// /// abstract public FilterDecision Decide(LoggingEvent loggingEvent); /// /// Property to get and set the next filter /// /// /// The next filter in the chain /// /// /// /// Filters are typically composed into chains. This property allows the next filter in /// the chain to be accessed. /// /// public IFilter Next { get { return m_next; } set { m_next = value; } } #endregion } }