001    /*
002     *  This file is part of the Jikes RVM project (http://jikesrvm.org).
003     *
004     *  This file is licensed to You under the Eclipse Public License (EPL);
005     *  You may not use this file except in compliance with the License. You
006     *  may obtain a copy of the License at
007     *
008     *      http://www.opensource.org/licenses/eclipse-1.0.php
009     *
010     *  See the COPYRIGHT.txt file distributed with this work for information
011     *  regarding copyright ownership.
012     */
013    package org.vmutil.options;
014    
015    import org.vmmagic.pragma.Uninterruptible;
016    
017    /**
018     * Base class for boolean options.
019     */
020    public class BooleanOption extends Option {
021      // values
022      protected boolean defaultValue;
023      protected boolean value;
024    
025      /**
026       * Create a new boolean option.
027       *
028       * @param set The option set this option belongs to.
029       * @param name The space separated name for the option.
030       * @param desc The purpose of the option
031       * @param defaultValue The default value of the option.
032       */
033      protected BooleanOption(OptionSet set, String name, String desc, boolean defaultValue) {
034        super(set, BOOLEAN_OPTION, name, desc);
035        this.value = this.defaultValue = defaultValue;
036      }
037    
038      /**
039       * Read the current value of the option.
040       *
041       * @return The option value.
042       */
043      @Uninterruptible
044      public boolean getValue() {
045        return this.value;
046      }
047    
048      /**
049       * Read the default value of the option.
050       *
051       * @return The default value.
052       */
053      @Uninterruptible
054      public boolean getDefaultValue() {
055        return this.defaultValue;
056      }
057    
058      /**
059       * Update the value of the option, echoing the change if the echoOptions
060       * option is set. This method also calls the validate method to allow
061       * subclasses to perform any required validation.
062       *
063       * @param value The new value for the option.
064       */
065      public void setValue(boolean value) {
066        this.value = value;
067        validate();
068        set.logChange(this);
069      }
070    
071      /**
072       * Modify the default value of the option.
073       *
074       * @param value The new default value for the option.
075       */
076      public void setDefaultValue(boolean value) {
077        this.value = this.defaultValue = value;
078      }
079    }