/* * Copyright 2008 Alin Dreghiciu. * * 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 org.ops4j.pax.exam.options; import static org.ops4j.lang.NullArgumentException.validateNotNull; /** * Option specifying a system property. * * @author Alin Dreghiciu (adreghiciu@gmail.com) * @since 0.3.0, December 10, 2008 */ public class SystemPropertyOption implements ValueOption<String> { /** * System property key (cannot be null or empty). */ private final String key; /** * System property value (can be null or empty). */ private String value; /** * Constructor. * * @param key * system property key (cannot be null or empty) * * @throws IllegalArgumentException * - If key is null or empty */ public SystemPropertyOption(final String key) { this.key = key; value = ""; } /** * Sets the system property value. * * @param _value * system property value (cannot be null, can be empty) * * @return itself, for fluent api usage * * @throws IllegalArgumentException * - If value is null */ public SystemPropertyOption value(final String _value) { validateNotNull(_value, "Value"); this.value = _value; return this; } /** * Getter. * * @return system property key (cannot be null or empty) */ public String getKey() { return key; } /** * Getter. * * @return system property value (cannot be null, can be empty) */ public String getValue() { return value; } /** * {@inheritDoc} */ @Override public String toString() { final StringBuilder sb = new StringBuilder(); sb.append("SystemPropertyOption"); sb.append("{key='").append(key).append('\''); sb.append(", value='").append(value).append('\''); sb.append('}'); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((key == null) ? 0 : key.hashCode()); result = prime * result + ((value == null) ? 0 : value.hashCode()); return result; } // CHECKSTYLE:OFF : generated code @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; SystemPropertyOption other = (SystemPropertyOption) obj; if (key == null) { if (other.key != null) return false; } else if (!key.equals(other.key)) return false; if (value == null) { if (other.value != null) return false; } else if (!value.equals(other.value)) return false; return true; } // CHECKSTYLE:ON }