Mirror von
https://github.com/IntellectualSites/FastAsyncWorldEdit.git
synchronisiert 2025-01-11 18:10:52 +01:00
Merge pull request #368 from thislooksfun/feature/fix-tab-completion
Fix tab completion
Dieser Commit ist enthalten in:
Commit
13b4d5e88d
@ -654,6 +654,8 @@ public class WorldEditPlugin extends JavaPlugin { //implements TabCompleter
|
|||||||
int firstSpace = buffer.indexOf(' ');
|
int firstSpace = buffer.indexOf(' ');
|
||||||
if (firstSpace < 0) return;
|
if (firstSpace < 0) return;
|
||||||
String label = buffer.substring(0, firstSpace);
|
String label = buffer.substring(0, firstSpace);
|
||||||
|
// Strip leading slash, if present.
|
||||||
|
label = label.startsWith("/") ? label.substring(1) : label;
|
||||||
final Optional<org.enginehub.piston.Command> command
|
final Optional<org.enginehub.piston.Command> command
|
||||||
= WorldEdit.getInstance().getPlatformManager().getPlatformCommandManager().getCommandManager().getCommand(label);
|
= WorldEdit.getInstance().getPlatformManager().getPlatformCommandManager().getCommandManager().getCommand(label);
|
||||||
if (!command.isPresent()) return;
|
if (!command.isPresent()) return;
|
||||||
|
@ -815,7 +815,10 @@ public final class PlatformCommandManager {
|
|||||||
@Subscribe
|
@Subscribe
|
||||||
public void handleCommandSuggestion(CommandSuggestionEvent event) {
|
public void handleCommandSuggestion(CommandSuggestionEvent event) {
|
||||||
try {
|
try {
|
||||||
String arguments = event.getArguments();
|
String rawArgs = event.getArguments();
|
||||||
|
// Increase the resulting positions by 1 if we remove a leading `/`
|
||||||
|
final int posOffset = rawArgs.startsWith("/") ? 1 : 0;
|
||||||
|
String arguments = rawArgs.startsWith("/") ? rawArgs.substring(1) : rawArgs;
|
||||||
List<Substring> split = parseArgs(arguments).collect(Collectors.toList());
|
List<Substring> split = parseArgs(arguments).collect(Collectors.toList());
|
||||||
List<String> argStrings = split.stream()
|
List<String> argStrings = split.stream()
|
||||||
.map(Substring::getSubstring)
|
.map(Substring::getSubstring)
|
||||||
@ -837,11 +840,10 @@ public final class PlatformCommandManager {
|
|||||||
Substring original = suggestion.getReplacedArgument() == split.size()
|
Substring original = suggestion.getReplacedArgument() == split.size()
|
||||||
? Substring.from(arguments, noSlashLength, noSlashLength)
|
? Substring.from(arguments, noSlashLength, noSlashLength)
|
||||||
: split.get(suggestion.getReplacedArgument());
|
: split.get(suggestion.getReplacedArgument());
|
||||||
// increase original points by 1, for removed `/` in `parseArgs`
|
|
||||||
return Substring.wrap(
|
return Substring.wrap(
|
||||||
suggestion.getSuggestion(),
|
suggestion.getSuggestion(),
|
||||||
original.getStart() + 1,
|
original.getStart() + posOffset,
|
||||||
original.getEnd() + 1
|
original.getEnd() + posOffset
|
||||||
);
|
);
|
||||||
}).collect(Collectors.toList()));
|
}).collect(Collectors.toList()));
|
||||||
} catch (ConditionFailedException e) {
|
} catch (ConditionFailedException e) {
|
||||||
|
Laden…
x
In neuem Issue referenzieren
Einen Benutzer sperren