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

org.tensorics.core.util.Instantiators Maven / Gradle / Ivy

Go to download

Tensorics is a java framework which uses a tensor as a central object. A tensor represents a set of values placed in an N-dimensional space. Wherever you are tempted to use maps of maps, a tensor might be a good choice ;-) Tensorics provides methods to create, transform and performing calculations with those tensors.

There is a newer version: 0.0.81
Show newest version
// @formatter:off
 /*******************************************************************************
 *
 * This file is part of tensorics.
 * 
 * Copyright (c) 2008-2011, CERN. All rights reserved.
 *
 * 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.
 * 
 ******************************************************************************/
// @formatter:on

package org.tensorics.core.util;

import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.Preconditions;

/**
 * Contains utility methods which help to instantiate classes which follow certain conventions. The most common one is
 * that e.g. a class provides a constructor with one argument of a certain type.
 * 
 * @author kfuchsbe
 */
public final class Instantiators {

    /**
     * Private Constructor to avoid instantiation
     */
    private Instantiators() {
        /* only static methods */
    }

    /**
     * Starting point for fluent clauses to create instantiators for certain type of objects. A typical example for the
     * creation of a certain type of object (Instance) with an argument of a certain type (Argument) could look like
     * this:
     * 
     * 
     * 
     *   Instantiator instantiator = 
     *      instantiatorFor(Instance.class).withArgumentType(Argument.class);
     * 
     *   Instance instance = instantiator.create(anArgument); // anArgument being of type Argument
     * 
     * 
* * @param instanceClass the type of the objects to be created by the instantiator * @return an objects that provides methods for refinements of the instantiator */ public static OngoingInstantiatorCreation instantiatorFor(Class instanceClass) { return new OngoingInstantiatorCreation<>(InstantiatorType.FACTORY_METHOD, instanceClass); } /** * Part of a fluent API to create Instantiators with one arguments. * * @author kfuchsbe * @param the type of the objects that will be finally created by the instantiators */ public static final class OngoingInstantiatorCreation { private final Class instanceClass; private final InstantiatorType type; /** * Constructor, which takes the class of the objects to instantiate, package private because it will be * instantiated from within this class only. * * @param instanceClass the type of the objects to create */ OngoingInstantiatorCreation(InstantiatorType type, Class instanceClass) { this.instanceClass = checkNotNull(instanceClass, "Class to instantiate must not be null!"); this.type = checkNotNull(type, "Instantiator type must not be null"); } public OngoingInstantiatorCreation ofType(InstantiatorType newType) { return new OngoingInstantiatorCreation<>(newType, instanceClass); } /** * Creates the Instantiator for the previously specified object type and the given type of arguments for the * object constructor. The returned Instantiator is reusable and thread safe, because it does not contain any * state. * * @param argumentClass the type of the argument of the constructor for the object * @return a new instantiator */ public Instantiator withArgumentType(Class argumentClass) { Preconditions.checkNotNull(argumentClass, "The type of the constructor argument must not be null!"); return type.createInstantiator(instanceClass, argumentClass); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy