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

com.cedarsoftware.io.reflect.InjectorFactory Maven / Gradle / Ivy

There is a newer version: 4.30.0
Show newest version
package com.cedarsoftware.io.reflect;

import java.lang.reflect.Field;
import java.util.Map;
import java.util.Optional;

/**
 * @author Kenny Partlow ([email protected])
 *         
* Copyright (c) Cedar Software LLC *

* 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 *

* License *

* 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. */ public interface InjectorFactory { /** * Creates accessors for accessing data from an object. * * @param field The field we're trying to access * @param nonStandardNames a map of possible methods from the class itself * @param uniqueName a uniqueName to use as a key in map if the class has two methods with same name. * @return The accessor if one fits for this field, otherwise null. */ Injector createInjector(Field field, Map, Map> nonStandardNames, String uniqueName); default Optional getMapping(Map, Map> classToMapping, Class c, String fieldName) { Map mapping = classToMapping.get(c); return mapping == null ? Optional.empty() : Optional.ofNullable(mapping.get(fieldName)); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy