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

com.opengamma.strata.product.common.LongShort Maven / Gradle / Ivy

/*
 * Copyright (C) 2014 - present by OpenGamma Inc. and the OpenGamma group of companies
 *
 * Please see distribution for license.
 */
package com.opengamma.strata.product.common;

import org.joda.convert.FromString;
import org.joda.convert.ToString;

import com.opengamma.strata.collect.named.EnumNames;
import com.opengamma.strata.collect.named.NamedEnum;

/**
 * Flag indicating whether a trade is "long" or "short".
 * 

* A long position is one where a financial instrument is bought with the expectation * that its value will rise. A short position is the opposite where the expectation * is that its value will fall, usually applied to the sale of a borrowed asset. */ public enum LongShort implements NamedEnum { /** * Long. */ LONG(1), /** * Short. */ SHORT(-1); // helper for name conversions private static final EnumNames NAMES = EnumNames.of(LongShort.class); /** * True if long, used to avoid a branch. */ private final boolean isLong; /** * The sign, used to avoid a branch. */ private final int sign; //------------------------------------------------------------------------- /** * Obtains an instance from the specified name. *

* Parsing handles the mixed case form produced by {@link #toString()} and * the upper and lower case variants of the enum constant name. * * @param name the name to parse * @return the type * @throws IllegalArgumentException if the name is not known */ @FromString public static LongShort of(String name) { return NAMES.parse(name); } //------------------------------------------------------------------------- /** * Converts a boolean "is long" flag to the enum value. * * @param isLong the long flag, true for long, false for short * @return the equivalent enum */ public static LongShort ofLong(boolean isLong) { return isLong ? LONG : SHORT; } // Restricted constructor private LongShort(int sign) { this.isLong = (sign == 1); this.sign = sign; } //------------------------------------------------------------------------- /** * Checks if the type is 'Long'. * * @return true if long, false if short */ public boolean isLong() { return isLong; } /** * Checks if the type is 'Short'. * * @return true if short, false if long */ public boolean isShort() { return !isLong; } /** * Returns the sign, where 'Long' returns 1 and 'Short' returns -1. * * @return 1 if long, -1 if short */ public int sign() { return sign; } //------------------------------------------------------------------------- /** * Supplies the opposite of this value. * * @return the opposite value */ public LongShort opposite() { return isLong() ? SHORT : LONG; } //------------------------------------------------------------------------- /** * Returns the formatted name of the type. * * @return the formatted string representing the type */ @ToString @Override public String toString() { return NAMES.format(this); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy