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

jvmMain.com.giancarlobuenaflor.kflogger.parameter.SimpleParameter Maven / Gradle / Ivy

/*
 * Copyright (C) 2012 The Flogger Authors.
 *
 * 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 com.giancarlobuenaflor.kflogger.parameter;

import static com.giancarlobuenaflor.kflogger.util.Checks.checkNotNull;

import com.giancarlobuenaflor.kflogger.backend.FormatChar;
import com.giancarlobuenaflor.kflogger.backend.FormatOptions;
import java.util.Collections;
import java.util.EnumMap;
import java.util.Map;

/**
 * A simple, single argument, parameter which can format arguments according to the rules specified
 * by {@link FormatChar}.
 * 

* This class is immutable and thread safe, as per the Parameter contract. */ public final class SimpleParameter extends Parameter { /** Cache parameters with indices 0-9 to cover the vast majority of cases. */ private static final int MAX_CACHED_PARAMETERS = 10; /** Map of the most common default general parameters (corresponds to %s, %d, %f etc...). */ private static final Map DEFAULT_PARAMETERS; static { Map map = new EnumMap(FormatChar.class); for (FormatChar fc : FormatChar.values()) { map.put(fc, createParameterArray(fc)); } DEFAULT_PARAMETERS = Collections.unmodifiableMap(map); } /** Helper to make reusable default parameter instances for the commonest indices. */ private static SimpleParameter[] createParameterArray(FormatChar formatChar) { SimpleParameter[] parameters = new SimpleParameter[MAX_CACHED_PARAMETERS]; for (int index = 0; index < MAX_CACHED_PARAMETERS; index++) { parameters[index] = new SimpleParameter(index, formatChar, FormatOptions.getDefault()); } return parameters; } /** * Returns a {@link Parameter} representing the given formatting options of the specified * formatting character. Note that a cached value may be returned. * * @param index the index of the argument to be processed. * @param formatChar the basic formatting type. * @param options additional formatting options. * @return the immutable, thread safe parameter instance. */ public static SimpleParameter of(int index, FormatChar formatChar, FormatOptions options) { // We can safely test FormatSpec with '==' because the factory methods always return the default // instance if applicable (and the class has no visible constructors). if (index < MAX_CACHED_PARAMETERS && options.isDefault()) { return DEFAULT_PARAMETERS.get(formatChar)[index]; } return new SimpleParameter(index, formatChar, options); } private final FormatChar formatChar; private final String formatString; private SimpleParameter(int index, FormatChar formatChar, FormatOptions options) { super(options, index); this.formatChar = checkNotNull(formatChar, "format char"); // TODO: Consider special case for hex strings where options are common (HexParameter?). this.formatString = options.isDefault() ? formatChar.getDefaultFormatString() : buildFormatString(options, formatChar); } // Visible for testing. static String buildFormatString(FormatOptions options, FormatChar formatChar) { // The format char is guaranteed to be a lower-case ASCII character, so can be made upper case // by simply subtracting 0x20 (or clearing the 6th bit). char c = formatChar.getChar(); c = options.shouldUpperCase() ? (char) (c & ~0x20) : c; return options.appendPrintfOptions(new StringBuilder("%")).append(c).toString(); } @Override protected void accept(ParameterVisitor visitor, Object value) { visitor.visit(value, formatChar, getFormatOptions()); } @Override public String getFormat() { return formatString; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy