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 import org.vmmagic.unboxed.Address;
017
018 /**
019 * An option with a simple integer value.
020 */
021 public class AddressOption extends Option {
022 // values
023 protected Address defaultValue;
024 protected Address value;
025
026 /**
027 * Create a new int option.
028 *
029 * @param set The option set this option belongs to.
030 * @param name The space separated name for the option.
031 * @param desc The purpose of the option
032 * @param defaultValue The default value of the option.
033 */
034 protected AddressOption(OptionSet set, String name, String desc, Address defaultValue) {
035 super(set, ADDRESS_OPTION, name, desc);
036 this.value = this.defaultValue = defaultValue;
037 }
038
039 /**
040 * Read the current value of the option.
041 *
042 * @return The option value.
043 */
044 @Uninterruptible
045 public Address getValue() {
046 return this.value;
047 }
048
049 /**
050 * Read the default value of the option.
051 *
052 * @return The default value.
053 */
054 @Uninterruptible
055 public Address getDefaultValue() {
056 return this.defaultValue;
057 }
058
059 /**
060 * Update the value of the option, echoing the change if the echoOptions
061 * option is set. This method also calls the validate method to allow
062 * subclasses to perform any required validation.
063 *
064 * @param value The new value for the option.
065 */
066 public void setValue(int value) {
067 this.value = Address.fromIntZeroExtend(value);
068 validate();
069 set.logChange(this);
070 }
071
072 /**
073 * Modify the default value of the option.
074 *
075 * @param value The new default value for the option.
076 */
077 public void setDefaultValue(Address value) {
078 this.value = this.defaultValue = value;
079 }
080 }