
org.refcodes.console.impls.AndConditionImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of refcodes-console Show documentation
Show all versions of refcodes-console Show documentation
Artifact for console issues regarding a CLI (command line interpreter)
frame, CLI commands or CLI interaction and so on.
// /////////////////////////////////////////////////////////////////////////////
// REFCODES.ORG
// /////////////////////////////////////////////////////////////////////////////
// This code is copyright (c) by Siegfried Steiner, Munich, Germany and licensed
// under the following (see "http://en.wikipedia.org/wiki/Multi-licensing")
// licenses:
// -----------------------------------------------------------------------------
// GNU General Public License, v3.0 ("http://www.gnu.org/licenses/gpl-3.0.html")
// -----------------------------------------------------------------------------
// Apache License, v2.0 ("http://www.apache.org/licenses/LICENSE-2.0")
// -----------------------------------------------------------------------------
// Please contact the copyright holding author(s) of the software artifacts in
// question for licensing issues not being covered by the above listed licenses,
// also regarding commercial licensing models or regarding the compatibility
// with other open source licenses.
// /////////////////////////////////////////////////////////////////////////////
package org.refcodes.console.impls;
import java.util.ArrayList;
import java.util.List;
import org.refcodes.console.AmbiguousArgsException;
import org.refcodes.console.Condition;
import org.refcodes.console.ConsoleUtility;
import org.refcodes.console.Operand;
import org.refcodes.console.ParseArgsException;
import org.refcodes.console.SyntaxNotation;
import org.refcodes.console.Syntaxable;
import org.refcodes.console.UnknownArgsException;
/**
* An {@link AndConditionImpl} represents a list of {@link Syntaxable} instances
* of which all are be parsed successfully when the {@link Syntaxable}s'
* {@link Syntaxable#parseArgs(String[])} methods are invoked. The command line
* arguments syntax -a & -b & -c specifies that all "-a", "-b" and "-c" must be
* set. In case at least one is not set, then the {@link AndConditionImpl} will
* terminate the {@link #parseArgs(String[])} method with an exception.
*/
public class AndConditionImpl extends AbstractCondition implements Condition {
// /////////////////////////////////////////////////////////////////////////
// STATIC:
// /////////////////////////////////////////////////////////////////////////
// /////////////////////////////////////////////////////////////////////////
// CONSTANTS:
// /////////////////////////////////////////////////////////////////////////
private static final char GUN_POSIX_AND = ' ';
private static final String LOGICAL_AND = " & ";
// /////////////////////////////////////////////////////////////////////////
// VARIABLES:
// /////////////////////////////////////////////////////////////////////////
// /////////////////////////////////////////////////////////////////////////
// CONSTRUCTORS:
// /////////////////////////////////////////////////////////////////////////
public AndConditionImpl( Syntaxable... aArgumentizers ) {
super( aArgumentizers );
}
// /////////////////////////////////////////////////////////////////////////
// METHODS:
// /////////////////////////////////////////////////////////////////////////
@SuppressWarnings("unchecked")
@Override
public List extends Operand>> parseArgs( String[] aArgs ) throws UnknownArgsException, AmbiguousArgsException, ParseArgsException {
List> theResult = new ArrayList>();
List> eOperands;
for ( Syntaxable e : getChildren() ) {
try {
eOperands = (List>) e.parseArgs( aArgs );
}
catch ( UnknownArgsException exc ) {
throw new UnknownArgsException( exc.getArgs(), "At least one AND operand (option ) did not matched the provided command line arguments; though allmust match.", exc );
}
catch ( AmbiguousArgsException exc ) {
throw new AmbiguousArgsException( exc.getArgs(), "At least one AND operand (option ) did not matched the provided command line arguments; though allmust match.", exc );
}
if ( eOperands != null ) {
theResult.addAll( (List extends Operand>>) eOperands );
}
aArgs = ConsoleUtility.toDiff( aArgs, eOperands );
}
return theResult;
}
@Override
public String parseSyntax( SyntaxNotation aSyntaxNotation ) {
StringBuilder theBuilder = new StringBuilder();
for ( Syntaxable eArgumentizer : getChildren() ) {
if ( theBuilder.length() != 0 ) {
if ( aSyntaxNotation == SyntaxNotation.REFCODES ) {
theBuilder.append( LOGICAL_AND );
}
else {
theBuilder.append( GUN_POSIX_AND );
}
}
theBuilder.append( eArgumentizer.toSyntax( aSyntaxNotation ) );
}
return theBuilder.toString();
}
@Override
public String toState() {
StringBuilder theBuilder = new StringBuilder();
for ( Syntaxable eArgumentizer : getChildren() ) {
if ( theBuilder.length() == 0 ) {
theBuilder.append( "( " );
}
else {
theBuilder.append( LOGICAL_AND );
}
theBuilder.append( eArgumentizer.toState() );
}
if ( theBuilder.length() != 0 ) {
theBuilder.append( " )" );
}
return theBuilder.toString();
}
// /////////////////////////////////////////////////////////////////////////
// HOOKS:
// /////////////////////////////////////////////////////////////////////////
// /////////////////////////////////////////////////////////////////////////
// HELPER:
// /////////////////////////////////////////////////////////////////////////
// /////////////////////////////////////////////////////////////////////////
// INNER CLASSES:
// /////////////////////////////////////////////////////////////////////////
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy