Mirror von
https://github.com/IntellectualSites/FastAsyncWorldEdit.git
synchronisiert 2024-11-05 11:00:05 +01:00
Improved the permissions list printer to handle nested commands.
Dieser Commit ist enthalten in:
Ursprung
b2547b2156
Commit
35ae72e8b7
@ -22,9 +22,11 @@ package com.sk89q.worldedit.dev;
|
|||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import com.sk89q.minecraft.util.commands.Command;
|
import com.sk89q.minecraft.util.commands.Command;
|
||||||
import com.sk89q.minecraft.util.commands.CommandPermissions;
|
import com.sk89q.minecraft.util.commands.CommandPermissions;
|
||||||
|
import com.sk89q.minecraft.util.commands.NestedCommand;
|
||||||
import com.sk89q.util.StringUtil;
|
import com.sk89q.util.StringUtil;
|
||||||
import com.sk89q.worldedit.commands.ChunkCommands;
|
import com.sk89q.worldedit.commands.ChunkCommands;
|
||||||
import com.sk89q.worldedit.commands.ClipboardCommands;
|
import com.sk89q.worldedit.commands.ClipboardCommands;
|
||||||
@ -99,7 +101,7 @@ public class DocumentationPrinter {
|
|||||||
try {
|
try {
|
||||||
stream = new FileOutputStream("wiki_permissions.txt");
|
stream = new FileOutputStream("wiki_permissions.txt");
|
||||||
PrintStream print = new PrintStream(stream);
|
PrintStream print = new PrintStream(stream);
|
||||||
_writePermissionsWikiTable(print, commandClasses);
|
_writePermissionsWikiTable(print, commandClasses, "/");
|
||||||
} finally {
|
} finally {
|
||||||
if (stream != null) {
|
if (stream != null) {
|
||||||
stream.close();
|
stream.close();
|
||||||
@ -108,7 +110,7 @@ public class DocumentationPrinter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static void _writePermissionsWikiTable(PrintStream stream,
|
private static void _writePermissionsWikiTable(PrintStream stream,
|
||||||
List<Class<?>> commandClasses) {
|
List<Class<?>> commandClasses, String prefix) {
|
||||||
|
|
||||||
for (Class<?> cls : commandClasses) {
|
for (Class<?> cls : commandClasses) {
|
||||||
for (Method method : cls.getMethods()) {
|
for (Method method : cls.getMethods()) {
|
||||||
@ -119,7 +121,7 @@ public class DocumentationPrinter {
|
|||||||
Command cmd = method.getAnnotation(Command.class);
|
Command cmd = method.getAnnotation(Command.class);
|
||||||
|
|
||||||
stream.println("|-");
|
stream.println("|-");
|
||||||
stream.print("| /" + cmd.aliases()[0]);
|
stream.print("| " + prefix + cmd.aliases()[0]);
|
||||||
stream.print(" || ");
|
stream.print(" || ");
|
||||||
|
|
||||||
if (method.isAnnotationPresent(CommandPermissions.class)) {
|
if (method.isAnnotationPresent(CommandPermissions.class)) {
|
||||||
@ -136,6 +138,16 @@ public class DocumentationPrinter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
stream.println();
|
stream.println();
|
||||||
|
|
||||||
|
if (method.isAnnotationPresent(NestedCommand.class)) {
|
||||||
|
NestedCommand nested =
|
||||||
|
method.getAnnotation(NestedCommand.class);
|
||||||
|
|
||||||
|
Class<?>[] nestedClasses = nested.value();
|
||||||
|
_writePermissionsWikiTable(stream,
|
||||||
|
Arrays.asList(nestedClasses),
|
||||||
|
prefix + cmd.aliases()[0] + " ");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren