The version of Apache log4j used by SoundHelix.

[[ 🗃 ^aEp6o apache-log4j ]] :: [📥 Inbox] [📤 Outbox] [🐤 Followers] [🤝 Collaborators] [🛠 Commits]

Clone

HTTPS: git clone https://vervis.peers.community/repos/aEp6o

SSH: git clone USERNAME@vervis.peers.community:aEp6o

Branches

Tags

v1_3alpha_1 :: src / java / org / apache / log4j / rule /

LevelInequalityRule.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.
 */

package org.apache.log4j.rule;

import java.io.IOException;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;

import org.apache.log4j.Level;
import org.apache.log4j.helpers.UtilLoggingLevel;
import org.apache.log4j.spi.LoggingEvent;
import org.apache.log4j.spi.LoggingEventFieldResolver;

/**
 * A Rule class implementing inequality evaluation for Levels (log4j and util.logging) using the toInt method.
 * 
 * @author Scott Deboy <sdeboy@apache.org>
 */
public class LevelInequalityRule extends AbstractRule {
  static final long serialVersionUID = 851854546425717836L;

  private static final LoggingEventFieldResolver resolver = LoggingEventFieldResolver.getInstance();
  private transient Level level;
  private transient List utilList = new LinkedList();
  private transient List levelList = new LinkedList();
  private transient String inequalitySymbol;

  private LevelInequalityRule(
    String inequalitySymbol, String value) {
    levelList.add(Level.FATAL.toString());
    levelList.add(Level.ERROR.toString());
    levelList.add(Level.WARN.toString());
    levelList.add(Level.INFO.toString());
    levelList.add(Level.DEBUG.toString());

    Iterator iter = UtilLoggingLevel.getAllPossibleLevels().iterator();

    while (iter.hasNext()) {
      utilList.add(((UtilLoggingLevel) iter.next()).toString());
    }

    if (levelList.contains(value.toUpperCase())) {
      this.level = Level.toLevel(value.toUpperCase());
    } else {
      this.level = UtilLoggingLevel.toLevel(value.toUpperCase());
    }

    this.inequalitySymbol = inequalitySymbol;
  }

  public static Rule getRule(String inequalitySymbol, String value) {
      return new LevelInequalityRule(inequalitySymbol, value);
  }
  
  public boolean evaluate(LoggingEvent event) {
    //use the type of the first level to access the static toLevel method on the second param
    Level level2 = null;
    if (level instanceof UtilLoggingLevel) {
        level2 = UtilLoggingLevel.toLevel(resolver.getValue("LEVEL", event).toString());
    } else { 
        level2 = Level.toLevel(resolver.getValue("LEVEL", event).toString());
    }

    boolean result = false;
    int first = level2.toInt();
    int second = level.toInt();

    if ("<".equals(inequalitySymbol)) {
      result = first < second;
    } else if (">".equals(inequalitySymbol)) {
      result = first > second;
    } else if ("<=".equals(inequalitySymbol)) {
      result = first <= second;
    } else if (">=".equals(inequalitySymbol)) {
      result = first >= second;
    }

    return result;
  }
  
  /**
    * Deserialize the state of the object
    *
    * @param in 
    *
    * @throws IOException 
    * @throws ClassNotFoundException 
    */
   private void readObject(java.io.ObjectInputStream in)
     throws IOException, ClassNotFoundException {
     utilList = new LinkedList();
     levelList = new LinkedList();
     inequalitySymbol = (String)in.readObject();
     boolean isUtilLogging = in.readBoolean();
     int levelInt = in.readInt();
     if (isUtilLogging) {
         level = UtilLoggingLevel.toLevel(levelInt);
     } else {
         level = Level.toLevel(levelInt);
     }
   }

   /**
    * Serialize the state of the object
    *
    * @param out 
    *
    * @throws IOException 
    */
   private void writeObject(java.io.ObjectOutputStream out)
     throws IOException {
     out.writeObject(inequalitySymbol);
     out.writeBoolean(level instanceof UtilLoggingLevel);
     out.writeInt(level.toInt());
   }
}

[See repo JSON]