/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at legal-notices/CDDLv1_0.txt * or http://forgerock.org/license/CDDLv1.0.html. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at legal-notices/CDDLv1_0.txt. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2006-2008 Sun Microsystems, Inc. * Portions Copyright 2013 ForgeRock AS. */ package org.opends.server.loggers; import java.util.ArrayList; /** * The category class defines a set of standard logging types that * can be used to control logging output. */ public class LogCategory { private static ArrayList known = new ArrayList(); /** * The non-localized name of the type. */ private final String name; /** * Create a named type. *

* Note that this constructor is "protected" to allow sub-classing. * * @param name the name of the category, for example "MESSAGE". */ protected LogCategory(String name) { if (name == null) { throw new NullPointerException(); } this.name = name; known.add(this); } /** * Return the non-localized string name of the Level. * * @return non-localized name */ public String getName() { return name; } /** * Retrieves the string representation of this log category. * * @return the non-localized name of the LogCategory, for example "ENTRY". */ public final String toString() { return name; } /** * Parse a category name string into a LogCategory. *

* For example: *

* @param name string to be parsed * @throws IllegalArgumentException if the value is not valid. * Known names are the categories defined by this class or created * by this class with appropriate package access, or new levels defined * or created by subclasses. * * @return The parsed category */ public static synchronized LogCategory parse(String name) throws IllegalArgumentException { // Check that name is not null. name.length(); // Look for a known Level with the given name. for (int i = 0; i < known.size(); i++) { LogCategory c = known.get(i); if (name.equalsIgnoreCase(c.name)) { return c; } } // OK, we've tried everything and failed throw new IllegalArgumentException("Bad category \"" + name + "\""); } }