All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.logging.log4j.message.StringFormattedMessage Maven / Gradle / Ivy

The newest version!
/*
 * 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.
 */
package org.apache.logging.log4j.message;

import java.util.Arrays;
import java.util.IllegalFormatException;
import java.util.Locale;
import java.util.Objects;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.status.StatusLogger;

/**
 * Handles messages that consist of a format string conforming to {@link java.util.Formatter}.
 *
 * 

* Note to implementors: *

*

* This class implements the unrolled args API even though StringFormattedMessage does not. This leaves the room for * StringFormattedMessage to unroll itself later. *

*/ public class StringFormattedMessage implements Message { private static final Logger LOGGER = StatusLogger.getLogger(); private final String messagePattern; private final Object[] argArray; private String formattedMessage; private Throwable throwable; private final Locale locale; /** * Constructs a message. * * @param locale the locale for this message format * @param messagePattern the pattern for this message format * @param arguments The objects to format * @since 2.6 */ public StringFormattedMessage(final Locale locale, final String messagePattern, final Object... arguments) { this.locale = locale; this.messagePattern = messagePattern; this.argArray = arguments; if (arguments != null && arguments.length > 0 && arguments[arguments.length - 1] instanceof Throwable) { this.throwable = (Throwable) arguments[arguments.length - 1]; } } /** * Constructs a message. * * @param messagePattern the pattern for this message format * @param arguments The objects to format * @since 2.6 */ public StringFormattedMessage(final String messagePattern, final Object... arguments) { this(Locale.getDefault(Locale.Category.FORMAT), messagePattern, arguments); } /** * Returns the formatted message. * @return the formatted message. */ @Override public String getFormattedMessage() { if (formattedMessage == null) { formattedMessage = formatMessage(messagePattern, argArray); } return formattedMessage; } /** * Returns the message pattern. * @return the message pattern. */ @Override public String getFormat() { return messagePattern; } /** * Returns the message parameters. * @return the message parameters. */ @Override public Object[] getParameters() { return argArray; } protected String formatMessage(final String msgPattern, final Object... args) { if (args != null && args.length == 0) { // Avoids some exceptions for LOG4J2-3458 return msgPattern; } try { return String.format(locale, msgPattern, args); } catch (final IllegalFormatException ife) { LOGGER.error("Unable to format msg: {}", msgPattern, ife); return msgPattern; } } @Override public boolean equals(final Object o) { if (this == o) { return true; } if (!(o instanceof StringFormattedMessage)) { return false; } final StringFormattedMessage that = (StringFormattedMessage) o; return Objects.equals(messagePattern, that.messagePattern) && Arrays.equals(argArray, that.argArray); } @Override public int hashCode() { int result = Objects.hash(messagePattern); result = 31 * result + Arrays.hashCode(argArray); return result; } @Override public String toString() { return getFormattedMessage(); } /** * Return the throwable passed to the Message. * * @return the Throwable. */ @Override public Throwable getThrowable() { return throwable; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy