Skip to content

Commit 3880640

Browse files
committed
Applying the patches from Brian Egge in CLI-133
git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/cli/branches/cli-1.0.x@544744 13f79535-47bb-0310-9956-ffa450edef68
1 parent 2b0a94a commit 3880640

3 files changed

Lines changed: 67 additions & 0 deletions

File tree

src/java/org/apache/commons/cli/Util.java

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,9 @@ class Util {
3333
*/
3434
static String stripLeadingHyphens(String str)
3535
{
36+
if (str == null) {
37+
return null;
38+
}
3639
if (str.startsWith("--"))
3740
{
3841
return str.substring(2, str.length());
Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
/**
2+
* Licensed to the Apache Software Foundation (ASF) under one or more
3+
* contributor license agreements. See the NOTICE file distributed with
4+
* this work for additional information regarding copyright ownership.
5+
* The ASF licenses this file to You under the Apache License, Version 2.0
6+
* (the "License"); you may not use this file except in compliance with
7+
* the License. You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*/
17+
package org.apache.commons.cli;
18+
19+
import junit.framework.TestCase;
20+
21+
/**
22+
* @author brianegge
23+
*/
24+
public class UtilTest extends TestCase {
25+
public void testStripLeadingHyphens() {
26+
assertEquals("f", Util.stripLeadingHyphens("-f"));
27+
assertEquals("foo", Util.stripLeadingHyphens("--foo"));
28+
assertNull(Util.stripLeadingHyphens(null));
29+
}
30+
}
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
/**
2+
* Licensed to the Apache Software Foundation (ASF) under one or more
3+
* contributor license agreements. See the NOTICE file distributed with
4+
* this work for additional information regarding copyright ownership.
5+
* The ASF licenses this file to You under the Apache License, Version 2.0
6+
* (the "License"); you may not use this file except in compliance with
7+
* the License. You may obtain a copy of the License at
8+
*
9+
* http://www.apache.org/licenses/LICENSE-2.0
10+
*
11+
* Unless required by applicable law or agreed to in writing, software
12+
* distributed under the License is distributed on an "AS IS" BASIS,
13+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14+
* See the License for the specific language governing permissions and
15+
* limitations under the License.
16+
*/
17+
package org.apache.commons.cli.bug;
18+
19+
import junit.framework.TestCase;
20+
import org.apache.commons.cli.*;
21+
22+
/**
23+
* @author brianegge
24+
*/
25+
public class BugCLI133Test extends TestCase {
26+
public void testOrder() throws ParseException {
27+
Option optionA = new Option("a", "first");
28+
Options opts = new Options();
29+
opts.addOption(optionA);
30+
PosixParser posixParser = new PosixParser();
31+
CommandLine line = posixParser.parse(opts, null);
32+
assertFalse(line.hasOption(null));
33+
}
34+
}

0 commit comments

Comments
 (0)