View Javadoc
1   package org.opentrafficsim.core.gtu.behavioralcharacteristics;
2   
3   import java.io.Serializable;
4   
5   import org.djunits.unit.DimensionlessUnit;
6   import org.djunits.value.vdouble.scalar.Dimensionless;
7   
8   import nl.tudelft.simulation.language.Throw;
9   
10  /**
11   * Wrapper class for boolean parameters.
12   * <p>
13   * Copyright (c) 2013-2017 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
14   * BSD-style license. See <a href="http://opentrafficsim.org/docs/current/license.html">OpenTrafficSim License</a>.
15   * <p>
16   * @version $Revision$, $LastChangedDate$, by $Author$, initial version Apr 13, 2016 <br>
17   * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
18   * @author <a href="http://www.transport.citg.tudelft.nl">Wouter Schakel</a>
19   */
20  public class ParameterTypeBoolean extends AbstractParameterType<Dimensionless> implements Serializable
21  {
22      /** */
23      private static final long serialVersionUID = 20160400L;
24  
25      /**
26       * Constructor without default value.
27       * @param id Short name of parameter.
28       * @param description Parameter description or full name.
29       */
30      public ParameterTypeBoolean(final String id, final String description)
31      {
32          this(id, description, false, false);
33      }
34  
35      /**
36       * Constructor with default value.
37       * @param id Short name of parameter.
38       * @param description Parameter description or full name.
39       * @param defaultValue Default value.
40       */
41      public ParameterTypeBoolean(final String id, final String description, final boolean defaultValue)
42      {
43          this(id, description, defaultValue, true);
44      }
45  
46      /**
47       * Private constructor with default value, which may check the default value.
48       * @param id Short name of parameter.
49       * @param description Parameter description or full name.
50       * @param defaultValue Default value.
51       * @param hasDefaultValue Whether to check the default value for null.
52       */
53      public ParameterTypeBoolean(final String id, final String description, final boolean defaultValue,
54              final boolean hasDefaultValue)
55      {
56          super(id, description, Dimensionless.class,
57                  hasDefaultValue ? new Dimensionless(defaultValue ? 1.0 : 0.0, DimensionlessUnit.SI) : null, null,
58                  hasDefaultValue);
59      }
60  
61      /** {@inheritDoc} */
62      public final Boolean getDefaultValue() throws ParameterException
63      {
64          Throw.when(null == this.defaultValue, ParameterException.class, "No default value was set for '%s'.", getId());
65          return super.defaultValue.si != 0.0;
66      }
67  
68      /** {@inheritDoc} */
69      public final String printValue(final BehavioralCharacteristics behavioralCharacteristics) throws ParameterException
70      {
71          return Boolean.toString(behavioralCharacteristics.getParameter(this));
72      }
73  
74      /** {@inheritDoc} */
75      @SuppressWarnings("checkstyle:designforextension")
76      @Override
77      public String toString()
78      {
79          return "ParameterTypeBoolean [id=" + getId() + ", description=" + getDescription() + "]";
80      }
81  
82  }