Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
CommandBuilder |
|
| 1.3333333333333333;1.333 |
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.cli2.builder; | |
18 | ||
19 | import java.util.HashSet; | |
20 | import java.util.Set; | |
21 | ||
22 | import org.apache.commons.cli2.Argument; | |
23 | import org.apache.commons.cli2.Group; | |
24 | import org.apache.commons.cli2.option.Command; | |
25 | import org.apache.commons.cli2.resource.ResourceConstants; | |
26 | import org.apache.commons.cli2.resource.ResourceHelper; | |
27 | ||
28 | /** | |
29 | * Builds Command instances | |
30 | */ | |
31 | public class CommandBuilder { | |
32 | /** the preferred name of the command */ | |
33 | private String preferredName; | |
34 | ||
35 | /** the description of the command */ | |
36 | private String description; | |
37 | ||
38 | /** the aliases of the command */ | |
39 | private Set aliases; | |
40 | ||
41 | /** whether the command is required or not */ | |
42 | private boolean required; | |
43 | ||
44 | /** the argument of the command */ | |
45 | private Argument argument; | |
46 | ||
47 | /** the children of the command */ | |
48 | private Group children; | |
49 | ||
50 | /** the id of the command */ | |
51 | private int id; | |
52 | ||
53 | /** | |
54 | * Creates a new <code>CommandBuilder</code> instance. | |
55 | */ | |
56 | 12 | public CommandBuilder() { |
57 | 12 | reset(); |
58 | 12 | } |
59 | ||
60 | /** | |
61 | * Creates a new <code>Command</code> instance using the properties of the | |
62 | * <code>CommandBuilder</code>. | |
63 | * | |
64 | * @return the new Command instance | |
65 | */ | |
66 | public Command create() { | |
67 | // check we have a valid name | |
68 | 37 | if (preferredName == null) { |
69 | 1 | throw new IllegalStateException(ResourceHelper.getResourceHelper().getMessage(ResourceConstants.OPTION_NO_NAME)); |
70 | } | |
71 | ||
72 | // build the command | |
73 | 36 | final Command option = |
74 | new Command(preferredName, description, aliases, required, argument, children, id); | |
75 | ||
76 | // reset the builder | |
77 | 36 | reset(); |
78 | ||
79 | 36 | return option; |
80 | } | |
81 | ||
82 | /** | |
83 | * Resets the CommandBuilder to the defaults for a new Command. | |
84 | * | |
85 | * This method is called automatically at the end of the | |
86 | * {@link #create() create} method. | |
87 | * @return this <code>CommandBuilder</code> | |
88 | */ | |
89 | public CommandBuilder reset() { | |
90 | 48 | preferredName = null; |
91 | 48 | description = null; |
92 | 48 | aliases = new HashSet(); |
93 | 48 | required = false; |
94 | 48 | argument = null; |
95 | 48 | children = null; |
96 | 48 | id = 0; |
97 | ||
98 | 48 | return this; |
99 | } | |
100 | ||
101 | /** | |
102 | * Specifies the name for the next <code>Command</code> | |
103 | * that is created. The first name is used as the preferred | |
104 | * display name for the <code>Command</code> and then | |
105 | * later names are used as aliases. | |
106 | * | |
107 | * @param name the name for the next <code>Command</code> | |
108 | * that is created. | |
109 | * @return this <code>CommandBuilder</code>. | |
110 | */ | |
111 | public CommandBuilder withName(final String name) { | |
112 | 87 | if (preferredName == null) { |
113 | 36 | preferredName = name; |
114 | } else { | |
115 | 51 | aliases.add(name); |
116 | } | |
117 | ||
118 | 87 | return this; |
119 | } | |
120 | ||
121 | /** | |
122 | * Specifies the description for the next <code>Command</code> | |
123 | * that is created. This description is used to produce | |
124 | * help documentation for the <code>Command</code>. | |
125 | * | |
126 | * @param newDescription the description for the next | |
127 | * <code>Command</code> that is created. | |
128 | * @return this <code>CommandBuilder</code>. | |
129 | */ | |
130 | public CommandBuilder withDescription(final String newDescription) { | |
131 | 26 | this.description = newDescription; |
132 | ||
133 | 26 | return this; |
134 | } | |
135 | ||
136 | /** | |
137 | * Specifies whether the next <code>Command</code> created is | |
138 | * required or not. | |
139 | * @param newRequired whether the next <code>Command</code> created is | |
140 | * required or not. | |
141 | * @return this <code>CommandBuilder</code>. | |
142 | */ | |
143 | public CommandBuilder withRequired(final boolean newRequired) { | |
144 | 1 | this.required = newRequired; |
145 | ||
146 | 1 | return this; |
147 | } | |
148 | ||
149 | /** | |
150 | * Specifies the children for the next <code>Command</code> | |
151 | * that is created. | |
152 | * | |
153 | * @param newChildren the child options for the next <code>Command</code> | |
154 | * that is created. | |
155 | * @return this <code>CommandBuilder</code>. | |
156 | */ | |
157 | public CommandBuilder withChildren(final Group newChildren) { | |
158 | 8 | this.children = newChildren; |
159 | ||
160 | 8 | return this; |
161 | } | |
162 | ||
163 | /** | |
164 | * Specifies the argument for the next <code>Command</code> | |
165 | * that is created. | |
166 | * | |
167 | * @param newArgument the argument for the next <code>Command</code> | |
168 | * that is created. | |
169 | * @return this <code>CommandBuilder</code>. | |
170 | */ | |
171 | public CommandBuilder withArgument(final Argument newArgument) { | |
172 | 8 | this.argument = newArgument; |
173 | ||
174 | 8 | return this; |
175 | } | |
176 | ||
177 | /** | |
178 | * Specifies the id for the next <code>Command</code> that is created. | |
179 | * | |
180 | * @param newId the id for the next <code>Command</code> that is created. | |
181 | * @return this <code>CommandBuilder</code>. | |
182 | */ | |
183 | public final CommandBuilder withId(final int newId) { | |
184 | 1 | this.id = newId; |
185 | ||
186 | 1 | return this; |
187 | } | |
188 | } |