/* * 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.*; import org.ops4j.pax.exam.Option; /** * Option specifying a system property. * * @author Alin Dreghiciu (adreghiciu@gmail.com) * @since 0.3.0, December 10, 2008 */ public class SystemPropertyOption implements Option { /** * System property key (cannot be null or empty). */ private final String m_key; /** * System property value (can be null or empty). */ private String m_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 ) { m_key = key; m_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" ); m_value = value; return this; } /** * Getter. * * @return system property key (cannot be null or empty) */ public String getKey() { return m_key; } /** * Getter. * * @return system property value (cannot be null, can be empty) */ public String getValue() { return m_value; } /** * {@inheritDoc} */ @Override public String toString() { final StringBuilder sb = new StringBuilder(); sb.append( "SystemPropertyOption" ); sb.append( "{key='" ).append( m_key ).append( '\'' ); sb.append( ", value='" ).append( m_value ).append( '\'' ); sb.append( '}' ); return sb.toString(); } }