com.vectorprint.configuration.observing.HandleEmptyValues Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of VectorPrintConfig Show documentation
Show all versions of VectorPrintConfig Show documentation
A library for configuration of applications and parameterization of objects. Settings can be provided in a configfile (file, url, stream), as arguments and programmatically, object parameters can be set using annotations or code. Both provide data type support, serialization, cloning, a help mechanism.
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package com.vectorprint.configuration.observing;
/*
* #%L
* VectorPrintConfig3.0
* %%
* Copyright (C) 2011 - 2013 VectorPrint
* %%
* 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.
* #L%
*/
import com.vectorprint.VectorPrintRuntimeException;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.Logger;
/**
* Class for dealing with empty (null or empty) values, throws an exception when an empty value is found or logs a
* warning, depending on {@link #HandleEmptyValues(boolean) the constructor argument}. A list of keys that never have
* values is skipped in the check. empties
*
* @author Eduard Drenth at VectorPrint.nl
*/
public class HandleEmptyValues extends AbstractPrepareKeyValue {
/**
* allow settings to be empty
*/
public static final String ALLOW_EMPTY_SETTINGS = "-allowemptyvalues";
private boolean allowEmpty = false;
private static final Logger log = Logger.getLogger(HandleEmptyValues.class.getName());
/**
*
* @param allowEmpty when true log a warning for empties otherwise throw an exception
*/
public HandleEmptyValues(boolean allowEmpty) {
this.allowEmpty = allowEmpty;
addKeyToSkip(ALLOW_EMPTY_SETTINGS);
}
@Override
public Map prepare(String key, String value) {
if (value == null || value.isEmpty()) {
if (allowEmpty) {
log.warning("empty value for key: " + key);
} else {
throw new VectorPrintRuntimeException("empty value not allowed for key: " + key);
}
}
Map m = new HashMap(1);
m.put(key, value);
return m;
}
}