Skip to content

Commit

Permalink
[WFCORE-4916] Unclear attribute name completion for LIST type
Browse files Browse the repository at this point in the history
  • Loading branch information
ChristinaDsl committed Jun 29, 2023
1 parent c63f6cf commit e11d8b6
Show file tree
Hide file tree
Showing 6 changed files with 44 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -349,6 +349,11 @@ public Collection<String> getCandidates(ModelNode attrsDescr, boolean writeOnly)
candidateIndex += chunk.length();
}
candidates.add("[");
} else if (modelType.equals(ModelType.STRING) || modelType.equals(ModelType.INT) || modelType.equals(ModelType.BOOLEAN)){
if (candidates.isEmpty()) {
candidateIndex += chunk.length();
}
candidates.add("");
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@
import org.jboss.as.cli.parsing.StateParser.SubstitutedLine;
import org.jboss.logging.Logger;


/**
*
* @author Alexey Loubyansky
Expand Down Expand Up @@ -418,21 +417,21 @@ private int completeWithValueCompleter(CommandContext ctx, ParsedCommandLine par
// Implies a single candidate to inline, the value is complete.
// propose the property separator if more properties to come
// or the propertyListEnd if no more properties.
if (suggestionEqualsUserEntry(candidates, chunk, valueResult)) {
if (suggestionEqualsUserEntry(candidates, chunk, valueResult)|| areIncludedCandidatesForSpecificValueTypes(candidates)) {
final CommandLineFormat format = parsedCmd.getFormat();
if (format != null) {
for (CommandArgument arg : allArgs) {
try {
if (arg.canAppearNext(ctx)) {
candidates.set(0, "" + format.getPropertySeparator());
candidates.add("" + format.getPropertySeparator());
return buffer.length();
}
} catch (CommandFormatException e) {
return -1;
}
}
// inline the end of properties.
candidates.set(0, format.getPropertyListEnd());
candidates.add(format.getPropertyListEnd());
// at the end of the input.
return buffer.length();
}
Expand Down Expand Up @@ -734,12 +733,26 @@ private boolean suggestionEqualsUserEntry(List<String> candidates, String chunk,
return false;
}

if (suggestionOffset > 0) {
if (suggestionOffset > 0 && candidates.get(0)!="") {
// user entry before suggestionOffset is always the same - compare only part after offset
return chunk.substring(suggestionOffset).equals(candidates.get(0));
} else {
return chunk.equals(candidates.get(0));
if(chunk.equals(candidates.get(0))){
candidates.clear();
return true;
}
return false;
}
}

boolean areIncludedCandidatesForSpecificValueTypes(List<String> candidates){
if(candidates.contains("[") || candidates.contains(".")){
return true;
}else if(candidates.contains("")){
candidates.remove("");
return true;
}
return false;
}

protected CommandLineCompleter getValueCompleter(CommandContext ctx, Iterable<CommandArgument> allArgs, final String argName) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -444,7 +444,7 @@ protected List<CommandArgument> getPropertiesFromPropList(List<Property> propLis
if(ctx.getParsedCommandLine().getLastParsedPropertyValue() == null) {
radical = ctx.getParsedCommandLine().getLastParsedPropertyName();
//Check if the property is completely specified and is negated
if(ctx.getParsedCommandLine().isLastPropertyNegated()) {
if(ctx.getParsedCommandLine().isLastPropertyNegated() || radical!=null) {
for (Property prop : propList) {
if(radical.equals(prop.getName())){
radical = null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ public void testMain() throws Exception {

candidates.clear();
i = completer.complete(null, "str", 0, candidates);
assertEquals(Arrays.asList("str2"), candidates);
assertEquals(Arrays.asList("", "str2"), candidates);
assertEquals(0, i);

candidates.clear();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1158,10 +1158,12 @@ public void testCommandsCompletion2() throws Exception {
List<String> candidates = new ArrayList<>();
ctx.getDefaultCommandCompleter().complete(ctx, cmd,
cmd.length(), candidates);
assertTrue(candidates.toString(), candidates.size() == 1);
assertTrue(candidates.toString(), candidates.size() == 2);
assertTrue(candidates.toString(), candidates.contains(" "));
assertTrue(candidates.toString(), candidates.contains("namespaces"));
candidates = complete(ctx, cmd, false, cmd.length() - "name".length());
assertTrue(candidates.toString(), candidates.size() == 1);
candidates = complete(ctx, cmd, false, cmd.length());
assertTrue(candidates.toString(), candidates.size() == 2);
assertTrue(candidates.toString(), candidates.contains(" "));
assertTrue(candidates.toString(), candidates.contains("namespaces"));
}

Expand All @@ -1175,6 +1177,17 @@ public void testCommandsCompletion2() throws Exception {
assertTrue(candidates.toString(), candidates.isEmpty());
}

{
String cmd = "read-attribute management-minor-version";
List<String> candidates = new ArrayList<>();
ctx.getDefaultCommandCompleter().complete(ctx, cmd,
cmd.length(), candidates);
assertTrue(candidates.toString(), candidates.size() == 1);
assertTrue(candidates.toString(), candidates.contains(" "));
candidates = complete(ctx, cmd, false, cmd.length());
assertTrue(candidates.toString(), candidates.contains(" "));
}

{
String cmd = "read-operation --node";
List<String> candidates = new ArrayList<>();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,8 @@ public void testAttachment() throws Exception {
cli.getCommandContext().getDefaultCommandCompleter().complete(cli.getCommandContext(), cmd,
cmd.length(), candidates);
assertTrue(candidates.toString(), candidates.contains("["));
assertTrue(candidates.toString(), candidates.size() == 1);
assertTrue(candidates.toString(), candidates.contains(")"));
assertTrue(candidates.toString(), candidates.size() == 2);
}

{
Expand Down

0 comments on commit e11d8b6

Please sign in to comment.