| /* |
| * Copyright 2001-2004 The Apache Software Foundation. |
| * |
| * 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. |
| */ |
| // This file is pulled from package org.apache.avalon.excalibur.cli Excalibur |
| // version 4.1 (Jan 30, 2002). Only the package name has been changed. |
| package org.apache.axis.utils; |
| |
| |
| /** |
| * CLUtil offers basic utility operations for use both internal and external to package. |
| * |
| * @author <a href="mailto:peter@apache.org">Peter Donald</a> |
| * @since 4.0 |
| */ |
| public final class CLUtil |
| { |
| private static final int MAX_DESCRIPTION_COLUMN_LENGTH = 60; |
| |
| /** |
| * Format options into StringBuffer and return. This is typically used to |
| * print "Usage" text in response to a "--help" or invalid option. |
| * |
| * @param options the option descriptors |
| * @return the formatted description/help for options |
| */ |
| public static final StringBuffer describeOptions( final CLOptionDescriptor[] options ) |
| { |
| final StringBuffer sb = new StringBuffer(); |
| |
| for( int i = 0; i < options.length; i++ ) |
| { |
| final char ch = (char) options[i].getId(); |
| final String name = options[i].getName(); |
| String description = options[i].getDescription(); |
| int flags = options[i].getFlags(); |
| boolean argumentRequired = |
| ( (flags & CLOptionDescriptor.ARGUMENT_REQUIRED) == |
| CLOptionDescriptor.ARGUMENT_REQUIRED); |
| boolean twoArgumentsRequired = |
| ( (flags & CLOptionDescriptor.ARGUMENTS_REQUIRED_2) == |
| CLOptionDescriptor.ARGUMENTS_REQUIRED_2); |
| boolean needComma = false; |
| if (twoArgumentsRequired) |
| argumentRequired = true; |
| |
| sb.append('\t'); |
| |
| if( Character.isLetter(ch) ) |
| { |
| sb.append( "-" ); |
| sb.append( ch ); |
| needComma = true; |
| } |
| |
| if( null != name ) |
| { |
| if( needComma ) |
| { |
| sb.append( ", " ); |
| } |
| |
| sb.append( "--" ); |
| sb.append( name ); |
| if (argumentRequired) |
| { |
| sb.append(" <argument>"); |
| } |
| if (twoArgumentsRequired) |
| { |
| sb.append("=<value>"); |
| } |
| sb.append( JavaUtils.LS ); |
| } |
| |
| if( null != description ) |
| { |
| while( description.length() > MAX_DESCRIPTION_COLUMN_LENGTH ) |
| { |
| final String descriptionPart = |
| description.substring( 0, MAX_DESCRIPTION_COLUMN_LENGTH ); |
| description = |
| description.substring( MAX_DESCRIPTION_COLUMN_LENGTH ); |
| sb.append( "\t\t" ); |
| sb.append( descriptionPart ); |
| sb.append( JavaUtils.LS ); |
| } |
| |
| sb.append( "\t\t" ); |
| sb.append( description ); |
| sb.append( JavaUtils.LS ); |
| } |
| } |
| return sb; |
| } |
| |
| /** |
| * Private Constructor so that no instance can ever be created. |
| * |
| */ |
| private CLUtil() |
| { |
| } |
| } |