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

net.objectlab.kit.datecalc.common.KitCalculatorsFactory Maven / Gradle / Ivy

/*
 * ObjectLab, http://www.objectlab.co.uk/open is sponsoring the ObjectLab Kit.
 *
 * Based in London, we are world leaders in the design and development
 * of bespoke applications for the securities financing markets.
 *
 * Click here to learn more
 *           ___  _     _           _   _          _
 *          / _ \| |__ (_) ___  ___| |_| |    __ _| |__
 *         | | | | '_ \| |/ _ \/ __| __| |   / _` | '_ \
 *         | |_| | |_) | |  __/ (__| |_| |__| (_| | |_) |
 *          \___/|_.__// |\___|\___|\__|_____\__,_|_.__/
 *                   |__/
 *
 *                     www.ObjectLab.co.uk
 *
 * $Id$
 *
 * Copyright 2006 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.objectlab.kit.datecalc.common;

import java.util.Set;

import net.objectlab.kit.datecalc.common.ccy.CurrencyCalculatorConfig;

/**
 * Factory will create new instances of calculators, these are lightweight, each
 * thread should use the factory as a given calculator should NOT be shared
 * across thread (unless you know what you're doing) as the startDate, current
 * date and working week would be shared. Once created, the set of holidays will
 * NOT change even if a new set is registered; one needs to get a new
 * DateCalculator to get the new set.
 *
 * @author Benoit Xhenseval
 *
 * @param 
 *            a representation of a date, typically JDK: Date, Calendar;
 *            Joda:LocalDate, YearMonthDay
 *
 */
public interface KitCalculatorsFactory {

    /**
     * Create a new CurrencyDateCalculatorBuilder specialised for 2 currencies, including WorkingWeek, calendars registered and CurrencyCalculatorConfig.
     *
     * NOTE that USD currency holiday must also be registered.
     *
     * @param ccy1
     *            first currency, will pickup the holiday set for this ccy.
     * @param ccy2
     *            second currency, will pick up the holiday set for this ccy.
     * @param spotLag
     *            the number of days between tradeDate and spotDate.
     * @return a new CurrencyDateCalculatorBuilder
     * @exception IllegalArgumentException
     *                if the type is not null or a valid value.
     * @since 1.4.0
     */
    CurrencyDateCalculatorBuilder getDefaultCurrencyDateCalculatorBuilder(String ccy1, String ccy2, SpotLag spotLag);

    CurrencyDateCalculator buildCurrencyDateCalculator(CurrencyDateCalculatorBuilder builder);

    /**
     * Create a new IMMUTABLE CurrencyDateCalculator specialised for 2 currencies, including WorkingWeek, calendars
     * registered and CurrencyCalculatorConfig.
     *
     * NOTE that USD currency holiday must also be registered.
     *
     * @param ccy1
     *            first currency, will pickup the holiday set for this ccy.
     * @param ccy2
     *            second currency, will pick up the holiday set for this ccy.
     * @param spotLag
     *            the number of days between tradeDate and spotDate.
     * @return a new CurrencyDateCalculator
     * @exception IllegalArgumentException
     *                if the type is not null or a valid value.
     * @since 1.4.0
     */
    CurrencyDateCalculator getDefaultCurrencyDateCalculator(String ccy1, String ccy2, SpotLag spotLag);

    /**
     * Use this method register a specific currency config, if not provided then the DefaultCurrencyCalculatorConfig will be given.
     * @param config that specifies the set of currencies subject to USD T+1.
     */
    void setCurrencyCalculatorConfig(CurrencyCalculatorConfig config);

    CurrencyCalculatorConfig getCurrencyCalculatorConfig();

    /**
     * Create a new DateCalculator for a given name and type of handling.
     *
     * @param name
     *            calendar name (holidays set interested in). If there is set of
     *            holidays with that name, it will return a DateCalculator with
     *            an empty holiday set (will work on Weekend only).
     * @param holidayHandlerType
     *            typically one of the value of HolidayHandlerType or null.
     * @return a new DateCalculator
     * @exception IllegalArgumentException
     *                if the type is not null or a valid value.
     */
    DateCalculator getDateCalculator(String name, String holidayHandlerType);

    /**
     * Use this method to register a holidays calendar.
     *
     * @param calendarName
     *            the calendar name to register these holidays under.
     * @param holidaysCalendar
     *            the holiday calendar (non-working days with boundaries).
     */
    KitCalculatorsFactory registerHolidays(String calendarName, HolidayCalendar holidaysCalendar);

    /**
     * @return true if the holiday calendar name is registered.
     */
    boolean isHolidayCalendarRegistered(String calendarName);

    /**
     * @return an immutable Holiday Calendar name that is registered.
     */
    HolidayCalendar getHolidayCalendar(String calendarName);

    /**
     * @return an immutable set of registered calendar names
     */
    Set getRegisteredHolidayCalendarNames();

    /**
     * Unregister a given holiday calendar
     * @param calendarName
     *          the calendar name to unregister.
     */
    KitCalculatorsFactory unregisterHolidayCalendar(String calendarName);

    /**
     * unregister all holiday calendars;
     */
    KitCalculatorsFactory unregisterAllHolidayCalendars();

    // -----------------------------------------------------------------------
    //
    // ObjectLab, world leaders in the design and development of bespoke
    // applications for the securities financing markets.
    // www.ObjectLab.co.uk
    //
    // -----------------------------------------------------------------------

    /**
     * Create a new PeriodCountCalculator.
     *
     * @return a PeriodCountCalculator
     */
    PeriodCountCalculator getPeriodCountCalculator();

    /**
     * Create a new IMMDateCalculator.
     *
     * @return an IMMDateCalculator
     */
    IMMDateCalculator getIMMDateCalculator();

    /**
     * Create a new holiday handler of given type
     * @param holidayHandlerType
     * @return a new handler
     * @throws IllegalArgumentException if the holidayHandlerType is unsupported
     * @since 1.4.0
     */
    HolidayHandler getHolidayHandler(String holidayHandlerType);

}

/*
 * ObjectLab, http://www.objectlab.co.uk/open is sponsoring the ObjectLab Kit.
 *
 * Based in London, we are world leaders in the design and development
 * of bespoke applications for the securities financing markets.
 *
 * Click here to learn more about us
 *           ___  _     _           _   _          _
 *          / _ \| |__ (_) ___  ___| |_| |    __ _| |__
 *         | | | | '_ \| |/ _ \/ __| __| |   / _` | '_ \
 *         | |_| | |_) | |  __/ (__| |_| |__| (_| | |_) |
 *          \___/|_.__// |\___|\___|\__|_____\__,_|_.__/
 *                   |__/
 *
 *                     www.ObjectLab.co.uk
 */




© 2015 - 2025 Weber Informatics LLC | Privacy Policy