net.derquinse.common.meta.MetaBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of derquinse-common-base Show documentation
Show all versions of derquinse-common-base Show documentation
Module containing support classes depending on Java SE 6, Guava 11 and Joda-Time 2.0
/*
* Copyright (C) the original author or 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 net.derquinse.common.meta;
import static com.google.common.base.Preconditions.checkNotNull;
import java.util.Map;
import net.derquinse.common.base.Builder;
import com.google.common.collect.Maps;
/**
* Meta builder class.
* @author Andres Rodriguez
* @param Built type.
*/
public abstract class MetaBuilder implements Builder {
/** Meta class. */
private final MetaClass metaClass;
/** Property value map. */
private final Map, Object> values = Maps.newHashMap();
MetaBuilder(MetaClass metaClass) {
this.metaClass = checkNotNull(metaClass);
}
final void checkField(MetaField super T, ?> field) {
if (!metaClass.getFields().containsValue(field)) {
throw new IllegalArgumentException(String.format("MetaClass [%s] does not contain field [%s]", metaClass, field));
}
}
final void checkFieldNotSet(MetaField super T, ?> field) {
checkField(field);
if (values.containsKey(field)) {
throw new IllegalArgumentException(String.format("Value already set for field [%s] of MetaClass [%s]", field,
metaClass));
}
}
/** Returns the metaclass of the object to build. */
public final MetaClass getMetaClass() {
return metaClass;
}
/**
* Sets a property value.
* @param property Property to set.
* @param value Value to set.
* @return This builder for method chaining.
* @throws IllegalArgumentException if the property is not defined for the meta class.
* @throws IllegalArgumentException If the value is not allowed for the property.
* @throws IllegalStateException If the value has already been set.
*/
public final MetaBuilder set(MetaProperty super T, V> property, V value) {
checkFieldNotSet(property);
property.checkValue(value);
values.put(property, value);
return this;
}
/**
* Sets a flag value.
* @param flag Flag to set.
* @param value Value to set.
* @return This builder for method chaining.
* @throws IllegalArgumentException if the property is not defined for the meta class.
* @throws IllegalArgumentException If the value is not allowed for the property.
* @throws IllegalStateException If the value has already been set.
*/
public final MetaBuilder set(MetaFlag super T> flag, boolean value) {
checkFieldNotSet(flag);
values.put(flag, value);
return this;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy