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

net.projectmonkey.object.mapper.construction.rule.MappingRule Maven / Gradle / Ivy

Go to download

Object mapping implementation written as an alternative to modelmapper which is able to support inheritance, handles flattening / expanding in a precise way, and is extensible / configurable

The newest version!
package net.projectmonkey.object.mapper.construction.rule;

import net.projectmonkey.object.mapper.construction.PopulationContext;

/*
 *
 *  * Copyright 2012 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.
 *
 */

/**
 * Provides a means for determining whether specific mappings
 * should be included in the population process.
 *
 * Note that rules operate as Vetoers - if any rule says that the context
 * should not be mapped then it won't be.
 *
 * @author Andy Moody
 */
public interface MappingRule
{

	/**
	 * @param context - the mapping context for the property
	 * @return true if the property should be mapped, false otherwise.
	 */
	boolean isIncluded(PopulationContext context);

	/**
	 * Method used to validate whether a Rule is applicable for the context.
	 * Note that if this evaluates to false when the rule has been specifically
	 * targeted to the property or type using {@link net.projectmonkey.object.mapper.annotations.group.Group }
	 * or {@link net.projectmonkey.object.mapper.annotations.group.Groups } an error is triggered.
	 *
	 * @param context - the mapping context for the property
	 * @return true if the rules should be applied when mapping the specified context
	 * from the source to the destination, false otherwise.
	 */
	boolean isApplicableFor(PopulationContext context);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy